forked from pool/apache2-mod_perl
		
	Accepting request 448261 from home:AndreasStieger:branches:Apache:Modules
update to 2.0.10 OBS-URL: https://build.opensuse.org/request/show/448261 OBS-URL: https://build.opensuse.org/package/show/Apache:Modules/apache2-mod_perl?expand=0&rev=66
This commit is contained in:
		| @@ -1,3 +1,13 @@ | |||||||
|  | ------------------------------------------------------------------- | ||||||
|  | Fri Dec 30 13:50:32 UTC 2016 - astieger@suse.com | ||||||
|  |  | ||||||
|  | - update to 2.0.10: | ||||||
|  |   * Automatically select the appropriate c89 option when modperl is | ||||||
|  |     being built with either gcc 5 or clang | ||||||
|  |   * Fix non-threaded Perl 5.22.x build and tests | ||||||
|  |   * Add support for Perl 5.22.x | ||||||
|  |     drop upstreamed mod_perl-add_support_for_perl_5.22.patch | ||||||
|  |  | ||||||
| ------------------------------------------------------------------- | ------------------------------------------------------------------- | ||||||
| Mon Oct  3 11:15:45 UTC 2016 - tchvatal@suse.com | Mon Oct  3 11:15:45 UTC 2016 - tchvatal@suse.com | ||||||
|  |  | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ | |||||||
|  |  | ||||||
| %define srcname mod_perl | %define srcname mod_perl | ||||||
| Name:           apache2-mod_perl | Name:           apache2-mod_perl | ||||||
| Version:        2.0.9 | Version:        2.0.10 | ||||||
| Release:        0 | Release:        0 | ||||||
| Summary:        Embedded Perl for Apache | Summary:        Embedded Perl for Apache | ||||||
| License:        Apache-2.0 | License:        Apache-2.0 | ||||||
| @@ -26,8 +26,6 @@ Group:          Productivity/Networking/Web/Servers | |||||||
| Url:            http://perl.apache.org/ | Url:            http://perl.apache.org/ | ||||||
| Source0:        http://apache.miloslavbrada.cz/perl/%{srcname}-%{version}.tar.gz | Source0:        http://apache.miloslavbrada.cz/perl/%{srcname}-%{version}.tar.gz | ||||||
| Patch1:         avoid-broken-provides.diff | Patch1:         avoid-broken-provides.diff | ||||||
| # PATCH-FIX-UPSTREAM http://svn.apache.org/viewvc?view=revision&revision=1717474 |  | ||||||
| Patch2:         mod_perl-add_support_for_perl_5.22.patch |  | ||||||
| BuildRequires:  apache-rpm-macros | BuildRequires:  apache-rpm-macros | ||||||
| BuildRequires:  apache2-devel | BuildRequires:  apache2-devel | ||||||
| BuildRequires:  db-devel | BuildRequires:  db-devel | ||||||
| @@ -82,7 +80,6 @@ software depending on apache2-mod_perl. | |||||||
| %prep | %prep | ||||||
| %setup -q -n %{srcname}-%{version} | %setup -q -n %{srcname}-%{version} | ||||||
| %patch1 -p1 | %patch1 -p1 | ||||||
| %patch2 |  | ||||||
|  |  | ||||||
| %build | %build | ||||||
| perl Makefile.PL INSTALLDIRS=vendor MP_APXS=%{apache_apxs} MP_APR_CONFIG=%{_bindir}/apr-1-config MP_CCOPTS="%{apache_cflags} -fgnu89-inline" | perl Makefile.PL INSTALLDIRS=vendor MP_APXS=%{apache_apxs} MP_APR_CONFIG=%{_bindir}/apr-1-config MP_CCOPTS="%{apache_cflags} -fgnu89-inline" | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								mod_perl-2.0.10.tar.gz
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								mod_perl-2.0.10.tar.gz
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | version https://git-lfs.github.com/spec/v1 | ||||||
|  | oid sha256:d1cf83ed4ea3a9dfceaa6d9662ff645177090749881093051020bf42f9872b64 | ||||||
|  | size 3846211 | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| version https://git-lfs.github.com/spec/v1 |  | ||||||
| oid sha256:0260f26ab771c1c95fadc67544b3400e420bb30b8a77565d2d02ad05498ef52b |  | ||||||
| size 3846584 |  | ||||||
| @@ -1,262 +0,0 @@ | |||||||
| Index: t/response/TestModperl/env.pm |  | ||||||
| =================================================================== |  | ||||||
| --- t/response/TestModperl/env.pm.orig	2015-06-18 22:13:58.000000000 +0200 |  | ||||||
| +++ t/response/TestModperl/env.pm	2015-12-16 14:57:47.432881096 +0100 |  | ||||||
| @@ -15,7 +15,7 @@ use Apache2::Const -compile => 'OK'; |  | ||||||
|  sub handler { |  | ||||||
|      my $r = shift; |  | ||||||
|   |  | ||||||
| -    plan $r, tests => 23 + keys(%ENV); |  | ||||||
| +    plan $r, tests => 23 + 3 * keys(%ENV); |  | ||||||
|   |  | ||||||
|      my $env = $r->subprocess_env; |  | ||||||
|   |  | ||||||
| @@ -75,6 +75,8 @@ sub handler { |  | ||||||
|      for my $key (sort keys %ENV) { |  | ||||||
|          eval { delete $ENV{$key}; }; |  | ||||||
|          ok t_cmp($@, '', $key); |  | ||||||
| +        ok t_cmp($ENV{$key}, undef, "ENV{$key} is empty"); |  | ||||||
| +        ok t_cmp($env->get($key), undef, "subprocess_env($key) is empty"); |  | ||||||
|      } |  | ||||||
|   |  | ||||||
|      Apache2::Const::OK; |  | ||||||
| Index: Changes |  | ||||||
| =================================================================== |  | ||||||
| --- Changes.orig	2015-06-18 22:13:50.000000000 +0200 |  | ||||||
| +++ Changes	2015-12-16 14:57:47.433881111 +0100 |  | ||||||
| @@ -10,6 +10,8 @@ Also refer to the Apache::Test changes l |  | ||||||
|   |  | ||||||
|  =over 3 |  | ||||||
|   |  | ||||||
| +Add support for Perl 5.22.x. [Niko Tyni <ntyni@iki.fi>, Steve Hay] |  | ||||||
| + |  | ||||||
|  =item 2.0.9 June 18, 2015 |  | ||||||
|   |  | ||||||
|  Add note to README about MP_INLINE problem when building with GCC 5. |  | ||||||
| Index: src/modules/perl/mod_perl.c |  | ||||||
| =================================================================== |  | ||||||
| --- src/modules/perl/mod_perl.c.orig	2015-06-18 22:13:55.000000000 +0200 |  | ||||||
| +++ src/modules/perl/mod_perl.c	2015-12-16 14:57:47.434881127 +0100 |  | ||||||
| @@ -262,6 +262,8 @@ PerlInterpreter *modperl_startup(server_ |  | ||||||
|          exit(1); |  | ||||||
|      } |  | ||||||
|   |  | ||||||
| +    modperl_env_init(aTHX); |  | ||||||
| + |  | ||||||
|      /* suspend END blocks to be run at server shutdown */ |  | ||||||
|      endav = PL_endav; |  | ||||||
|      PL_endav = (AV *)NULL; |  | ||||||
| @@ -576,9 +578,6 @@ static apr_status_t modperl_sys_init(voi |  | ||||||
|      /* modifies PL_ppaddr */ |  | ||||||
|      modperl_perl_pp_set_all(); |  | ||||||
|   |  | ||||||
| -    /* modifies PL_vtbl_env{elem} */ |  | ||||||
| -    modperl_env_init(); |  | ||||||
| - |  | ||||||
|      return APR_SUCCESS; |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| @@ -597,8 +596,6 @@ static apr_status_t modperl_sys_term(voi |  | ||||||
|   |  | ||||||
|      MP_TRACE_i(MP_FUNC, "mod_perl sys term"); |  | ||||||
|   |  | ||||||
| -    modperl_env_unload(); |  | ||||||
| - |  | ||||||
|      modperl_perl_pp_unset_all(); |  | ||||||
|   |  | ||||||
|      PERL_SYS_TERM(); |  | ||||||
| Index: src/modules/perl/modperl_env.c |  | ||||||
| =================================================================== |  | ||||||
| --- src/modules/perl/modperl_env.c.orig	2015-06-18 22:13:54.000000000 +0200 |  | ||||||
| +++ src/modules/perl/modperl_env.c	2015-12-16 14:57:47.434881127 +0100 |  | ||||||
| @@ -121,6 +121,7 @@ static void modperl_env_table_populate(p |  | ||||||
|      const apr_array_header_t *array; |  | ||||||
|      apr_table_entry_t *elts; |  | ||||||
|   |  | ||||||
| +    modperl_env_init(aTHX); |  | ||||||
|      modperl_env_untie(mg_flags); |  | ||||||
|   |  | ||||||
|      array = apr_table_elts(table); |  | ||||||
| @@ -431,14 +432,10 @@ void modperl_env_request_untie(pTHX_ req |  | ||||||
|  #endif |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| -/* to store the original virtual tables |  | ||||||
| - * these are global, not per-interpreter |  | ||||||
| +/* handy access to perl's original virtual tables |  | ||||||
|   */ |  | ||||||
| -static MGVTBL MP_PERL_vtbl_env; |  | ||||||
| -static MGVTBL MP_PERL_vtbl_envelem; |  | ||||||
| - |  | ||||||
|  #define MP_PL_vtbl_call(name, meth) \ |  | ||||||
| -    MP_PERL_vtbl_##name.svt_##meth(aTHX_ sv, mg) |  | ||||||
| +    PL_vtbl_##name.svt_##meth(aTHX_ sv, mg) |  | ||||||
|   |  | ||||||
|  #define MP_dENV_KEY \ |  | ||||||
|      STRLEN klen; \ |  | ||||||
| @@ -529,6 +526,26 @@ static int modperl_env_magic_clear_all(p |  | ||||||
|      return 0; |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| +static int modperl_env_magic_copy(pTHX_ SV *sv, MAGIC *mg, SV *nsv, const char *name, I32 namlen) |  | ||||||
| +{ |  | ||||||
| +    MP_TRACE_e(MP_FUNC, "setting up %%ENV element magic"); |  | ||||||
| +    sv_magicext(nsv, mg->mg_obj, toLOWER(mg->mg_type), &MP_vtbl_envelem, name, namlen); |  | ||||||
| + |  | ||||||
| +    return 1; |  | ||||||
| +} |  | ||||||
| + |  | ||||||
| +static int modperl_env_magic_local_all(pTHX_ SV *nsv, MAGIC *mg) |  | ||||||
| +{ |  | ||||||
| +    MAGIC *nmg; |  | ||||||
| +    MP_TRACE_e(MP_FUNC, "localizing %%ENV"); |  | ||||||
| +    nmg = sv_magicext(nsv, mg->mg_obj, mg->mg_type, &MP_vtbl_env, (char*)NULL, 0); |  | ||||||
| +    nmg->mg_ptr = mg->mg_ptr; |  | ||||||
| +    nmg->mg_flags |= MGf_COPY; |  | ||||||
| +    nmg->mg_flags |= MGf_LOCAL; |  | ||||||
| + |  | ||||||
| +    return 1; |  | ||||||
| +} |  | ||||||
| + |  | ||||||
|  static int modperl_env_magic_set(pTHX_ SV *sv, MAGIC *mg) |  | ||||||
|  { |  | ||||||
|      request_rec *r = (request_rec *)EnvMgObj; |  | ||||||
| @@ -613,15 +630,18 @@ static int modperl_env_magic_get(pTHX_ S |  | ||||||
|  #endif |  | ||||||
|   |  | ||||||
|  /* override %ENV virtual tables with our own */ |  | ||||||
| -static MGVTBL MP_vtbl_env = { |  | ||||||
| +MGVTBL MP_vtbl_env = { |  | ||||||
|      0, |  | ||||||
|      modperl_env_magic_set_all, |  | ||||||
|      0, |  | ||||||
|      modperl_env_magic_clear_all, |  | ||||||
| -    0 |  | ||||||
| +    0, |  | ||||||
| +    modperl_env_magic_copy, |  | ||||||
| +    0, |  | ||||||
| +    modperl_env_magic_local_all |  | ||||||
|  }; |  | ||||||
|   |  | ||||||
| -static MGVTBL MP_vtbl_envelem = { |  | ||||||
| +MGVTBL MP_vtbl_envelem = { |  | ||||||
|      0, |  | ||||||
|      modperl_env_magic_set, |  | ||||||
|      0, |  | ||||||
| @@ -629,22 +649,64 @@ static MGVTBL MP_vtbl_envelem = { |  | ||||||
|      0 |  | ||||||
|  }; |  | ||||||
|   |  | ||||||
| -void modperl_env_init(void) |  | ||||||
| +void modperl_env_init(pTHX) |  | ||||||
|  { |  | ||||||
| -    /* save originals */ |  | ||||||
| -    StructCopy(&PL_vtbl_env, &MP_PERL_vtbl_env, MGVTBL); |  | ||||||
| -    StructCopy(&PL_vtbl_envelem, &MP_PERL_vtbl_envelem, MGVTBL); |  | ||||||
| +    MAGIC *mg; |  | ||||||
| + |  | ||||||
| +    /* Find the 'E' magic on %ENV */ |  | ||||||
| +    if (!my_perl) |  | ||||||
| +        return; |  | ||||||
| +    if (!PL_envgv) |  | ||||||
| +        return; |  | ||||||
| +    if (!SvRMAGICAL(ENVHV)) |  | ||||||
| +        return; |  | ||||||
| +    mg = mg_find((const SV *)ENVHV, PERL_MAGIC_env); |  | ||||||
| +    if (!mg) |  | ||||||
| +        return; |  | ||||||
| +        |  | ||||||
| +    /* Ignore it if it isn't perl's original version */ |  | ||||||
| +    if (mg->mg_virtual != &PL_vtbl_env) |  | ||||||
| +        return; |  | ||||||
| + |  | ||||||
| +    MP_TRACE_e(MP_FUNC, "env_init - ptr: %x obj: %x flags: %x", |  | ||||||
| +               mg->mg_ptr, mg->mg_obj, mg->mg_flags); |  | ||||||
|   |  | ||||||
| -    /* replace with our versions */ |  | ||||||
| -    StructCopy(&MP_vtbl_env, &PL_vtbl_env, MGVTBL); |  | ||||||
| -    StructCopy(&MP_vtbl_envelem, &PL_vtbl_envelem, MGVTBL); |  | ||||||
| +    /* Remove it */ |  | ||||||
| +    mg_free_type((SV*)ENVHV, PERL_MAGIC_env); |  | ||||||
| + |  | ||||||
| +    /* Add our version instead */ |  | ||||||
| +    mg = sv_magicext((SV*)ENVHV, (SV*)NULL, PERL_MAGIC_env, &MP_vtbl_env, (char*)NULL, 0); |  | ||||||
| +    mg->mg_flags |= MGf_COPY; |  | ||||||
| +    mg->mg_flags |= MGf_LOCAL; |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| -void modperl_env_unload(void) |  | ||||||
| +void modperl_env_unload(pTHX) |  | ||||||
|  { |  | ||||||
| -    /* restore originals */ |  | ||||||
| -    StructCopy(&MP_PERL_vtbl_env, &PL_vtbl_env, MGVTBL); |  | ||||||
| -    StructCopy(&MP_PERL_vtbl_envelem, &PL_vtbl_envelem, MGVTBL); |  | ||||||
| +    MAGIC *mg; |  | ||||||
| + |  | ||||||
| +    /* Find the 'E' magic on %ENV */ |  | ||||||
| +    if (!my_perl) |  | ||||||
| +        return; |  | ||||||
| +    if (!PL_envgv) |  | ||||||
| +        return; |  | ||||||
| +    if (!SvRMAGICAL(ENVHV)) |  | ||||||
| +        return; |  | ||||||
| +    mg = mg_find((const SV *)ENVHV, PERL_MAGIC_env); |  | ||||||
| +    if (!mg) |  | ||||||
| +        return; |  | ||||||
| + |  | ||||||
| +    /* Ignore it if it isn't our version */ |  | ||||||
| +    if (mg->mg_virtual != &MP_vtbl_env) |  | ||||||
| +        return; |  | ||||||
| + |  | ||||||
| +    MP_TRACE_e(MP_FUNC, "env_unload - ptr: %x obj: %x flags: %x", |  | ||||||
| +               mg->mg_ptr, mg->mg_obj, mg->mg_flags); |  | ||||||
| + |  | ||||||
| +    /* Remove it */ |  | ||||||
| +    mg_free_type((SV*)ENVHV, PERL_MAGIC_env); |  | ||||||
| + |  | ||||||
| +    /* Restore perl's original version */ |  | ||||||
| +    sv_magicext((SV*)ENVHV, (SV*)NULL, PERL_MAGIC_env, &PL_vtbl_env, (char*)NULL, 0); |  | ||||||
|  } |  | ||||||
|   |  | ||||||
|  /* |  | ||||||
| Index: src/modules/perl/modperl_env.h |  | ||||||
| =================================================================== |  | ||||||
| --- src/modules/perl/modperl_env.h.orig	2015-06-18 22:13:54.000000000 +0200 |  | ||||||
| +++ src/modules/perl/modperl_env.h	2015-12-16 14:57:47.434881127 +0100 |  | ||||||
| @@ -28,7 +28,7 @@ |  | ||||||
|      MP_magical_tie(ENVHV, mg_flags) |  | ||||||
|   |  | ||||||
|  #define modperl_envelem_tie(sv, key, klen) \ |  | ||||||
| -    sv_magic(sv, (SV *)NULL, 'e', key, klen) |  | ||||||
| +    sv_magicext(sv, (SV *)NULL, PERL_MAGIC_envelem, &MP_vtbl_envelem, key, klen) |  | ||||||
|   |  | ||||||
|  void modperl_env_hash_keys(pTHX); |  | ||||||
|   |  | ||||||
| @@ -58,9 +58,12 @@ void modperl_env_request_tie(pTHX_ reque |  | ||||||
|   |  | ||||||
|  void modperl_env_request_untie(pTHX_ request_rec *r); |  | ||||||
|   |  | ||||||
| -void modperl_env_init(void); |  | ||||||
| +void modperl_env_init(pTHX); |  | ||||||
|   |  | ||||||
| -void modperl_env_unload(void); |  | ||||||
| +void modperl_env_unload(pTHX); |  | ||||||
| + |  | ||||||
| +MGVTBL MP_vtbl_env; |  | ||||||
| +MGVTBL MP_vtbl_envelem; |  | ||||||
|   |  | ||||||
|  #endif /* MODPERL_ENV_H */ |  | ||||||
|   |  | ||||||
| Index: src/modules/perl/modperl_perl.c |  | ||||||
| =================================================================== |  | ||||||
| --- src/modules/perl/modperl_perl.c.orig	2015-06-18 22:13:55.000000000 +0200 |  | ||||||
| +++ src/modules/perl/modperl_perl.c	2015-12-16 14:57:47.434881127 +0100 |  | ||||||
| @@ -181,6 +181,8 @@ void modperl_perl_destruct(PerlInterpret |  | ||||||
|          } |  | ||||||
|      } |  | ||||||
|   |  | ||||||
| +    modperl_env_unload(perl); |  | ||||||
| + |  | ||||||
|      perl_destruct(perl); |  | ||||||
|   |  | ||||||
|      /* XXX: big bug in 5.6.1 fixed in 5.7.2+ |  | ||||||
		Reference in New Issue
	
	Block a user