Commit | Line | Data |
---|---|---|
47be8fd0 NC |
1 | /* -*- buffer-read-only: t -*- |
2 | !!!!!!! DO NOT EDIT THIS FILE !!!!!!! | |
3 | This file is built by regen/miniperlmain.pl and ExtUtils::Miniperl. | |
4 | Any changes made here will be lost! | |
5 | */ | |
6 | ||
d6376244 JH |
7 | /* miniperlmain.c |
8 | * | |
cbdf9ef8 | 9 | * Copyright (C) 1994, 1995, 1996, 1997, 1999, 2000, 2001, 2002, 2003, |
663f364b | 10 | * 2004, 2005, 2006, 2007, by Larry Wall and others |
d6376244 JH |
11 | * |
12 | * You may distribute under the terms of either the GNU General Public | |
13 | * License or the Artistic License, as specified in the README file. | |
14 | * | |
15 | */ | |
16 | ||
a0d0e21e | 17 | /* |
4ac71550 TC |
18 | * The Road goes ever on and on |
19 | * Down from the door where it began. | |
20 | * | |
21 | * [Bilbo on p.35 of _The Lord of the Rings_, I/i: "A Long-Expected Party"] | |
22 | * [Frodo on p.73 of _The Lord of the Rings_, I/iii: "Three Is Company"] | |
a0d0e21e LW |
23 | */ |
24 | ||
166f8a29 DM |
25 | /* This file contains the main() function for the perl interpreter. |
26 | * Note that miniperlmain.c contains main() for the 'miniperl' binary, | |
27 | * while perlmain.c contains main() for the 'perl' binary. | |
28 | * | |
ddfa107c DM |
29 | * Miniperl is like perl except that it does not support dynamic loading, |
30 | * and in fact is used to build the dynamic modules needed for the 'real' | |
61296642 | 31 | * perl executable. |
166f8a29 DM |
32 | */ |
33 | ||
60e4866f | 34 | #ifdef OEMVS |
9133bbab | 35 | #ifdef MYMALLOC |
61296642 | 36 | /* sbrk is limited to first heap segment so make it big */ |
9133bbab NIS |
37 | #pragma runopts(HEAP(8M,500K,ANYWHERE,KEEP,8K,4K) STACK(,,ANY,) ALL31(ON)) |
38 | #else | |
39 | #pragma runopts(HEAP(2M,500K,ANYWHERE,KEEP,8K,4K) STACK(,,ANY,) ALL31(ON)) | |
40 | #endif | |
60e4866f LJ |
41 | #endif |
42 | ||
864dbfa3 | 43 | #define PERL_IN_MINIPERLMAIN_C |
d573a731 | 44 | #include "EXTERN.h" |
2304df62 | 45 | #include "perl.h" |
c8935f6c | 46 | #include "XSUB.h" |
2304df62 | 47 | |
864dbfa3 | 48 | static void xs_init (pTHX); |
a0d0e21e LW |
49 | static PerlInterpreter *my_perl; |
50 | ||
27da23d5 JH |
51 | #if defined(PERL_GLOBAL_STRUCT_PRIVATE) |
52 | /* The static struct perl_vars* may seem counterproductive since the | |
53 | * whole idea PERL_GLOBAL_STRUCT_PRIVATE was to avoid statics, but note | |
54 | * that this static is not in the shared perl library, the globals PL_Vars | |
55 | * and PL_VarsPtr will stay away. */ | |
56 | static struct perl_vars* my_plvarsp; | |
57 | struct perl_vars* Perl_GetVarsPrivate(void) { return my_plvarsp; } | |
58 | #endif | |
59 | ||
2f3efc97 JH |
60 | #ifdef NO_ENV_ARRAY_IN_MAIN |
61 | extern char **environ; | |
62 | int | |
63 | main(int argc, char **argv) | |
64 | #else | |
c07a80fd | 65 | int |
91487cfc | 66 | main(int argc, char **argv, char **env) |
2f3efc97 | 67 | #endif |
2304df62 | 68 | { |
01be0729 | 69 | int exitstatus, i; |
27da23d5 | 70 | #ifdef PERL_GLOBAL_STRUCT |
79403e77 | 71 | struct perl_vars *my_vars = init_global_struct(); |
27da23d5 | 72 | # ifdef PERL_GLOBAL_STRUCT_PRIVATE |
79403e77 | 73 | my_plvarsp = my_vars; |
27da23d5 JH |
74 | # endif |
75 | #endif /* PERL_GLOBAL_STRUCT */ | |
dedb16dc DL |
76 | #ifndef NO_ENV_ARRAY_IN_MAIN |
77 | PERL_UNUSED_ARG(env); | |
78 | #endif | |
50acdf95 | 79 | #ifndef PERL_USE_SAFE_PUTENV |
8bf20623 | 80 | PL_use_safe_putenv = FALSE; |
50acdf95 | 81 | #endif /* PERL_USE_SAFE_PUTENV */ |
2304df62 | 82 | |
2c4f7f0e DM |
83 | /* if user wants control of gprof profiling off by default */ |
84 | /* noop unless Configure is given -Accflags=-DPERL_GPROF_CONTROL */ | |
85 | PERL_GPROF_MONCONTROL(0); | |
86 | ||
2f3efc97 JH |
87 | #ifdef NO_ENV_ARRAY_IN_MAIN |
88 | PERL_SYS_INIT3(&argc,&argv,&environ); | |
89 | #else | |
91487cfc | 90 | PERL_SYS_INIT3(&argc,&argv,&env); |
2f3efc97 | 91 | #endif |
4633a7c4 | 92 | |
3db8f154 | 93 | #if defined(USE_ITHREADS) |
52e18b1f GS |
94 | /* XXX Ideally, this should really be happening in perl_alloc() or |
95 | * perl_construct() to keep libperl.a transparently fork()-safe. | |
96 | * It is currently done here only because Apache/mod_perl have | |
97 | * problems due to lack of a call to cancel pthread_atfork() | |
98 | * handlers when shared objects that contain the handlers may | |
99 | * be dlclose()d. This forces applications that embed perl to | |
100 | * call PTHREAD_ATFORK() explicitly, but if and only if it hasn't | |
101 | * been called at least once before in the current process. | |
102 | * --GSAR 2001-07-20 */ | |
98e467d9 DM |
103 | PTHREAD_ATFORK(Perl_atfork_lock, |
104 | Perl_atfork_unlock, | |
105 | Perl_atfork_unlock); | |
106 | #endif | |
107 | ||
3280af22 | 108 | if (!PL_do_undump) { |
a0d0e21e LW |
109 | my_perl = perl_alloc(); |
110 | if (!my_perl) | |
111 | exit(1); | |
642f9deb | 112 | perl_construct(my_perl); |
3280af22 | 113 | PL_perl_destruct_level = 0; |
a0d0e21e | 114 | } |
31d77e54 | 115 | PL_exit_flags |= PERL_EXIT_DESTRUCT_END; |
642f9deb | 116 | exitstatus = perl_parse(my_perl, xs_init, argc, argv, (char **)NULL); |
8815fa0e | 117 | if (!exitstatus) |
31d77e54 | 118 | perl_run(my_perl); |
22f43f2c | 119 | |
01d65469 | 120 | #ifndef PERL_MICRO |
01be0729 | 121 | /* Unregister our signal handler before destroying my_perl */ |
724be0c9 | 122 | for (i = 1; PL_sig_name[i]; i++) { |
01be0729 JW |
123 | if (rsignal_state(PL_sig_num[i]) == (Sighandler_t) PL_csighandlerp) { |
124 | rsignal(PL_sig_num[i], (Sighandler_t) SIG_DFL); | |
125 | } | |
126 | } | |
01d65469 | 127 | #endif |
01be0729 | 128 | |
8815fa0e | 129 | exitstatus = perl_destruct(my_perl); |
2304df62 | 130 | |
642f9deb | 131 | perl_free(my_perl); |
2304df62 | 132 | |
2f3efc97 | 133 | #if defined(USE_ENVIRON_ARRAY) && defined(PERL_TRACK_MEMPOOL) && !defined(NO_ENV_ARRAY_IN_MAIN) |
22f43f2c MHM |
134 | /* |
135 | * The old environment may have been freed by perl_free() | |
136 | * when PERL_TRACK_MEMPOOL is defined, but without having | |
137 | * been restored by perl_destruct() before (this is only | |
138 | * done if destruct_level > 0). | |
139 | * | |
140 | * It is important to have a valid environment for atexit() | |
141 | * routines that are eventually called. | |
142 | */ | |
143 | environ = env; | |
144 | #endif | |
145 | ||
f0af002c TC |
146 | PERL_SYS_TERM(); |
147 | ||
27da23d5 | 148 | #ifdef PERL_GLOBAL_STRUCT |
79403e77 | 149 | free_global_struct(my_vars); |
5c64bffd NC |
150 | # ifdef PERL_GLOBAL_STRUCT_PRIVATE |
151 | my_plvarsp = NULL; | |
152 | /* Remember, functions registered with atexit() can run after this point, | |
153 | and may access "global" variables, and hence end up calling | |
154 | Perl_GetVarsPrivate() */ | |
155 | #endif | |
27da23d5 JH |
156 | #endif /* PERL_GLOBAL_STRUCT */ |
157 | ||
642f9deb | 158 | exit(exitstatus); |
4e35701f | 159 | return exitstatus; |
2304df62 AD |
160 | } |
161 | ||
162 | /* Register any extra external extensions */ | |
163 | ||
4633a7c4 | 164 | |
a0d0e21e | 165 | static void |
864dbfa3 | 166 | xs_init(pTHX) |
2304df62 | 167 | { |
a78951c8 | 168 | dXSUB_SYS; |
96a5add6 | 169 | PERL_UNUSED_CONTEXT; |
2304df62 | 170 | } |
66610fdd | 171 | |
47be8fd0 | 172 | /* ex: set ro: */ |