X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fback-perl%2Finit.c;h=f15e6fc0b685abab6111a1c647c2f5bb06ac52eb;hb=9547dd7a0d9fd079e6e75fb59b20a2fc661c9782;hp=a695a8f97f82bc9276ac8c6091888413561a661f;hpb=da6d9eb0463255782f3fa70c61fd958d94c048cf;p=openldap diff --git a/servers/slapd/back-perl/init.c b/servers/slapd/back-perl/init.c index a695a8f97f..f15e6fc0b6 100644 --- a/servers/slapd/back-perl/init.c +++ b/servers/slapd/back-perl/init.c @@ -1,7 +1,7 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 1999-2007 The OpenLDAP Foundation. + * Copyright 1999-2012 The OpenLDAP Foundation. * Portions Copyright 1999 John C. Quillan. * Portions Copyright 2002 myinternet Limited. * All rights reserved. @@ -16,6 +16,12 @@ */ #include "perl_back.h" +#include "../config.h" + +#ifdef PERL_SYS_INIT3 +#include /* 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)); @@ -35,7 +41,13 @@ perl_back_initialize( BackendInfo *bi ) { - char *embedding[] = { "", "-e", "0" }; + 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; @@ -76,16 +88,23 @@ perl_back_initialize( ldap_pvt_thread_mutex_init( &perl_interpreter_mutex ); +#ifdef PERL_SYS_INIT3 + PERL_SYS_INIT3(&argc, &argv, &env); +#endif PERL_INTERPRETER = perl_alloc(); perl_construct(PERL_INTERPRETER); - perl_parse(PERL_INTERPRETER, perl_back_xs_init, 3, embedding, (char **)NULL); +#ifdef PERL_EXIT_DESTRUCT_END + PL_exit_flags |= PERL_EXIT_DESTRUCT_END; +#endif + perl_parse(PERL_INTERPRETER, perl_back_xs_init, argc, argv, env); perl_run(PERL_INTERPRETER); - return 0; + return perl_back_init_cf( bi ); } int perl_back_db_init( - BackendDB *be + BackendDB *be, + ConfigReply *cr ) { be->be_private = (PerlBackend *) ch_malloc( sizeof(PerlBackend) ); @@ -95,12 +114,15 @@ perl_back_db_init( Debug( LDAP_DEBUG_TRACE, "perl backend db init\n", 0, 0, 0 ); + be->be_cf_ocs = be->bd_info->bi_cf_ocs; + return 0; } int perl_back_db_open( - BackendDB *be + BackendDB *be, + ConfigReply *cr ) { int count; @@ -118,11 +140,7 @@ perl_back_db_open( PUTBACK; -#ifdef PERL_IS_5_6 count = call_method("init", G_SCALAR); -#else - count = perl_call_method("init", G_SCALAR); -#endif SPAGAIN;