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