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