summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAndrew Dunstan <andrew@dunslane.net>2009-06-04 15:59:55 +0000
committerAndrew Dunstan <andrew@dunslane.net>2009-06-04 15:59:55 +0000
commitfd416db406f9efdbbdbd7b63ea4f9ccf47eec8b3 (patch)
tree7d51adbc2e960977462a959f9afaf7ce69ee834e /src
parent5d682cab65ded697fb9b6f8ae3bf9e45444306d7 (diff)
downloadpostgresql-fd416db406f9efdbbdbd7b63ea4f9ccf47eec8b3.tar.gz
Initialise perl library as documented in perl API. Backpatch to release 7.4.
Diffstat (limited to 'src')
-rw-r--r--src/pl/plperl/plperl.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/pl/plperl/plperl.c b/src/pl/plperl/plperl.c
index 7c6cc868cd..f937c67bfa 100644
--- a/src/pl/plperl/plperl.c
+++ b/src/pl/plperl/plperl.c
@@ -1,7 +1,7 @@
/**********************************************************************
* plperl.c - perl as a procedural language for PostgreSQL
*
- * $PostgreSQL: pgsql/src/pl/plperl/plperl.c,v 1.146 2009/02/20 10:39:19 petere Exp $
+ * $PostgreSQL: pgsql/src/pl/plperl/plperl.c,v 1.147 2009/06/04 15:59:55 adunstan Exp $
*
**********************************************************************/
@@ -399,6 +399,8 @@ plperl_init_interp(void)
"", "-e", PERLBOOT
};
+ int nargs = 3;
+
#ifdef WIN32
/*
@@ -442,13 +444,19 @@ plperl_init_interp(void)
#endif
+#ifdef PERL_SYS_INIT3
+ /* only call this the first time through, as per perlembed man page */
+ if (interp_state == INTERP_NONE)
+ PERL_SYS_INIT3(&nargs, (char ***) &embedding, NULL);
+#endif
+
plperl_held_interp = perl_alloc();
if (!plperl_held_interp)
elog(ERROR, "could not allocate Perl interpreter");
perl_construct(plperl_held_interp);
perl_parse(plperl_held_interp, plperl_init_shared_libs,
- 3, embedding, NULL);
+ nargs, embedding, NULL);
perl_run(plperl_held_interp);
if (interp_state == INTERP_NONE)