From 1e62263697ba71f5f18b8652cc70c31208b3b466 Mon Sep 17 00:00:00 2001 From: Hallvard Furuseth Date: Tue, 1 Nov 2011 06:28:40 +0100 Subject: [PATCH] ITS#7075 Fix back-perl initialization. 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 | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/servers/slapd/back-perl/init.c b/servers/slapd/back-perl/init.c index 392084233f..234d773831 100644 --- a/servers/slapd/back-perl/init.c +++ b/servers/slapd/back-perl/init.c @@ -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 ); } -- 2.39.2