Oh my! mod_perl released a new version that includes the perl 5.22+
patches!

https://metacpan.org/pod/release/SHAY/mod_perl-2.0.10/Changes

Anyone who actually uses this want to test?


I was able to get all the tests passing except one that seems to be a
problem in others are seeing:
http://marc.info/?l=apache-modperl&m=147541037913776&w=2

More details and showing it happened in 2.09, but still no response:
http://www.gossamer-threads.com/lists/modperl/modperl/108837


Index: Makefile
===================================================================
RCS file: /cvs/ports/www/ap2-mod_perl/Makefile,v
retrieving revision 1.39
diff -u -p -r1.39 Makefile
--- Makefile    12 Oct 2016 11:05:05 -0000      1.39
+++ Makefile    1 Nov 2016 21:58:50 -0000
@@ -2,8 +2,7 @@
 
 COMMENT=       module that embeds a Perl interpreter into Apache2
 
-DISTNAME=      mod_perl-2.0.9
-REVISION=      2
+DISTNAME=      mod_perl-2.0.10
 PKGNAME=       ap2-${DISTNAME:S/-rc/rc/}
 CATEGORIES=    www net
 
@@ -23,6 +22,9 @@ LIB_DEPENDS=          converters/libiconv \
                        devel/apr-util
 RUN_DEPENDS=           www/apache-httpd
 BUILD_DEPENDS=         ${RUN_DEPENDS}
+
+# Addtional dependencies to avoid skipping tests
+TEST_DEPENDS=          devel/p5-BSD-Resource
 
 PORTHOME=              ${WRKDIR}
 
