]> git.sur5r.net Git - openldap/commitdiff
ITS#7075 Re-fix back-perl initialization.
authorHallvard Furuseth <hallvard@openldap.org>
Sat, 21 Jan 2012 03:57:58 +0000 (04:57 +0100)
committerHallvard Furuseth <hallvard@openldap.org>
Sat, 21 Jan 2012 04:01:43 +0000 (05:01 +0100)
Use PERL_SYS_INIT3() after all.  There appears to be no correct
way to do this, so we should as least follow the documentation.

servers/slapd/back-perl/init.c

index 9c48eb62bbf4a316e29c6c1e3a86d384a9f4d0d8..f15e6fc0b685abab6111a1c647c2f5bb06ac52eb 100644 (file)
 #include "perl_back.h"
 #include "../config.h"
 
+#ifdef PERL_SYS_INIT3
+#include <ac/unistd.h>         /* maybe get environ */
+extern char **environ;
+#endif
+
 static void perl_back_xs_init LDAP_P((PERL_BACK_XS_INIT_PARAMS));
 EXT void boot_DynaLoader LDAP_P((PERL_BACK_BOOT_DYNALOADER_PARAMS));
 
@@ -38,6 +43,11 @@ perl_back_initialize(
 {
        char *embedding[] = { "", "-e", "0", NULL }, **argv = embedding;
        int argc = 3;
+#ifdef PERL_SYS_INIT3
+       char **env = environ;
+#else
+       char **env = NULL;
+#endif
 
        bi->bi_open = NULL;
        bi->bi_config = 0;
@@ -78,15 +88,15 @@ perl_back_initialize(
        
        ldap_pvt_thread_mutex_init( &perl_interpreter_mutex );
 
-#ifdef PERL_SYS_INIT
-       PERL_SYS_INIT(&argc, &argv);
+#ifdef PERL_SYS_INIT3
+       PERL_SYS_INIT3(&argc, &argv, &env);
 #endif
        PERL_INTERPRETER = perl_alloc();
        perl_construct(PERL_INTERPRETER);
 #ifdef PERL_EXIT_DESTRUCT_END
        PL_exit_flags |= PERL_EXIT_DESTRUCT_END;
 #endif
-       perl_parse(PERL_INTERPRETER, perl_back_xs_init, argc, argv, (char **)NULL);
+       perl_parse(PERL_INTERPRETER, perl_back_xs_init, argc, argv, env);
        perl_run(PERL_INTERPRETER);
        return perl_back_init_cf( bi );
 }