This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Mention the warnings changes in "updated modules"
[perl5.git] / intrpvar.h
CommitLineData
907b3e23
DM
1/* intrpvar.h
2 *
3 * Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
1129b882 4 * 2006, 2007, 2008 by Larry Wall and others
907b3e23
DM
5 *
6 * You may distribute under the terms of either the GNU General Public
7 * License or the Artistic License, as specified in the README file.
8 *
9 */
10
11/*
12=head1 Per-Interpreter Variables
13*/
49f531da 14
907b3e23
DM
15/* These variables are per-interpreter in threaded/multiplicity builds,
16 * global otherwise.
17
18 * Don't forget to re-run embed.pl to propagate changes! */
cb68f92d 19
6537fe72
MS
20/* New variables must be added to the very end for binary compatibility.
21 * XSUB.h provides wrapper functions via perlapi.h that make this
22 * irrelevant, but not all code may be expected to #include XSUB.h. */
23
02506efe
JH
24/* Don't forget to add your variable also to perl_clone()! */
25
cb68f92d
GS
26/* The 'I' prefix is only needed for vars that need appropriate #defines
27 * generated when built with or without MULTIPLICITY. It is also used
28 * to generate the appropriate export list for win32.
29 *
907b3e23
DM
30 * When building without MULTIPLICITY, these variables will be truly global.
31 *
32 * Important ones in the first cache line (if alignment is done right) */
33
34PERLVAR(Istack_sp, SV **) /* top of the stack */
35#ifdef OP_IN_REGISTER
36PERLVAR(Iopsave, OP *)
37#else
38PERLVAR(Iop, OP *) /* currently executing op */
39#endif
40PERLVAR(Icurpad, SV **) /* active pad (lexicals+tmps) */
41
42PERLVAR(Istack_base, SV **)
43PERLVAR(Istack_max, SV **)
44
45PERLVAR(Iscopestack, I32 *) /* scopes we've ENTERed */
f2b88940
NC
46/* name of the scopes we've ENTERed. Only used with -DDEBUGGING, but needs to be
47 present always, as -DDEUBGGING must be binary compatible with non. */
48PERLVARI(Iscopestack_name, const char * *, NULL)
907b3e23
DM
49PERLVAR(Iscopestack_ix, I32)
50PERLVAR(Iscopestack_max,I32)
51
52PERLVAR(Isavestack, ANY *) /* items that need to be restored when
53 LEAVEing scopes we've ENTERed */
54PERLVAR(Isavestack_ix, I32)
55PERLVAR(Isavestack_max, I32)
56
57PERLVAR(Itmps_stack, SV **) /* mortals we've made */
58PERLVARI(Itmps_ix, I32, -1)
59PERLVARI(Itmps_floor, I32, -1)
60PERLVAR(Itmps_max, I32)
61PERLVAR(Imodcount, I32) /* how much mod()ification in
62 assignment? */
63
64PERLVAR(Imarkstack, I32 *) /* stack_sp locations we're
65 remembering */
66PERLVAR(Imarkstack_ptr, I32 *)
67PERLVAR(Imarkstack_max, I32 *)
68
69PERLVAR(ISv, SV *) /* used to hold temporary values */
70PERLVAR(IXpv, XPV *) /* used to hold temporary values */
71
72/*
73=for apidoc Amn|STRLEN|PL_na
74
75A convenience variable which is typically used with C<SvPV> when one
76doesn't care about the length of the string. It is usually more efficient
77to either declare a local variable and use that instead or to use the
78C<SvPV_nolen> macro.
79
80=cut
81*/
82
83PERLVAR(Ina, STRLEN) /* for use in SvPV when length is
84 Not Applicable */
85
86/* stat stuff */
87PERLVAR(Istatbuf, Stat_t)
88PERLVAR(Istatcache, Stat_t) /* _ */
89PERLVAR(Istatgv, GV *)
90PERLVARI(Istatname, SV *, NULL)
91
92#ifdef HAS_TIMES
93PERLVAR(Itimesbuf, struct tms)
94#endif
95
96/* Fields used by magic variables such as $@, $/ and so on */
97PERLVAR(Icurpm, PMOP *) /* what to do \ interps in REs from */
98
99/*
100=for apidoc mn|SV*|PL_rs
101
102The input record separator - C<$/> in Perl space.
103
104=for apidoc mn|GV*|PL_last_in_gv
105
106The GV which was last used for a filehandle input operation. (C<< <FH> >>)
107
e23d9e2f 108=for apidoc mn|GV*|PL_ofsgv
907b3e23 109
e23d9e2f 110The glob containing the output field separator - C<*,> in Perl space.
907b3e23
DM
111
112=cut
113*/
114
115PERLVAR(Irs, SV *) /* input record separator $/ */
116PERLVAR(Ilast_in_gv, GV *) /* GV used in last <FH> */
e23d9e2f 117PERLVAR(Iofsgv, GV *) /* GV of output field separator *, */
907b3e23
DM
118PERLVAR(Idefoutgv, GV *) /* default FH for output */
119PERLVARI(Ichopset, const char *, " \n-") /* $: */
120PERLVAR(Iformtarget, SV *)
121PERLVAR(Ibodytarget, SV *)
122PERLVAR(Itoptarget, SV *)
123
124/* Stashes */
125PERLVAR(Idefstash, HV *) /* main symbol table */
126PERLVAR(Icurstash, HV *) /* symbol table for current package */
127
128PERLVAR(Irestartop, OP *) /* propagating an error from croak? */
febb3a6d 129PERLVAR(Irestartjmpenv, JMPENV *) /* target frame for longjmp in die */
910e0671 130PERLVAR(Icurcop, COP *)
907b3e23
DM
131PERLVAR(Icurstack, AV *) /* THE STACK */
132PERLVAR(Icurstackinfo, PERL_SI *) /* current stack + context */
133PERLVAR(Imainstack, AV *) /* the stack when nothing funny is
134 happening */
135
136PERLVAR(Itop_env, JMPENV *) /* ptr to current sigjmp environment */
137PERLVAR(Istart_env, JMPENV) /* empty startup sigjmp environment */
138PERLVARI(Ierrors, SV *, NULL) /* outstanding queued errors */
139
140/* statics "owned" by various functions */
907b3e23
DM
141PERLVAR(Ihv_fetch_ent_mh, HE*) /* owned by hv_fetch_ent() */
142
907b3e23
DM
143PERLVAR(Ilastgotoprobe, OP*) /* from pp_ctl.c */
144
145/* sort stuff */
146PERLVAR(Isortcop, OP *) /* user defined sort routine */
147PERLVAR(Isortstash, HV *) /* which is in some package or other */
148PERLVAR(Ifirstgv, GV *) /* $a */
149PERLVAR(Isecondgv, GV *) /* $b */
150
151/* float buffer */
152PERLVAR(Iefloatbuf, char *)
153PERLVAR(Iefloatsize, STRLEN)
154
155/* regex stuff */
156
157PERLVAR(Iscreamfirst, I32 *)
158PERLVAR(Iscreamnext, I32 *)
159PERLVAR(Ilastscream, SV *)
160
161PERLVAR(Ireg_state, struct re_save_state)
162
163PERLVAR(Iregdummy, regnode) /* from regcomp.c */
164
165PERLVARI(Idumpindent, U16, 4) /* number of blanks per dump
166 indentation level */
167
157b3822
NC
168
169PERLVAR(Iutf8locale, bool) /* utf8 locale detected */
170PERLVARI(Irehash_seed_set, bool, FALSE) /* 582 hash initialized? */
907b3e23
DM
171
172PERLVARA(Icolors,6, char *) /* from regcomp.c */
173
174PERLVARI(Ipeepp, peep_t, MEMBER_TO_FPTR(Perl_peep))
1a0a2ba9
Z
175 /* Pointer to per-sub peephole optimizer */
176PERLVARI(Irpeepp, peep_t, MEMBER_TO_FPTR(Perl_rpeep))
177 /* Pointer to recursive peephole optimizer */
907b3e23 178
2f175318
VP
179/*
180=for apidoc Amn|Perl_ophook_t|PL_opfreehook
181
182When non-C<NULL>, the function pointed by this variable will be called each time an OP is freed with the corresponding OP as the argument.
183This allows extensions to free any extra attribute they have locally attached to an OP.
184It is also assured to first fire for the parent OP and then for its kids.
185
186When you replace this variable, it is considered a good practice to store the possibly previously installed hook and that you recall it inside your own.
187
188=cut
189*/
190
799dfa8f 191PERLVARI(Iopfreehook, Perl_ophook_t, 0) /* op_free() hook */
f37b8c3f 192
907b3e23
DM
193PERLVARI(Imaxscream, I32, -1)
194PERLVARI(Ireginterp_cnt,I32, 0) /* Whether "Regexp" was interpolated. */
195PERLVARI(Iwatchaddr, char **, 0)
196PERLVAR(Iwatchok, char *)
197
198/* the currently active slab in a chain of slabs of regmatch states,
199 * and the currently active state within that slab */
200
201PERLVARI(Iregmatch_slab, regmatch_slab *, NULL)
202PERLVAR(Iregmatch_state, regmatch_state *)
203
907b3e23 204/* Put anything new that is pointer aligned here. */
d95e864f 205
907b3e23
DM
206PERLVAR(Idelaymagic, U16) /* ($<,$>) = ... */
207PERLVAR(Ilocalizing, U8) /* are we processing a local() list? */
208PERLVAR(Icolorset, bool) /* from regcomp.c */
209PERLVARI(Idirty, bool, FALSE) /* in the middle of tearing things
210 down? */
910e0671 211PERLVAR(Iin_eval, U8) /* trap "fatal" errors? */
907b3e23 212PERLVAR(Itainted, bool) /* using variables controlled by $< */
d95e864f
NC
213
214/* This value may be set when embedding for full cleanup */
215/* 0=none, 1=full, 2=full with checks */
801627e8
NC
216/* mod_perl is special, and also assigns a meaning -1 */
217PERLVARI(Iperl_destruct_level, signed char, 0)
d95e864f
NC
218
219PERLVAR(Iperldb, U32)
220
49f531da 221/* pseudo environmental stuff */
d95e864f 222PERLVAR(Iorigargc, int)
cb68f92d
GS
223PERLVAR(Iorigargv, char **)
224PERLVAR(Ienvgv, GV *)
cb68f92d 225PERLVAR(Iincgv, GV *)
b3ac6de7 226PERLVAR(Ihintgv, GV *)
cb68f92d
GS
227PERLVAR(Iorigfilename, char *)
228PERLVAR(Idiehook, SV *)
229PERLVAR(Iwarnhook, SV *)
1d7c1841
GS
230
231/* switches */
a7cb1f99 232PERLVAR(Ipatchlevel, SV *)
1e8125c6 233PERLVAR(Iapiversion, SV *)
27da23d5 234PERLVAR(Ilocalpatches, const char * const *)
dd374669 235PERLVARI(Isplitstr, const char *, " ")
9f7da6d5
NC
236
237PERLVAR(Iminus_c, bool)
cb68f92d
GS
238PERLVAR(Iminus_n, bool)
239PERLVAR(Iminus_p, bool)
240PERLVAR(Iminus_l, bool)
241PERLVAR(Iminus_a, bool)
242PERLVAR(Iminus_F, bool)
243PERLVAR(Idoswitches, bool)
bc9b29db 244PERLVAR(Iminus_E, bool)
954c1994
GS
245
246/*
ccfc67b7 247
2eb25c99 248=for apidoc mn|bool|PL_dowarn
954c1994
GS
249
250The C variable which corresponds to Perl's $^W warning variable.
251
252=cut
253*/
254
d41ff1b8 255PERLVAR(Idowarn, U8)
cb68f92d 256PERLVAR(Idoextract, bool)
49f531da 257PERLVAR(Isawampersand, bool) /* must save all match strings */
cb68f92d 258PERLVAR(Iunsafe, bool)
9f7da6d5
NC
259PERLVAR(Iexit_flags, U8) /* was exit() unexpected, etc. */
260PERLVAR(Isrand_called, bool)
261/* Part of internal state, but makes the 16th 1 byte variable in a row. */
262PERLVAR(Itainting, bool) /* doing taint checks */
4fa7c2bf 263PERLVARI(Iin_load_module, bool, FALSE) /* to prevent recursions in PerlIO_find_layer */
cb68f92d
GS
264PERLVAR(Iinplace, char *)
265PERLVAR(Ie_script, SV *)
49f531da
NIS
266
267/* magical thingies */
268PERLVAR(Ibasetime, Time_t) /* $^T */
269PERLVAR(Iformfeed, SV *) /* $^L */
d4cce5f1
NIS
270
271
cb68f92d
GS
272PERLVARI(Imaxsysfd, I32, MAXSYSFD)
273 /* top fd to pass to subprocesses */
49f531da
NIS
274PERLVAR(Istatusvalue, I32) /* $? */
275#ifdef VMS
cb68f92d 276PERLVAR(Istatusvalue_vms,U32)
e5218da5
GA
277#else
278PERLVAR(Istatusvalue_posix,I32)
49f531da
NIS
279#endif
280
157b3822
NC
281PERLVARI(Isig_pending, int,0) /* Number if highest signal pending */
282PERLVAR(Ipsig_pend, int *) /* per-signal "count" of pending */
283
49f531da 284/* shortcuts to various I/O objects */
16d811d4
DM
285PERLVAR(Istdingv, GV *) /* *STDIN */
286PERLVAR(Istderrgv, GV *) /* *STDERR */
cb68f92d 287PERLVAR(Idefgv, GV *)
16d811d4
DM
288PERLVAR(Iargvgv, GV *) /* *ARGV */
289PERLVAR(Iargvoutgv, GV *) /* *ARGVOUT */
1d7c1841 290PERLVAR(Iargvout_stack, AV *)
49f531da
NIS
291
292/* shortcuts to regexp stuff */
16d811d4 293PERLVAR(Ireplgv, GV *) /* *^R */
49f531da
NIS
294
295/* shortcuts to misc objects */
16d811d4 296PERLVAR(Ierrgv, GV *) /* *@ */
49f531da
NIS
297
298/* shortcuts to debugging objects */
16d811d4
DM
299PERLVAR(IDBgv, GV *) /* *DB::DB */
300PERLVAR(IDBline, GV *) /* *DB::line */
954c1994
GS
301
302/*
2eb25c99 303=for apidoc mn|GV *|PL_DBsub
954c1994
GS
304When Perl is run in debugging mode, with the B<-d> switch, this GV contains
305the SV which holds the name of the sub being debugged. This is the C
306variable which corresponds to Perl's $DB::sub variable. See
307C<PL_DBsingle>.
308
2eb25c99 309=for apidoc mn|SV *|PL_DBsingle
954c1994 310When Perl is run in debugging mode, with the B<-d> switch, this SV is a
7889fe52 311boolean which indicates whether subs are being single-stepped.
954c1994
GS
312Single-stepping is automatically turned on after every step. This is the C
313variable which corresponds to Perl's $DB::single variable. See
314C<PL_DBsub>.
315
2eb25c99 316=for apidoc mn|SV *|PL_DBtrace
954c1994
GS
317Trace variable used when Perl is run in debugging mode, with the B<-d>
318switch. This is the C variable which corresponds to Perl's $DB::trace
319variable. See C<PL_DBsingle>.
320
321=cut
322*/
323
16d811d4
DM
324PERLVAR(IDBsub, GV *) /* *DB::sub */
325PERLVAR(IDBsingle, SV *) /* $DB::single */
326PERLVAR(IDBtrace, SV *) /* $DB::trace */
327PERLVAR(IDBsignal, SV *) /* $DB::signal */
49f531da
NIS
328PERLVAR(Idbargs, AV *) /* args to call listed by caller function */
329
330/* symbol tables */
49f531da
NIS
331PERLVAR(Idebstash, HV *) /* symbol table for perldb package */
332PERLVAR(Iglobalstash, HV *) /* global keyword overrides imported here */
333PERLVAR(Icurstname, SV *) /* name of current package */
334PERLVAR(Ibeginav, AV *) /* names of BEGIN subroutines */
d4cce5f1 335PERLVAR(Iendav, AV *) /* names of END subroutines */
3c10abe3 336PERLVAR(Iunitcheckav, AV *) /* names of UNITCHECK subroutines */
7d30b5c4 337PERLVAR(Icheckav, AV *) /* names of CHECK subroutines */
49f531da
NIS
338PERLVAR(Iinitav, AV *) /* names of INIT subroutines */
339PERLVAR(Istrtab, HV *) /* shared string table */
005a453c 340PERLVARI(Isub_generation,U32,1) /* incr to invalidate method cache */
49f531da 341
9f7da6d5
NC
342/* funky return mechanisms */
343PERLVAR(Iforkprocess, int) /* so do_open |- can return proc# */
344
49f531da 345/* memory management */
49f531da
NIS
346PERLVAR(Isv_count, I32) /* how many SV* are currently allocated */
347PERLVAR(Isv_objcount, I32) /* how many objects are currently allocated */
348PERLVAR(Isv_root, SV*) /* storage for SVs belonging to interp */
349PERLVAR(Isv_arenaroot, SV*) /* list of areas for garbage collection */
350
49f531da 351/* subprocess state */
d4cce5f1 352PERLVAR(Ifdpid, AV *) /* keep fd-to-pid mappings for my_popen */
49f531da
NIS
353
354/* internal state */
49f531da
NIS
355PERLVARI(Iop_mask, char *, NULL) /* masked operations for safe evals */
356
49f531da 357/* current interpreter roots */
cb68f92d
GS
358PERLVAR(Imain_cv, CV *)
359PERLVAR(Imain_root, OP *)
360PERLVAR(Imain_start, OP *)
361PERLVAR(Ieval_root, OP *)
362PERLVAR(Ieval_start, OP *)
49f531da
NIS
363
364/* runtime control stuff */
cb68f92d 365PERLVARI(Icurcopdb, COP *, NULL)
49f531da 366
49f531da
NIS
367PERLVAR(Ifilemode, int) /* so nextargv() can preserve mode */
368PERLVAR(Ilastfd, int) /* what to preserve mode on */
369PERLVAR(Ioldname, char *) /* what to preserve mode on */
360ea906 370PERLVAR(IArgv, const char **) /* stuff to free from do_aexec, vfork safe */
d4cce5f1 371PERLVAR(ICmd, char *) /* stuff to free from do_aexec, vfork safe */
00accf8d
NC
372/* Elements in this array have ';' appended and are injected as a single line
373 into the tokeniser. You can't put any (literal) newlines into any program
374 you stuff in into this array, as the point where it's injected is expecting
375 a single physical line. */
cb68f92d 376PERLVAR(Ipreambleav, AV *)
cb68f92d 377PERLVAR(Imess_sv, SV *)
7889fe52 378PERLVAR(Iors_sv, SV *) /* output record separator $\ */
71eebe1e
NC
379/* statics moved here for shared library purposes */
380PERLVARI(Igensym, I32, 0) /* next symbol for getsym() to define */
a4021b77 381PERLVARI(Icv_has_eval, bool, FALSE) /* PL_compcv includes an entereval or similar */
157b3822 382PERLVAR(Itaint_warn, bool) /* taint warns instead of dying */
d95e864f
NC
383PERLVARI(Ilaststype, U16, OP_STAT)
384PERLVARI(Ilaststatval, int, -1)
d4cce5f1 385
4b556e6c 386/* interpreter atexit processing */
d95e864f 387PERLVARI(Iexitlistlen, I32, 0) /* length of same */
cb68f92d
GS
388PERLVARI(Iexitlist, PerlExitListEntry *, NULL)
389 /* list of exit functions */
954c1994
GS
390
391/*
392=for apidoc Amn|HV*|PL_modglobal
393
7889fe52 394C<PL_modglobal> is a general purpose, interpreter global HV for use by
954c1994 395extensions that need to keep information on a per-interpreter basis.
7889fe52
NIS
396In a pinch, it can also be used as a symbol table for extensions
397to share data among each other. It is a good idea to use keys
954c1994
GS
398prefixed by the package name of the extension that owns the data.
399
400=cut
401*/
402
cb68f92d
GS
403PERLVAR(Imodglobal, HV *) /* per-interp module data */
404
405/* these used to be in global before 5.004_68 */
406PERLVARI(Iprofiledata, U32 *, NULL) /* table of ops, counts */
cb68f92d
GS
407
408PERLVAR(Icompiling, COP) /* compiling/done executing marker */
409
410PERLVAR(Icompcv, CV *) /* currently compiling subroutine */
411PERLVAR(Icomppad, AV *) /* storage for lexically scoped temporaries */
412PERLVAR(Icomppad_name, AV *) /* variable names for "my" variables */
413PERLVAR(Icomppad_name_fill, I32) /* last "introduced" variable offset */
414PERLVAR(Icomppad_name_floor, I32) /* start of vars in innermost block */
4b556e6c
JD
415
416#ifdef HAVE_INTERP_INTERN
cb68f92d
GS
417PERLVAR(Isys_intern, struct interp_intern)
418 /* platform internals */
4b556e6c
JD
419#endif
420
7fae4e64 421/* more statics moved here */
7fae4e64 422PERLVAR(IDBcv, CV *) /* from perl.c */
9f7da6d5 423PERLVARI(Igeneration, int, 100) /* from op.c */
56953603 424
cb68f92d
GS
425PERLVARI(Iin_clean_objs,bool, FALSE) /* from sv.c */
426PERLVARI(Iin_clean_all, bool, FALSE) /* from sv.c */
9f7da6d5
NC
427PERLVAR(Inomemok, bool) /* let malloc context handle nomem */
428PERLVARI(Isavebegin, bool, FALSE) /* save BEGINs for compiler */
7fae4e64 429
d8eceb89
JH
430PERLVAR(Iuid, Uid_t) /* current real user id */
431PERLVAR(Ieuid, Uid_t) /* current effective user id */
432PERLVAR(Igid, Gid_t) /* current real group id */
433PERLVAR(Iegid, Gid_t) /* current effective group id */
bf9cdc68
RG
434PERLVARI(Ian, U32, 0) /* malloc sequence number */
435PERLVARI(Icop_seqmax, U32, 0) /* statement sequence number */
bf9cdc68 436PERLVARI(Ievalseq, U32, 0) /* eval sequence number */
0672f40e 437PERLVAR(Iorigalen, U32)
9f7da6d5 438PERLVAR(Iorigenviron, char **)
ca0c25f6 439#ifdef PERL_USES_PL_PIDSTATUS
0672f40e 440PERLVAR(Ipidstatus, HV *) /* pid-to-status mappings for waitpid */
ca0c25f6 441#endif
0672f40e 442PERLVAR(Iosname, char *) /* operating system */
5c728af0 443
0672f40e
GS
444PERLVAR(Isighandlerp, Sighandler_t)
445
232d1c15 446PERLVARA(Ibody_roots, PERL_ARENA_ROOTS_SIZE, void*) /* array of body roots */
93e68bfb 447
ed29bbba 448PERLVAR(Iunicode, U32) /* Unicode features: $ENV{PERL_UNICODE} or -C */
0672f40e 449
9f7da6d5
NC
450PERLVARI(Imaxo, int, MAXO) /* maximum number of ops */
451
0b94c7bb 452PERLVARI(Irunops, runops_proc_t, MEMBER_TO_FPTR(RUNOPS_DEFAULT))
0672f40e 453
954c1994
GS
454/*
455=for apidoc Amn|SV|PL_sv_undef
456This is the C<undef> SV. Always refer to this as C<&PL_sv_undef>.
457
458=for apidoc Amn|SV|PL_sv_no
459This is the C<false> SV. See C<PL_sv_yes>. Always refer to this as
460C<&PL_sv_no>.
461
462=for apidoc Amn|SV|PL_sv_yes
463This is the C<true> SV. See C<PL_sv_no>. Always refer to this as
464C<&PL_sv_yes>.
465
466=cut
467*/
468
0672f40e
GS
469PERLVAR(Isv_undef, SV)
470PERLVAR(Isv_no, SV)
471PERLVAR(Isv_yes, SV)
472
0672f40e
GS
473PERLVAR(Isubname, SV *) /* name of current subroutine */
474
d95e864f 475PERLVAR(Isubline, I32) /* line this subroutine began on */
0672f40e 476PERLVAR(Imin_intro_pending, I32) /* start of vars to introduce */
d95e864f 477
0672f40e
GS
478PERLVAR(Imax_intro_pending, I32) /* end of vars to introduce */
479PERLVAR(Ipadix, I32) /* max used index in current "register" pad */
d95e864f 480
0672f40e 481PERLVAR(Ipadix_floor, I32) /* how low may inner block reset padix */
0672f40e 482
1d7c1841 483PERLVAR(Ihints, U32) /* pragma-tic compile-time flags */
0672f40e
GS
484
485PERLVAR(Idebug, VOL U32) /* flags given to -D switch */
486
f0cb02e3
NC
487/* Perl_Ibreakable_sub_generation_ptr was too long for VMS, hence "gen" */
488PERLVARI(Ibreakable_sub_gen, U32, 0)
489
bf9cdc68 490PERLVARI(Iamagic_generation, long, 0)
0672f40e
GS
491
492#ifdef USE_LOCALE_COLLATE
0672f40e 493PERLVAR(Icollation_name,char *) /* Name of current collation */
0672f40e
GS
494PERLVAR(Icollxfrm_base, Size_t) /* Basic overhead in *xfrm() */
495PERLVARI(Icollxfrm_mult,Size_t, 2) /* Expansion factor in *xfrm() */
9f7da6d5
NC
496PERLVARI(Icollation_ix, U32, 0) /* Collation generation index */
497PERLVARI(Icollation_standard, bool, TRUE)
498 /* Assume simple collation */
0672f40e
GS
499#endif /* USE_LOCALE_COLLATE */
500
9f7da6d5 501
edd11d75 502#if defined (PERL_UTF8_CACHE_ASSERT) || defined (DEBUGGING)
95ca8690 503# define PERL___I -1
9f7da6d5 504#else
7cd91da4 505# define PERL___I 1
9f7da6d5 506#endif
95ca8690
DM
507PERLVARI(Iutf8cache, I8, PERL___I) /* Is the utf8 caching code enabled? */
508#undef PERL___I
509
9f7da6d5 510
0672f40e
GS
511#ifdef USE_LOCALE_NUMERIC
512
0672f40e
GS
513PERLVARI(Inumeric_standard, bool, TRUE)
514 /* Assume simple numerics */
515PERLVARI(Inumeric_local, bool, TRUE)
516 /* Assume local numerics */
9f7da6d5 517PERLVAR(Inumeric_name, char *) /* Name of current numeric locale */
0672f40e
GS
518#endif /* !USE_LOCALE_NUMERIC */
519
520/* utf8 character classes */
521PERLVAR(Iutf8_alnum, SV *)
b8c5462f 522PERLVAR(Iutf8_ascii, SV *)
0672f40e
GS
523PERLVAR(Iutf8_alpha, SV *)
524PERLVAR(Iutf8_space, SV *)
d1eb3177
YO
525PERLVAR(Iutf8_perl_space, SV *)
526PERLVAR(Iutf8_perl_word, SV *)
527PERLVAR(Iutf8_posix_digit, SV *)
b8c5462f
JH
528PERLVAR(Iutf8_cntrl, SV *)
529PERLVAR(Iutf8_graph, SV *)
0672f40e
GS
530PERLVAR(Iutf8_digit, SV *)
531PERLVAR(Iutf8_upper, SV *)
532PERLVAR(Iutf8_lower, SV *)
533PERLVAR(Iutf8_print, SV *)
b8c5462f
JH
534PERLVAR(Iutf8_punct, SV *)
535PERLVAR(Iutf8_xdigit, SV *)
0672f40e 536PERLVAR(Iutf8_mark, SV *)
37e2e78e
KW
537PERLVAR(Iutf8_X_begin, SV *)
538PERLVAR(Iutf8_X_extend, SV *)
539PERLVAR(Iutf8_X_prepend, SV *)
540PERLVAR(Iutf8_X_non_hangul, SV *)
541PERLVAR(Iutf8_X_L, SV *)
542PERLVAR(Iutf8_X_LV, SV *)
543PERLVAR(Iutf8_X_LVT, SV *)
544PERLVAR(Iutf8_X_T, SV *)
545PERLVAR(Iutf8_X_V, SV *)
546PERLVAR(Iutf8_X_LV_LVT_V, SV *)
0672f40e
GS
547PERLVAR(Iutf8_toupper, SV *)
548PERLVAR(Iutf8_totitle, SV *)
549PERLVAR(Iutf8_tolower, SV *)
b4e400f9 550PERLVAR(Iutf8_tofold, SV *)
0672f40e 551PERLVAR(Ilast_swash_hv, HV *)
0672f40e
GS
552PERLVAR(Ilast_swash_tmps, U8 *)
553PERLVAR(Ilast_swash_slen, STRLEN)
9f7da6d5 554PERLVARA(Ilast_swash_key,10, U8)
d95e864f
NC
555PERLVAR(Ilast_swash_klen, U8) /* Only needs to store 0-10 */
556
557#ifdef FCRYPT
558PERLVARI(Icryptseen, bool, FALSE) /* has fast crypt() been initialized? */
559#endif
560
f0cb02e3 561PERLVAR(Ipad_reset_pending, bool) /* reset pad on next attempted alloc */
49947b44 562
d95e864f
NC
563PERLVARI(Iglob_index, int, 0)
564
0672f40e 565
5912531f 566PERLVAR(Iparser, yy_parser *) /* current parser state */
12fbd33b 567
c4a30c8c
NC
568/* Array of signal handlers, indexed by signal number, through which the C
569 signal handler dispatches. */
1d7c1841 570PERLVAR(Ipsig_ptr, SV**)
c4a30c8c 571/* Array of names of signals, indexed by signal number, for (re)use as the first
d525a7b2
NC
572 argument to a signal handler. Only one block of memory is allocated for
573 both psig_name and psig_ptr. */
c4a30c8c 574PERLVAR(Ipsig_name, SV**)
1d7c1841 575
c5be433b 576#if defined(PERL_IMPLICIT_SYS)
32e30700 577PERLVAR(IMem, struct IPerlMem*)
1d7c1841
GS
578PERLVAR(IMemShared, struct IPerlMem*)
579PERLVAR(IMemParse, struct IPerlMem*)
32e30700
GS
580PERLVAR(IEnv, struct IPerlEnv*)
581PERLVAR(IStdIO, struct IPerlStdIO*)
582PERLVAR(ILIO, struct IPerlLIO*)
583PERLVAR(IDir, struct IPerlDir*)
584PERLVAR(ISock, struct IPerlSock*)
585PERLVAR(IProc, struct IPerlProc*)
76e3520e 586#endif
1d7c1841 587
1d7c1841 588PERLVAR(Iptr_table, PTR_TBL_t*)
7d49f689 589PERLVARI(Ibeginav_save, AV*, NULL) /* save BEGIN{}s when compiling */
f180df80 590
fdda85ca 591PERLVAR(Ibody_arenas, void*) /* pointer to list of body-arenas */
93e68bfb 592
d95e864f 593
a453c169
JH
594#ifdef USE_LOCALE_NUMERIC
595
596PERLVAR(Inumeric_radix_sv, SV *) /* The radix separator if not '.' */
597
598#endif
ce08f86c 599
1fcf4c12 600#if defined(USE_ITHREADS)
e6853197
NC
601PERLVAR(Iregex_pad, SV**) /* Shortcut into the array of
602 regex_padav */
603PERLVAR(Iregex_padav, AV*) /* All regex objects, indexed via the
604 values in op_pmoffset of pmop.
402d2eb1
NC
605 Entry 0 is an SV whose PV is a
606 "packed" list of IVs listing
e6853197 607 the now-free slots in the array */
1fcf4c12
AB
608#endif
609
ea68fd67
NC
610#ifdef USE_REENTRANT_API
611PERLVAR(Ireentrant_buffer, REENTR*) /* here we store the _r buffers */
f5a82810
JH
612#endif
613
53e06cf0
SC
614PERLVAR(Icustom_op_names, HV*) /* Names of user defined ops */
615PERLVAR(Icustom_op_descs, HV*) /* Descriptions of user defined ops */
19e8ce8e 616
a1ea730d
NIS
617#ifdef PERLIO_LAYERS
618PERLVARI(Iperlio, PerlIO *,NULL)
3a1ee7e8
NIS
619PERLVARI(Iknown_layers, PerlIO_list_t *,NULL)
620PERLVARI(Idef_layerlist, PerlIO_list_t *,NULL)
a1ea730d
NIS
621#endif
622
a0714e2c 623PERLVARI(Iencoding, SV*, NULL) /* character encoding */
0a378802 624
128e8167 625PERLVAR(Idebug_pad, struct perl_debug_pad) /* always needed because of the re extension */
ce333219 626
82686b01
JH
627PERLVAR(Iutf8_idstart, SV *)
628PERLVAR(Iutf8_idcont, SV *)
629
147f47de
AB
630PERLVAR(Isort_RealCmp, SVCOMPARE_t)
631
7d49f689 632PERLVARI(Icheckav_save, AV*, NULL) /* save CHECK{}s when compiling */
3c10abe3 633PERLVARI(Iunitcheckav_save, AV*, NULL) /* save UNITCHECK{}s when compiling */
ece599bd 634
5311654c
JH
635PERLVARI(Iclocktick, long, 0) /* this many times() ticks in a second */
636
4ffa73a3
JH
637PERLVAR(Isignals, U32) /* Using which pre-5.8 signals */
638
57c6e6d2
JH
639PERLVAR(Ireentrant_retint, int) /* Integer return value from reentrant functions */
640
9f7da6d5
NC
641PERLVAR(Istashcache, HV *) /* Cache to speed up S_method_common */
642
15a5279a
JH
643/* Hooks to shared SVs and locks. */
644PERLVARI(Isharehook, share_proc_t, MEMBER_TO_FPTR(Perl_sv_nosharing))
d5b2b27b 645PERLVARI(Ilockhook, share_proc_t, MEMBER_TO_FPTR(Perl_sv_nosharing))
d0647d4e
NC
646#ifdef NO_MATHOMS
647# define PERL_UNLOCK_HOOK Perl_sv_nosharing
648#else
649/* This reference ensures that the mathoms are linked with perl */
650# define PERL_UNLOCK_HOOK Perl_sv_nounlocking
651#endif
652PERLVARI(Iunlockhook, share_proc_t, MEMBER_TO_FPTR(PERL_UNLOCK_HOOK))
653
15a5279a
JH
654PERLVARI(Ithreadhook, thrhook_proc_t, MEMBER_TO_FPTR(Perl_nothreadhook))
655
92f022bb
DM
656PERLVARI(Isignalhook, despatch_signals_proc_t, MEMBER_TO_FPTR(Perl_despatch_signals))
657
504f80c1
JH
658PERLVARI(Ihash_seed, UV, 0) /* Hash initializer */
659
008fb0c0 660PERLVARI(Irehash_seed, UV, 0) /* 582 hash initializer */
4b5190b5 661
ba6d381e 662PERLVARI(Iisarev, HV*, NULL) /* Reverse map of @ISA dependencies */
f16dd614 663
ffee3ff6
NC
664/* The last unconditional member of the interpreter structure when 5.10.0 was
665 released. The offset of the end of this is baked into a global variable in
666 any shared perl library which will allow a sanity test in future perl
667 releases. */
668#define PERL_LAST_5_10_0_INTERP_MEMBER Iisarev
669
f16dd614 670#ifdef PERL_IMPLICIT_CONTEXT
4c901e72 671PERLVARI(Imy_cxt_size, int, 0) /* size of PL_my_cxt_list */
f16dd614 672PERLVARI(Imy_cxt_list, void **, NULL) /* per-module array of MY_CXT pointers */
ba6d381e 673# ifdef PERL_GLOBAL_STRUCT_PRIVATE
53d44271 674PERLVARI(Imy_cxt_keys, const char **, NULL) /* per-module array of pointers to MY_CXT_KEY constants */
ba6d381e 675# endif
f16dd614
DM
676#endif
677
7cb608b5
NC
678#ifdef PERL_TRACK_MEMPOOL
679/* For use with the memory debugging code in util.c */
680PERLVAR(Imemory_debug_header, struct perl_memory_debug_header)
681#endif
682
ba6d381e
NC
683#ifdef DEBUG_LEAKING_SCALARS_FORK_DUMP
684/* File descriptor to talk to the child which dumps scalars. */
685PERLVARI(Idumper_fd, int, -1)
686#endif
687
688/* Stores the PPID */
689#ifdef THREADS_HAVE_PIDS
690PERLVARI(Ippid, IV, 0)
691#endif
692
693#ifdef PERL_MAD
694PERLVARI(Imadskills, bool, FALSE) /* preserve all syntactic info */
695 /* (MAD = Misc Attribute Decoration) */
696PERLVARI(Ixmlfp, PerlIO *,NULL)
697#endif
698
699#ifdef PL_OP_SLAB_ALLOC
700PERLVAR(IOpPtr,I32 **)
701PERLVARI(IOpSpace,I32,0)
702PERLVAR(IOpSlab,I32 *)
703#endif
704
f1fac472
NC
705#ifdef PERL_DEBUG_READONLY_OPS
706PERLVARI(Islabs, I32**, NULL) /* Array of slabs that have been allocated */
707PERLVARI(Islab_count, U32, 0) /* Size of the array */
708#endif
709
eba16661
JH
710/* Can shared object be destroyed */
711PERLVARI(Idestroyhook, destroyable_proc_t, MEMBER_TO_FPTR(Perl_sv_destroyable))
712
d7a2c63c
MHM
713#ifdef DEBUG_LEAKING_SCALARS
714PERLVARI(Isv_serial, U32, 0) /* SV serial number, used in sv.c */
715#endif
716
a3e6e81e
NC
717/* Register of known Method Resolution Orders.
718 What this actually points to is an implementation detail (it may change to
719 a structure incorporating a reference count - use mro_get_from_name to
720 retrieve a C<struct mro_alg *> */
721PERLVAR(Iregistered_mros, HV *)
722
1930840b
BM
723/* Compile-time block start/end hooks */
724PERLVAR(Iblockhooks, AV *)
725
157b3822
NC
726/* If you are adding a U8 or U16, check to see if there are 'Space' comments
727 * above on where there are gaps which currently will be structure padding. */
d95e864f
NC
728
729/* Within a stable branch, new variables must be added to the very end, before
730 * this comment, for binary compatibility (the offsets of the old members must
731 * not change).
b83cd129 732 * (Don't forget to add your variable also to perl_clone()!)
e3acbfda 733 * XSUB.h provides wrapper functions via perlapi.h that make this
b83cd129
JH
734 * irrelevant, but not all code may be expected to #include XSUB.h.
735 */