Index: distinfo
===================================================================
RCS file: /cvs/ports/www/ap2-mod_perl/distinfo,v
retrieving revision 1.7
diff -u -p -r1.7 distinfo
--- distinfo    28 Apr 2016 16:41:22 -0000      1.7
+++ distinfo    1 Nov 2016 21:58:50 -0000
@@ -1,2 +1,2 @@
-SHA256 (mod_perl-2.0.9.tar.gz) = AmDyardxwclfrcZ1RLNADkILswuKd1ZdLQKtBUmO9Ss=
-SIZE (mod_perl-2.0.9.tar.gz) = 3846584
+SHA256 (mod_perl-2.0.10.tar.gz) = 0c+D7U6jqd/Oqm2WYv9kUXcJB0mIEJMFECC/QvmHK2Q=
+SIZE (mod_perl-2.0.10.tar.gz) = 3846211
Index: patches/patch-src_modules_perl_mod_perl_c
===================================================================
RCS file: patches/patch-src_modules_perl_mod_perl_c
diff -N patches/patch-src_modules_perl_mod_perl_c
--- patches/patch-src_modules_perl_mod_perl_c   12 Oct 2016 11:05:05 -0000      
1.1
+++ /dev/null   1 Jan 1970 00:00:00 -0000
@@ -1,37 +0,0 @@
-$OpenBSD: patch-src_modules_perl_mod_perl_c,v 1.1 2016/10/12 11:05:05 sthen 
Exp $
-
-From 82827132efd3c2e25cc413c85af61bb63375da6e Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Tue, 1 Dec 2015 17:39:43 +0000
-Subject: [PATCH] Add support for Perl 5.22.x.
-
---- src/modules/perl/mod_perl.c.orig   Thu Jun 18 21:13:55 2015
-+++ src/modules/perl/mod_perl.c        Wed Oct 12 11:51:59 2016
-@@ -262,6 +262,8 @@ PerlInterpreter *modperl_startup(server_rec *s, apr_po
-         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(void)
-     /* modifies PL_ppaddr */
-     modperl_perl_pp_set_all();
- 
--    /* modifies PL_vtbl_env{elem} */
--    modperl_env_init();
--
-     return APR_SUCCESS;
- }
- 
-@@ -596,8 +595,6 @@ static apr_status_t modperl_sys_term(void *data)
-     MP_PERL_FREE_THREAD_KEY_WORKAROUND;
- 
-     MP_TRACE_i(MP_FUNC, "mod_perl sys term");
--
--    modperl_env_unload();
- 
-     modperl_perl_pp_unset_all();
- 
Index: patches/patch-src_modules_perl_modperl_env_c
===================================================================
RCS file: patches/patch-src_modules_perl_modperl_env_c
diff -N patches/patch-src_modules_perl_modperl_env_c
--- patches/patch-src_modules_perl_modperl_env_c        12 Oct 2016 11:05:05 
-0000      1.1
+++ /dev/null   1 Jan 1970 00:00:00 -0000
@@ -1,160 +0,0 @@
-$OpenBSD: patch-src_modules_perl_modperl_env_c,v 1.1 2016/10/12 11:05:05 sthen 
Exp $
-
-From 82827132efd3c2e25cc413c85af61bb63375da6e Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Tue, 1 Dec 2015 17:39:43 +0000
-Subject: [PATCH] Add support for Perl 5.22.x.
-
-From a6629db9dacd3c6152df599397cfa913928d18d2 Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Fri, 4 Mar 2016 08:23:32 +0000
-Subject: [PATCH] Fix compile errors since SVN revision 1717474 for unthreaded 
perl
-
---- src/modules/perl/modperl_env.c.orig        Wed Oct 12 11:52:43 2016
-+++ src/modules/perl/modperl_env.c     Wed Oct 12 11:52:36 2016
-@@ -121,6 +121,7 @@ static void modperl_env_table_populate(pTHX_ apr_table
-     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_ request_rec *r)
- #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(pTHX_ SV *sv, M
-     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_ SV *sv, MAGIC *
- #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,60 @@ 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;
- 
--    /* replace with our versions */
--    StructCopy(&MP_vtbl_env, &PL_vtbl_env, MGVTBL);
--    StructCopy(&MP_vtbl_envelem, &PL_vtbl_envelem, MGVTBL);
-+    /* Find the 'E' magic on %ENV */
-+    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);
-+
-+    /* 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 (!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: patches/patch-src_modules_perl_modperl_env_h
===================================================================
RCS file: patches/patch-src_modules_perl_modperl_env_h
diff -N patches/patch-src_modules_perl_modperl_env_h
--- patches/patch-src_modules_perl_modperl_env_h        12 Oct 2016 11:05:05 
-0000      1.1
+++ /dev/null   1 Jan 1970 00:00:00 -0000
@@ -1,33 +0,0 @@
-$OpenBSD: patch-src_modules_perl_modperl_env_h,v 1.1 2016/10/12 11:05:05 sthen 
Exp $
-
-From 82827132efd3c2e25cc413c85af61bb63375da6e Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Tue, 1 Dec 2015 17:39:43 +0000
-Subject: [PATCH] Add support for Perl 5.22.x.
-
---- src/modules/perl/modperl_env.h.orig        Thu Jun 18 21:13:54 2015
-+++ src/modules/perl/modperl_env.h     Wed Oct 12 11:51:59 2016
-@@ -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_ request_rec *r);
- 
- 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: patches/patch-src_modules_perl_modperl_perl_c
===================================================================
RCS file: patches/patch-src_modules_perl_modperl_perl_c
diff -N patches/patch-src_modules_perl_modperl_perl_c
--- patches/patch-src_modules_perl_modperl_perl_c       12 Oct 2016 11:05:05 
-0000      1.1
+++ /dev/null   1 Jan 1970 00:00:00 -0000
@@ -1,23 +0,0 @@
-$OpenBSD: patch-src_modules_perl_modperl_perl_c,v 1.1 2016/10/12 11:05:05 
sthen Exp $
-
-From 82827132efd3c2e25cc413c85af61bb63375da6e Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Tue, 1 Dec 2015 17:39:43 +0000
-Subject: [PATCH] Add support for Perl 5.22.x.
-
-From a6629db9dacd3c6152df599397cfa913928d18d2 Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Fri, 4 Mar 2016 08:23:32 +0000
-Subject: [PATCH] Fix compile errors since SVN revision 1717474 for unthreaded 
perl
-
---- src/modules/perl/modperl_perl.c.orig       Wed Oct 12 11:52:43 2016
-+++ src/modules/perl/modperl_perl.c    Wed Oct 12 11:52:36 2016
-@@ -181,6 +181,8 @@ void modperl_perl_destruct(PerlInterpreter *perl)
-         }
-     }
- 
-+    modperl_env_unload(aTHX);
-+
-     perl_destruct(perl);
- 
-     /* XXX: big bug in 5.6.1 fixed in 5.7.2+
Index: patches/patch-t_lib_TestAPRlib_util_pm
===================================================================
RCS file: patches/patch-t_lib_TestAPRlib_util_pm
diff -N patches/patch-t_lib_TestAPRlib_util_pm
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ patches/patch-t_lib_TestAPRlib_util_pm      1 Nov 2016 21:58:50 -0000
@@ -0,0 +1,12 @@
+$OpenBSD$
+--- t/lib/TestAPRlib/util.pm.orig      Tue Nov  1 10:42:49 2016
++++ t/lib/TestAPRlib/util.pm   Tue Nov  1 10:49:55 2016
+@@ -11,7 +11,7 @@ use Apache::TestUtil;
+ 
+ use APR::Util ();
+ 
+-use constant CRYPT_WORKS => $^O !~ /^(MSWin32|beos|NetWare)$/;
++use constant CRYPT_WORKS => $^O !~ /^(MSWin32|beos|NetWare|openbsd)$/;
+ 
+ my $clear = "this is some text";
+ # to get the hash values used:
Index: patches/patch-t_response_TestModperl_env_pm
===================================================================
RCS file: patches/patch-t_response_TestModperl_env_pm
diff -N patches/patch-t_response_TestModperl_env_pm
--- patches/patch-t_response_TestModperl_env_pm 12 Oct 2016 11:05:05 -0000      
1.1
+++ /dev/null   1 Jan 1970 00:00:00 -0000
@@ -1,27 +0,0 @@
-$OpenBSD: patch-t_response_TestModperl_env_pm,v 1.1 2016/10/12 11:05:05 sthen 
Exp $
-
-From 82827132efd3c2e25cc413c85af61bb63375da6e Mon Sep 17 00:00:00 2001
-From: Steve Hay <steve...@apache.org>
-Date: Tue, 1 Dec 2015 17:39:43 +0000
-Subject: [PATCH] Add support for Perl 5.22.x.
-
---- t/response/TestModperl/env.pm.orig Thu Jun 18 21:13:58 2015
-+++ t/response/TestModperl/env.pm      Wed Oct 12 11:51:59 2016
-@@ -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: patches/patch-t_response_TestModperl_perl_pm
===================================================================
RCS file: patches/patch-t_response_TestModperl_perl_pm
diff -N patches/patch-t_response_TestModperl_perl_pm
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ patches/patch-t_response_TestModperl_perl_pm        1 Nov 2016 21:58:50 
-0000
@@ -0,0 +1,14 @@
+$OpenBSD$
+--- t/response/TestModperl/perl.pm.orig        Thu Oct 27 13:11:28 2016
++++ t/response/TestModperl/perl.pm     Tue Nov  1 14:22:28 2016
+@@ -17,8 +17,8 @@ sub handler {
+ 
+     plan $r, tests => 1;
+ 
+-    ok t_cmp("SNXJvM5I.PJrE",
+-             crypt("testing", "SNXJvM5I.PJrE"),
++    ok t_cmp('$2b$12$123456789012345678901u1ZJSwXPi/vx1HZAMoHfzxhzXjZiOB5q',
++             crypt("testing", 
'$2b$12$123456789012345678901u1ZJSwXPi/vx1HZAMoHfzxhzXjZiOB5q'),
+              "crypt");
+ 
+     Apache2::Const::OK;

----- End forwarded message -----

-- 
andrew - http://afresh1.com

Real programmers don't document.
          If it was hard to write, it should be hard to understand.

Reply via email to