]> git.sur5r.net Git - openldap/commitdiff
ITS#7075 Fix back-perl initialization.
authorHallvard Furuseth <hallvard@openldap.org>
Tue, 1 Nov 2011 05:28:40 +0000 (06:28 +0100)
committerHallvard Furuseth <hallvard@openldap.org>
Tue, 1 Nov 2011 05:28:40 +0000 (06:28 +0100)
Use PERL_SYS_INIT() instead of broken PERL_SYS_INIT3(,,NULL).  Pass its
output variables to perl_parse().  Fix argument type 'char *(*argv)[3]'
to 'char ***argv'.  NULL-terminate argv in case that is needed.

servers/slapd/back-perl/init.c

index 392084233ffcae1af33b4359b10c63b45c84901a..234d77383181c676a98a173ea7177693d234e0e8 100644 (file)
@@ -36,7 +36,7 @@ perl_back_initialize(
        BackendInfo     *bi
 )
 {
-       char *embedding[] = { "", "-e", "0" };
+       char *embedding[] = { "", "-e", "0", NULL }, **argv = embedding;
        int argc = 3;
 
        bi->bi_open = NULL;
@@ -78,15 +78,15 @@ perl_back_initialize(
        
        ldap_pvt_thread_mutex_init( &perl_interpreter_mutex );
 
-#ifdef PERL_SYS_INIT3
-       PERL_SYS_INIT3(&argc, &embedding, (char ***)NULL);
+#ifdef PERL_SYS_INIT
+       PERL_SYS_INIT(&argc, &argv);
 #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, embedding, (char **)NULL);
+       perl_parse(PERL_INTERPRETER, perl_back_xs_init, argc, argv, (char **)NULL);
        perl_run(PERL_INTERPRETER);
        return perl_back_init_cf( bi );
 }