This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
expand Porting/release_managers_guide.pod
[perl5.git] / perl.h
1 /*    perl.h
2  *
3  *    Copyright (C) 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001
4  *    2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 by Larry Wall and others
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 #ifndef H_PERL
12 #define H_PERL 1
13
14 #ifdef PERL_FOR_X2P
15 /*
16  * This file is being used for x2p stuff.
17  * Above symbol is defined via -D in 'x2p/Makefile.SH'
18  * Decouple x2p stuff from some of perls more extreme eccentricities.
19  */
20 #undef MULTIPLICITY
21 #undef USE_STDIO
22 #define USE_STDIO
23 #endif /* PERL_FOR_X2P */
24
25 #if defined(DGUX)
26 #include <sys/fcntl.h>
27 #endif
28
29 #ifdef VOIDUSED
30 #   undef VOIDUSED
31 #endif 
32 #define VOIDUSED 1
33
34 #ifdef PERL_MICRO
35 #   include "uconfig.h"
36 #else
37 #   ifndef USE_CROSS_COMPILE
38 #       include "config.h"
39 #   else
40 #       include "xconfig.h"
41 #   endif
42 #endif
43
44 /* See L<perlguts/"The Perl API"> for detailed notes on
45  * PERL_IMPLICIT_CONTEXT and PERL_IMPLICIT_SYS */
46
47 /* Note that from here --> to <-- the same logic is
48  * repeated in makedef.pl, so be certain to update
49  * both places when editing. */
50
51 #ifdef PERL_IMPLICIT_SYS
52 /* PERL_IMPLICIT_SYS implies PerlMemShared != PerlMem
53    so use slab allocator to avoid lots of MUTEX overhead
54  */
55 #  ifndef PL_OP_SLAB_ALLOC
56 #    define PL_OP_SLAB_ALLOC
57 #  endif
58 #endif
59
60 #ifdef USE_ITHREADS
61 #  if !defined(MULTIPLICITY)
62 #    define MULTIPLICITY
63 #  endif
64 #endif
65
66 #ifdef PERL_GLOBAL_STRUCT_PRIVATE
67 #  ifndef PERL_GLOBAL_STRUCT
68 #    define PERL_GLOBAL_STRUCT
69 #  endif
70 #endif
71
72 #ifdef PERL_GLOBAL_STRUCT
73 #  ifndef MULTIPLICITY
74 #    define MULTIPLICITY
75 #  endif
76 #endif
77
78 #ifdef MULTIPLICITY
79 #  ifndef PERL_IMPLICIT_CONTEXT
80 #    define PERL_IMPLICIT_CONTEXT
81 #  endif
82 #endif
83
84 /* undef WIN32 when building on Cygwin (for libwin32) - gph */
85 #ifdef __CYGWIN__
86 #   undef WIN32
87 #   undef _WIN32
88 #endif
89
90 #if defined(__SYMBIAN32__) || (defined(__VC32__) && defined(WINS))
91 #   ifndef SYMBIAN
92 #       define SYMBIAN
93 #   endif
94 #endif
95
96 #ifdef __SYMBIAN32__
97 #  include "symbian/symbian_proto.h"
98 #endif
99
100 /* Any stack-challenged places.  The limit varies (and often
101  * is configurable), but using more than a kilobyte of stack
102  * is usually dubious in these systems. */
103 #if defined(EPOC) || defined(__SYMBIAN32__)
104 /* EPOC/Symbian: need to work around the SDK features. *
105  * On WINS: MS VC5 generates calls to _chkstk,         *
106  * if a "large" stack frame is allocated.              *
107  * gcc on MARM does not generate calls like these.     */
108 #   define USE_HEAP_INSTEAD_OF_STACK
109 #endif
110
111 #/* Use the reentrant APIs like localtime_r and getpwent_r */
112 /* Win32 has naturally threadsafe libraries, no need to use any _r variants. */
113 #if defined(USE_ITHREADS) && !defined(USE_REENTRANT_API) && !defined(NETWARE) && !defined(WIN32) && !defined(PERL_DARWIN)
114 #   define USE_REENTRANT_API
115 #endif
116
117 /* <--- here ends the logic shared by perl.h and makedef.pl */
118
119 /*
120  * PERL_DARWIN for MacOSX (__APPLE__ exists but is not officially sanctioned)
121  * (The -DPERL_DARWIN comes from the hints/darwin.sh.)
122  * __bsdi__ for BSD/OS
123  */
124 #if defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(PERL_DARWIN) || defined(__bsdi__) || defined(BSD41) || defined(BSD42) || defined(BSD43) || defined(BSD44)
125 #   ifndef BSDish
126 #       define BSDish
127 #   endif
128 #endif
129
130 #undef START_EXTERN_C
131 #undef END_EXTERN_C
132 #undef EXTERN_C
133 #ifdef __cplusplus
134 #  define START_EXTERN_C extern "C" {
135 #  define END_EXTERN_C }
136 #  define EXTERN_C extern "C"
137 #else
138 #  define START_EXTERN_C
139 #  define END_EXTERN_C
140 #  define EXTERN_C extern
141 #endif
142
143 #ifdef PERL_GLOBAL_STRUCT
144 #  ifndef PERL_GET_VARS
145 #    ifdef PERL_GLOBAL_STRUCT_PRIVATE
146        EXTERN_C struct perl_vars* Perl_GetVarsPrivate();
147 #      define PERL_GET_VARS() Perl_GetVarsPrivate() /* see miniperlmain.c */
148 #      ifndef PERLIO_FUNCS_CONST
149 #        define PERLIO_FUNCS_CONST /* Can't have these lying around. */
150 #      endif
151 #    else
152 #      define PERL_GET_VARS() PL_VarsPtr
153 #    endif
154 #  endif
155 #endif
156
157 #define pVAR    register struct perl_vars* my_vars PERL_UNUSED_DECL
158
159 #ifdef PERL_GLOBAL_STRUCT
160 #  define dVAR          pVAR    = (struct perl_vars*)PERL_GET_VARS()
161 #else
162 #  define dVAR          dNOOP
163 #endif
164
165 #ifdef PERL_IMPLICIT_CONTEXT
166 #  ifndef MULTIPLICITY
167 #    define MULTIPLICITY
168 #  endif
169 #  define tTHX  PerlInterpreter*
170 #  define pTHX  register tTHX my_perl PERL_UNUSED_DECL
171 #  define aTHX  my_perl
172 #  ifdef PERL_GLOBAL_STRUCT
173 #    define dTHXa(a)    dVAR; pTHX = (tTHX)a
174 #  else
175 #    define dTHXa(a)    pTHX = (tTHX)a
176 #  endif
177 #  ifdef PERL_GLOBAL_STRUCT
178 #    define dTHX                dVAR; pTHX = PERL_GET_THX
179 #  else
180 #    define dTHX                pTHX = PERL_GET_THX
181 #  endif
182 #  define pTHX_         pTHX,
183 #  define aTHX_         aTHX,
184 #  define pTHX_1        2
185 #  define pTHX_2        3
186 #  define pTHX_3        4
187 #  define pTHX_4        5
188 #  define pTHX_5        6
189 #  define pTHX_6        7
190 #  define pTHX_7        8
191 #  define pTHX_8        9
192 #  define pTHX_9        10
193 #  if defined(DEBUGGING) && !defined(PERL_TRACK_MEMPOOL)
194 #    define PERL_TRACK_MEMPOOL
195 #  endif
196 #else
197 #  undef PERL_TRACK_MEMPOOL
198 #endif
199
200 #define STATIC static
201 #define CPERLscope(x) x
202 #define CPERLarg void
203 #define CPERLarg_
204 #define _CPERLarg
205 #define PERL_OBJECT_THIS
206 #define _PERL_OBJECT_THIS
207 #define PERL_OBJECT_THIS_
208 #define CALL_FPTR(fptr) (*fptr)
209
210 #define CALLRUNOPS  CALL_FPTR(PL_runops)
211
212 #define CALLREGCOMP(sv, flags) Perl_pregcomp(aTHX_ (sv),(flags))
213
214 #define CALLREGCOMP_ENG(prog, sv, flags) \
215     CALL_FPTR(((prog)->comp))(aTHX_ sv, flags)
216 #define CALLREGEXEC(prog,stringarg,strend,strbeg,minend,screamer,data,flags) \
217     CALL_FPTR(RX_ENGINE(prog)->exec)(aTHX_ (prog),(stringarg),(strend), \
218         (strbeg),(minend),(screamer),(data),(flags))
219 #define CALLREG_INTUIT_START(prog,sv,strpos,strend,flags,data) \
220     CALL_FPTR(RX_ENGINE(prog)->intuit)(aTHX_ (prog), (sv), (strpos), \
221         (strend),(flags),(data))
222 #define CALLREG_INTUIT_STRING(prog) \
223     CALL_FPTR(RX_ENGINE(prog)->checkstr)(aTHX_ (prog))
224
225 #define CALLREGFREE(prog) \
226     Perl_pregfree(aTHX_ (prog))
227
228 #define CALLREGFREE_PVT(prog) \
229     if(prog) CALL_FPTR(RX_ENGINE(prog)->free)(aTHX_ (prog))
230
231 #define CALLREG_NUMBUF_FETCH(rx,paren,usesv)                                \
232     CALL_FPTR(RX_ENGINE(rx)->numbered_buff_FETCH)(aTHX_ (rx),(paren),(usesv))
233
234 #define CALLREG_NUMBUF_STORE(rx,paren,value) \
235     CALL_FPTR(RX_ENGINE(rx)->numbered_buff_STORE)(aTHX_ (rx),(paren),(value))
236
237 #define CALLREG_NUMBUF_LENGTH(rx,sv,paren)                              \
238     CALL_FPTR(RX_ENGINE(rx)->numbered_buff_LENGTH)(aTHX_ (rx),(sv),(paren))
239
240 #define CALLREG_NAMED_BUFF_FETCH(rx, key, flags) \
241     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), (key), NULL, ((flags) | RXapif_FETCH))
242
243 #define CALLREG_NAMED_BUFF_STORE(rx, key, value, flags) \
244     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), (key), (value), ((flags) | RXapif_STORE))
245
246 #define CALLREG_NAMED_BUFF_DELETE(rx, key, flags) \
247     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx),(key), NULL, ((flags) | RXapif_DELETE))
248
249 #define CALLREG_NAMED_BUFF_CLEAR(rx, flags) \
250     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), NULL, NULL, ((flags) | RXapif_CLEAR))
251
252 #define CALLREG_NAMED_BUFF_EXISTS(rx, key, flags) \
253     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), (key), NULL, ((flags) | RXapif_EXISTS))
254
255 #define CALLREG_NAMED_BUFF_FIRSTKEY(rx, flags) \
256     CALL_FPTR(RX_ENGINE(rx)->named_buff_iter)(aTHX_ (rx), NULL, ((flags) | RXapif_FIRSTKEY))
257
258 #define CALLREG_NAMED_BUFF_NEXTKEY(rx, lastkey, flags) \
259     CALL_FPTR(RX_ENGINE(rx)->named_buff_iter)(aTHX_ (rx), (lastkey), ((flags) | RXapif_NEXTKEY))
260
261 #define CALLREG_NAMED_BUFF_SCALAR(rx, flags) \
262     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), NULL, NULL, ((flags) | RXapif_SCALAR))
263
264 #define CALLREG_NAMED_BUFF_COUNT(rx) \
265     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), NULL, NULL, RXapif_REGNAMES_COUNT)
266
267 #define CALLREG_NAMED_BUFF_ALL(rx, flags) \
268     CALL_FPTR(RX_ENGINE(rx)->named_buff)(aTHX_ (rx), NULL, NULL, flags)
269
270 #define CALLREG_PACKAGE(rx) \
271     CALL_FPTR(RX_ENGINE(rx)->qr_package)(aTHX_ (rx))
272
273 #if defined(USE_ITHREADS)         
274 #define CALLREGDUPE(prog,param) \
275     Perl_re_dup(aTHX_ (prog),(param))
276
277 #define CALLREGDUPE_PVT(prog,param) \
278     (prog ? CALL_FPTR(RX_ENGINE(prog)->dupe)(aTHX_ (prog),(param)) \
279           : (REGEXP *)NULL) 
280 #endif
281
282
283
284
285
286 /*
287  * Because of backward compatibility reasons the PERL_UNUSED_DECL
288  * cannot be changed from postfix to PERL_UNUSED_DECL(x).  Sigh.
289  *
290  * Note that there are C compilers such as MetroWerks CodeWarrior
291  * which do not have an "inlined" way (like the gcc __attribute__) of
292  * marking unused variables (they need e.g. a #pragma) and therefore
293  * cpp macros like PERL_UNUSED_DECL cannot work for this purpose, even
294  * if it were PERL_UNUSED_DECL(x), which it cannot be (see above).
295  *
296  */
297
298 #if defined(__SYMBIAN32__) && defined(__GNUC__)
299 #  ifdef __cplusplus
300 #    define PERL_UNUSED_DECL
301 #  else
302 #    define PERL_UNUSED_DECL __attribute__((unused))
303 #  endif
304 #endif
305
306 #ifndef PERL_UNUSED_DECL
307 #  if defined(HASATTRIBUTE_UNUSED) && !defined(__cplusplus)
308 #    define PERL_UNUSED_DECL __attribute__unused__
309 #  else
310 #    define PERL_UNUSED_DECL
311 #  endif
312 #endif
313  
314 /* gcc -Wall:
315  * for silencing unused variables that are actually used most of the time,
316  * but we cannot quite get rid of, such as "ax" in PPCODE+noargs xsubs
317  */
318 #ifndef PERL_UNUSED_ARG
319 #  if defined(lint) && defined(S_SPLINT_S) /* www.splint.org */
320 #    include <note.h>
321 #    define PERL_UNUSED_ARG(x) NOTE(ARGUNUSED(x))
322 #  else
323 #    define PERL_UNUSED_ARG(x) ((void)x)
324 #  endif
325 #endif
326 #ifndef PERL_UNUSED_VAR
327 #  define PERL_UNUSED_VAR(x) ((void)x)
328 #endif
329
330 #ifdef USE_ITHREADS
331 #  define PERL_UNUSED_CONTEXT PERL_UNUSED_ARG(my_perl)
332 #else
333 #  define PERL_UNUSED_CONTEXT
334 #endif
335
336 #define NOOP /*EMPTY*/(void)0
337 #if !defined(HASATTRIBUTE_UNUSED) && defined(__cplusplus)
338 #define dNOOP /*EMPTY*/(void)0 /* Older g++ has no __attribute((unused))__ */
339 #else
340 #define dNOOP extern int /*@unused@*/ Perl___notused PERL_UNUSED_DECL
341 #endif
342
343 #ifndef pTHX
344 /* Don't bother defining tTHX and sTHX; using them outside
345  * code guarded by PERL_IMPLICIT_CONTEXT is an error.
346  */
347 #  define pTHX          void
348 #  define pTHX_
349 #  define aTHX
350 #  define aTHX_
351 #  define dTHXa(a)      dNOOP
352 #  define dTHX          dNOOP
353 #  define pTHX_1        1       
354 #  define pTHX_2        2
355 #  define pTHX_3        3
356 #  define pTHX_4        4
357 #  define pTHX_5        5
358 #  define pTHX_6        6
359 #  define pTHX_7        7
360 #  define pTHX_8        8
361 #  define pTHX_9        9
362 #endif
363
364 #ifndef dVAR
365 #  define dVAR          dNOOP
366 #endif
367
368 /* these are only defined for compatibility; should not be used internally */
369 #if !defined(pTHXo) && !defined(PERL_CORE)
370 #  define pTHXo         pTHX
371 #  define pTHXo_        pTHX_
372 #  define aTHXo         aTHX
373 #  define aTHXo_        aTHX_
374 #  define dTHXo         dTHX
375 #  define dTHXoa(x)     dTHXa(x)
376 #endif
377
378 #ifndef pTHXx
379 #  define pTHXx         register PerlInterpreter *my_perl
380 #  define pTHXx_        pTHXx,
381 #  define aTHXx         my_perl
382 #  define aTHXx_        aTHXx,
383 #  define dTHXx         dTHX
384 #endif
385
386 /* Under PERL_IMPLICIT_SYS (used in Windows for fork emulation)
387  * PerlIO_foo() expands to PL_StdIO->pFOO(PL_StdIO, ...).
388  * dTHXs is therefore needed for all functions using PerlIO_foo(). */
389 #ifdef PERL_IMPLICIT_SYS
390 #  ifdef PERL_GLOBAL_STRUCT_PRIVATE
391 #    define dTHXs               dVAR; dTHX
392 #  else
393 #    define dTHXs               dTHX
394 #  endif
395 #else
396 #  ifdef PERL_GLOBAL_STRUCT_PRIVATE
397 #    define dTHXs               dVAR
398 #  else
399 #    define dTHXs               dNOOP
400 #  endif
401 #endif
402
403 /* Some platforms require marking function declarations
404  * for them to be exportable.  Used in perlio.h, proto.h
405  * is handled either by the makedef.pl or by defining the
406  * PERL_CALLCONV to be something special.  See also the
407  * definition of XS() in XSUB.h. */
408 #ifndef PERL_EXPORT_C
409 #  ifdef __cplusplus
410 #    define PERL_EXPORT_C extern "C"
411 #  else
412 #    define PERL_EXPORT_C extern
413 #  endif
414 #endif
415 #ifndef PERL_XS_EXPORT_C
416 #  ifdef __cplusplus
417 #    define PERL_XS_EXPORT_C extern "C"
418 #  else
419 #    define PERL_XS_EXPORT_C
420 #  endif
421 #endif
422
423 #ifdef OP_IN_REGISTER
424 #  ifdef __GNUC__
425 #    define stringify_immed(s) #s
426 #    define stringify(s) stringify_immed(s)
427 register struct op *Perl_op asm(stringify(OP_IN_REGISTER));
428 #  endif
429 #endif
430
431 /* gcc (-ansi) -pedantic doesn't allow gcc statement expressions,
432  * g++ allows them but seems to have problems with them
433  * (insane errors ensue).
434  * g++ does not give insane errors now (RMB 2008-01-30, gcc 4.2.2).
435  */
436 #if defined(PERL_GCC_PEDANTIC) || \
437     (defined(__GNUC__) && defined(__cplusplus) && \
438         ((__GNUC__ < 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ < 2))))
439 #  ifndef PERL_GCC_BRACE_GROUPS_FORBIDDEN
440 #    define PERL_GCC_BRACE_GROUPS_FORBIDDEN
441 #  endif
442 #endif
443
444 #if defined(__GNUC__) && !defined(PERL_GCC_BRACE_GROUPS_FORBIDDEN) && !defined(__cplusplus)
445 #  ifndef PERL_USE_GCC_BRACE_GROUPS
446 #    define PERL_USE_GCC_BRACE_GROUPS
447 #  endif
448 #endif
449
450 /*
451  * STMT_START { statements; } STMT_END;
452  * can be used as a single statement, as in
453  * if (x) STMT_START { ... } STMT_END; else ...
454  *
455  * Trying to select a version that gives no warnings...
456  */
457 #if !(defined(STMT_START) && defined(STMT_END))
458 # ifdef PERL_USE_GCC_BRACE_GROUPS
459 #   define STMT_START   (void)( /* gcc supports "({ STATEMENTS; })" */
460 #   define STMT_END     )
461 # else
462    /* Now which other defined()s do we need here ??? */
463 #  if (VOIDFLAGS) && (defined(sun) || defined(__sun__)) && !defined(__GNUC__)
464 #   define STMT_START   if (1)
465 #   define STMT_END     else (void)0
466 #  else
467 #   define STMT_START   do
468 #   define STMT_END     while (0)
469 #  endif
470 # endif
471 #endif
472
473 #define WITH_THX(s) STMT_START { dTHX; s; } STMT_END
474 #define WITH_THR(s) WITH_THX(s)
475
476 #ifndef BYTEORDER  /* Should never happen -- byteorder is in config.h */
477 #   define BYTEORDER 0x1234
478 #endif
479
480 /* Overall memory policy? */
481 #ifndef CONSERVATIVE
482 #   define LIBERAL 1
483 #endif
484
485 #if 'A' == 65 && 'I' == 73 && 'J' == 74 && 'Z' == 90
486 #define ASCIIish
487 #else
488 #undef  ASCIIish
489 #endif
490
491 /*
492  * The following contortions are brought to you on behalf of all the
493  * standards, semi-standards, de facto standards, not-so-de-facto standards
494  * of the world, as well as all the other botches anyone ever thought of.
495  * The basic theory is that if we work hard enough here, the rest of the
496  * code can be a lot prettier.  Well, so much for theory.  Sorry, Henry...
497  */
498
499 /* define this once if either system, instead of cluttering up the src */
500 #if defined(MSDOS) || defined(atarist) || defined(WIN32) || defined(NETWARE)
501 #define DOSISH 1
502 #endif
503
504 #if defined(__STDC__) || defined(_AIX) || defined(__stdc__) || defined(__cplusplus) || defined(EPOC) || defined(NETWARE) || defined(__SYMBIAN32__)
505 # define STANDARD_C 1
506 #endif
507
508 #if defined(__cplusplus) || defined(WIN32) || defined(__sgi) || defined(__EMX__) || defined(__DGUX) || defined(EPOC) || defined(__QNX__) || defined(NETWARE) || defined(PERL_MICRO)
509 # define DONT_DECLARE_STD 1
510 #endif
511
512 #if defined(HASVOLATILE) || defined(STANDARD_C)
513 #       define VOL volatile
514 #else
515 #   define VOL
516 #endif
517
518 #define TAINT           (PL_tainted = TRUE)
519 #define TAINT_NOT       (PL_tainted = FALSE)
520 #define TAINT_IF(c)     if (c) { PL_tainted = TRUE; }
521 #define TAINT_ENV()     if (PL_tainting) { taint_env(); }
522 #define TAINT_PROPER(s) if (PL_tainting) { taint_proper(NULL, s); }
523
524 /* XXX All process group stuff is handled in pp_sys.c.  Should these
525    defines move there?  If so, I could simplify this a lot. --AD  9/96.
526 */
527 /* Process group stuff changed from traditional BSD to POSIX.
528    perlfunc.pod documents the traditional BSD-style syntax, so we'll
529    try to preserve that, if possible.
530 */
531 #ifdef HAS_SETPGID
532 #  define BSD_SETPGRP(pid, pgrp)        setpgid((pid), (pgrp))
533 #else
534 #  if defined(HAS_SETPGRP) && defined(USE_BSD_SETPGRP)
535 #    define BSD_SETPGRP(pid, pgrp)      setpgrp((pid), (pgrp))
536 #  else
537 #    ifdef HAS_SETPGRP2  /* DG/UX */
538 #      define BSD_SETPGRP(pid, pgrp)    setpgrp2((pid), (pgrp))
539 #    endif
540 #  endif
541 #endif
542 #if defined(BSD_SETPGRP) && !defined(HAS_SETPGRP)
543 #  define HAS_SETPGRP  /* Well, effectively it does . . . */
544 #endif
545
546 /* getpgid isn't POSIX, but at least Solaris and Linux have it, and it makes
547     our life easier :-) so we'll try it.
548 */
549 #ifdef HAS_GETPGID
550 #  define BSD_GETPGRP(pid)              getpgid((pid))
551 #else
552 #  if defined(HAS_GETPGRP) && defined(USE_BSD_GETPGRP)
553 #    define BSD_GETPGRP(pid)            getpgrp((pid))
554 #  else
555 #    ifdef HAS_GETPGRP2  /* DG/UX */
556 #      define BSD_GETPGRP(pid)          getpgrp2((pid))
557 #    endif
558 #  endif
559 #endif
560 #if defined(BSD_GETPGRP) && !defined(HAS_GETPGRP)
561 #  define HAS_GETPGRP  /* Well, effectively it does . . . */
562 #endif
563
564 /* These are not exact synonyms, since setpgrp() and getpgrp() may
565    have different behaviors, but perl.h used to define USE_BSDPGRP
566    (prior to 5.003_05) so some extension might depend on it.
567 */
568 #if defined(USE_BSD_SETPGRP) || defined(USE_BSD_GETPGRP)
569 #  ifndef USE_BSDPGRP
570 #    define USE_BSDPGRP
571 #  endif
572 #endif
573
574 /* HP-UX 10.X CMA (Common Multithreaded Architecure) insists that
575    pthread.h must be included before all other header files.
576 */
577 #if defined(USE_ITHREADS) && defined(PTHREAD_H_FIRST) && defined(I_PTHREAD)
578 #  include <pthread.h>
579 #endif
580
581 #ifndef _TYPES_         /* If types.h defines this it's easy. */
582 #   ifndef major                /* Does everyone's types.h define this? */
583 #       include <sys/types.h>
584 #   endif
585 #endif
586
587 #ifdef __cplusplus
588 #  ifndef I_STDARG
589 #    define I_STDARG 1
590 #  endif
591 #endif
592
593 #ifdef I_STDARG
594 #  include <stdarg.h>
595 #else
596 #  ifdef I_VARARGS
597 #    include <varargs.h>
598 #  endif
599 #endif
600
601 #ifdef USE_NEXT_CTYPE
602
603 #if NX_CURRENT_COMPILER_RELEASE >= 500
604 #  include <bsd/ctypes.h>
605 #else
606 #  if NX_CURRENT_COMPILER_RELEASE >= 400
607 #    include <objc/NXCType.h>
608 #  else /*  NX_CURRENT_COMPILER_RELEASE < 400 */
609 #    include <appkit/NXCType.h>
610 #  endif /*  NX_CURRENT_COMPILER_RELEASE >= 400 */
611 #endif /*  NX_CURRENT_COMPILER_RELEASE >= 500 */
612
613 #else /* !USE_NEXT_CTYPE */
614 #include <ctype.h>
615 #endif /* USE_NEXT_CTYPE */
616
617 #ifdef METHOD   /* Defined by OSF/1 v3.0 by ctype.h */
618 #undef METHOD
619 #endif
620
621 #ifdef PERL_MICRO
622 #   define NO_LOCALE
623 #endif
624
625 #ifdef I_LOCALE
626 #   include <locale.h>
627 #endif
628
629 #if !defined(NO_LOCALE) && defined(HAS_SETLOCALE)
630 #   define USE_LOCALE
631 #   if !defined(NO_LOCALE_COLLATE) && defined(LC_COLLATE) \
632        && defined(HAS_STRXFRM)
633 #       define USE_LOCALE_COLLATE
634 #   endif
635 #   if !defined(NO_LOCALE_CTYPE) && defined(LC_CTYPE)
636 #       define USE_LOCALE_CTYPE
637 #   endif
638 #   if !defined(NO_LOCALE_NUMERIC) && defined(LC_NUMERIC)
639 #       define USE_LOCALE_NUMERIC
640 #   endif
641 #endif /* !NO_LOCALE && HAS_SETLOCALE */
642
643 #include <setjmp.h>
644
645 #ifdef I_SYS_PARAM
646 #   ifdef PARAM_NEEDS_TYPES
647 #       include <sys/types.h>
648 #   endif
649 #   include <sys/param.h>
650 #endif
651
652 /* Use all the "standard" definitions? */
653 #if defined(STANDARD_C) && defined(I_STDLIB)
654 #   include <stdlib.h>
655 #endif
656
657 /* If this causes problems, set i_unistd=undef in the hint file.  */
658 #ifdef I_UNISTD
659 #   include <unistd.h>
660 #endif
661
662 /* for WCOREDUMP */
663 #ifdef I_SYS_WAIT
664 #   include <sys/wait.h>
665 #endif
666
667 #ifdef __SYMBIAN32__
668 #   undef _SC_ARG_MAX /* Symbian has _SC_ARG_MAX but no sysconf() */
669 #endif
670
671 #if defined(HAS_SYSCALL) && !defined(HAS_SYSCALL_PROTO) && !defined(PERL_MICRO)
672 EXTERN_C int syscall(int, ...);
673 #endif
674
675 #if defined(HAS_USLEEP) && !defined(HAS_USLEEP_PROTO) && !defined(PERL_MICRO)
676 EXTERN_C int usleep(unsigned int);
677 #endif
678
679 /* Funky places that do not have socket stuff. */
680 #if defined(__LIBCATAMOUNT__)
681 #  define MYSWAP
682 #endif
683
684 #ifdef PERL_MICRO /* Last chance to export Perl_my_swap */
685 #  define MYSWAP
686 #endif
687
688 #ifdef PERL_CORE
689
690 /* macros for correct constant construction */
691 # if INTSIZE >= 2
692 #  define U16_CONST(x) ((U16)x##U)
693 # else
694 #  define U16_CONST(x) ((U16)x##UL)
695 # endif
696
697 # if INTSIZE >= 4
698 #  define U32_CONST(x) ((U32)x##U)
699 # else
700 #  define U32_CONST(x) ((U32)x##UL)
701 # endif
702
703 # ifdef HAS_QUAD
704 #  if INTSIZE >= 8
705 #   define U64_CONST(x) ((U64)x##U)
706 #  elif LONGSIZE >= 8
707 #   define U64_CONST(x) ((U64)x##UL)
708 #  elif QUADKIND == QUAD_IS_LONG_LONG
709 #   define U64_CONST(x) ((U64)x##ULL)
710 #  else /* best guess we can make */
711 #   define U64_CONST(x) ((U64)x##UL)
712 #  endif
713 # endif
714
715 /* byte-swapping functions for big-/little-endian conversion */
716 # define _swab_16_(x) ((U16)( \
717          (((U16)(x) & U16_CONST(0x00ff)) << 8) | \
718          (((U16)(x) & U16_CONST(0xff00)) >> 8) ))
719
720 # define _swab_32_(x) ((U32)( \
721          (((U32)(x) & U32_CONST(0x000000ff)) << 24) | \
722          (((U32)(x) & U32_CONST(0x0000ff00)) <<  8) | \
723          (((U32)(x) & U32_CONST(0x00ff0000)) >>  8) | \
724          (((U32)(x) & U32_CONST(0xff000000)) >> 24) ))
725
726 # ifdef HAS_QUAD
727 #  define _swab_64_(x) ((U64)( \
728           (((U64)(x) & U64_CONST(0x00000000000000ff)) << 56) | \
729           (((U64)(x) & U64_CONST(0x000000000000ff00)) << 40) | \
730           (((U64)(x) & U64_CONST(0x0000000000ff0000)) << 24) | \
731           (((U64)(x) & U64_CONST(0x00000000ff000000)) <<  8) | \
732           (((U64)(x) & U64_CONST(0x000000ff00000000)) >>  8) | \
733           (((U64)(x) & U64_CONST(0x0000ff0000000000)) >> 24) | \
734           (((U64)(x) & U64_CONST(0x00ff000000000000)) >> 40) | \
735           (((U64)(x) & U64_CONST(0xff00000000000000)) >> 56) ))
736 # endif
737
738 /*----------------------------------------------------------------------------*/
739 # if BYTEORDER == 0x1234 || BYTEORDER == 0x12345678  /*     little-endian     */
740 /*----------------------------------------------------------------------------*/
741 #  define my_htole16(x)         (x)
742 #  define my_letoh16(x)         (x)
743 #  define my_htole32(x)         (x)
744 #  define my_letoh32(x)         (x)
745 #  define my_htobe16(x)         _swab_16_(x)
746 #  define my_betoh16(x)         _swab_16_(x)
747 #  define my_htobe32(x)         _swab_32_(x)
748 #  define my_betoh32(x)         _swab_32_(x)
749 #  ifdef HAS_QUAD
750 #   define my_htole64(x)        (x)
751 #   define my_letoh64(x)        (x)
752 #   define my_htobe64(x)        _swab_64_(x)
753 #   define my_betoh64(x)        _swab_64_(x)
754 #  endif
755 #  define my_htoles(x)          (x)
756 #  define my_letohs(x)          (x)
757 #  define my_htolei(x)          (x)
758 #  define my_letohi(x)          (x)
759 #  define my_htolel(x)          (x)
760 #  define my_letohl(x)          (x)
761 #  if SHORTSIZE == 1
762 #   define my_htobes(x)         (x)
763 #   define my_betohs(x)         (x)
764 #  elif SHORTSIZE == 2
765 #   define my_htobes(x)         _swab_16_(x)
766 #   define my_betohs(x)         _swab_16_(x)
767 #  elif SHORTSIZE == 4
768 #   define my_htobes(x)         _swab_32_(x)
769 #   define my_betohs(x)         _swab_32_(x)
770 #  elif SHORTSIZE == 8
771 #   define my_htobes(x)         _swab_64_(x)
772 #   define my_betohs(x)         _swab_64_(x)
773 #  else
774 #   define PERL_NEED_MY_HTOBES
775 #   define PERL_NEED_MY_BETOHS
776 #  endif
777 #  if INTSIZE == 1
778 #   define my_htobei(x)         (x)
779 #   define my_betohi(x)         (x)
780 #  elif INTSIZE == 2
781 #   define my_htobei(x)         _swab_16_(x)
782 #   define my_betohi(x)         _swab_16_(x)
783 #  elif INTSIZE == 4
784 #   define my_htobei(x)         _swab_32_(x)
785 #   define my_betohi(x)         _swab_32_(x)
786 #  elif INTSIZE == 8
787 #   define my_htobei(x)         _swab_64_(x)
788 #   define my_betohi(x)         _swab_64_(x)
789 #  else
790 #   define PERL_NEED_MY_HTOBEI
791 #   define PERL_NEED_MY_BETOHI
792 #  endif
793 #  if LONGSIZE == 1
794 #   define my_htobel(x)         (x)
795 #   define my_betohl(x)         (x)
796 #  elif LONGSIZE == 2
797 #   define my_htobel(x)         _swab_16_(x)
798 #   define my_betohl(x)         _swab_16_(x)
799 #  elif LONGSIZE == 4
800 #   define my_htobel(x)         _swab_32_(x)
801 #   define my_betohl(x)         _swab_32_(x)
802 #  elif LONGSIZE == 8
803 #   define my_htobel(x)         _swab_64_(x)
804 #   define my_betohl(x)         _swab_64_(x)
805 #  else
806 #   define PERL_NEED_MY_HTOBEL
807 #   define PERL_NEED_MY_BETOHL
808 #  endif
809 #  define my_htolen(p,n)        NOOP
810 #  define my_letohn(p,n)        NOOP
811 #  define my_htoben(p,n)        my_swabn(p,n)
812 #  define my_betohn(p,n)        my_swabn(p,n)
813 /*----------------------------------------------------------------------------*/
814 # elif BYTEORDER == 0x4321 || BYTEORDER == 0x87654321  /*     big-endian      */
815 /*----------------------------------------------------------------------------*/
816 #  define my_htobe16(x)         (x)
817 #  define my_betoh16(x)         (x)
818 #  define my_htobe32(x)         (x)
819 #  define my_betoh32(x)         (x)
820 #  define my_htole16(x)         _swab_16_(x)
821 #  define my_letoh16(x)         _swab_16_(x)
822 #  define my_htole32(x)         _swab_32_(x)
823 #  define my_letoh32(x)         _swab_32_(x)
824 #  ifdef HAS_QUAD
825 #   define my_htobe64(x)        (x)
826 #   define my_betoh64(x)        (x)
827 #   define my_htole64(x)        _swab_64_(x)
828 #   define my_letoh64(x)        _swab_64_(x)
829 #  endif
830 #  define my_htobes(x)          (x)
831 #  define my_betohs(x)          (x)
832 #  define my_htobei(x)          (x)
833 #  define my_betohi(x)          (x)
834 #  define my_htobel(x)          (x)
835 #  define my_betohl(x)          (x)
836 #  if SHORTSIZE == 1
837 #   define my_htoles(x)         (x)
838 #   define my_letohs(x)         (x)
839 #  elif SHORTSIZE == 2
840 #   define my_htoles(x)         _swab_16_(x)
841 #   define my_letohs(x)         _swab_16_(x)
842 #  elif SHORTSIZE == 4
843 #   define my_htoles(x)         _swab_32_(x)
844 #   define my_letohs(x)         _swab_32_(x)
845 #  elif SHORTSIZE == 8
846 #   define my_htoles(x)         _swab_64_(x)
847 #   define my_letohs(x)         _swab_64_(x)
848 #  else
849 #   define PERL_NEED_MY_HTOLES
850 #   define PERL_NEED_MY_LETOHS
851 #  endif
852 #  if INTSIZE == 1
853 #   define my_htolei(x)         (x)
854 #   define my_letohi(x)         (x)
855 #  elif INTSIZE == 2
856 #   define my_htolei(x)         _swab_16_(x)
857 #   define my_letohi(x)         _swab_16_(x)
858 #  elif INTSIZE == 4
859 #   define my_htolei(x)         _swab_32_(x)
860 #   define my_letohi(x)         _swab_32_(x)
861 #  elif INTSIZE == 8
862 #   define my_htolei(x)         _swab_64_(x)
863 #   define my_letohi(x)         _swab_64_(x)
864 #  else
865 #   define PERL_NEED_MY_HTOLEI
866 #   define PERL_NEED_MY_LETOHI
867 #  endif
868 #  if LONGSIZE == 1
869 #   define my_htolel(x)         (x)
870 #   define my_letohl(x)         (x)
871 #  elif LONGSIZE == 2
872 #   define my_htolel(x)         _swab_16_(x)
873 #   define my_letohl(x)         _swab_16_(x)
874 #  elif LONGSIZE == 4
875 #   define my_htolel(x)         _swab_32_(x)
876 #   define my_letohl(x)         _swab_32_(x)
877 #  elif LONGSIZE == 8
878 #   define my_htolel(x)         _swab_64_(x)
879 #   define my_letohl(x)         _swab_64_(x)
880 #  else
881 #   define PERL_NEED_MY_HTOLEL
882 #   define PERL_NEED_MY_LETOHL
883 #  endif
884 #  define my_htolen(p,n)        my_swabn(p,n)
885 #  define my_letohn(p,n)        my_swabn(p,n)
886 #  define my_htoben(p,n)        NOOP
887 #  define my_betohn(p,n)        NOOP
888 /*----------------------------------------------------------------------------*/
889 # else /*                       all other byte-orders                         */
890 /*----------------------------------------------------------------------------*/
891 #  define PERL_NEED_MY_HTOLE16
892 #  define PERL_NEED_MY_LETOH16
893 #  define PERL_NEED_MY_HTOBE16
894 #  define PERL_NEED_MY_BETOH16
895 #  define PERL_NEED_MY_HTOLE32
896 #  define PERL_NEED_MY_LETOH32
897 #  define PERL_NEED_MY_HTOBE32
898 #  define PERL_NEED_MY_BETOH32
899 #  ifdef HAS_QUAD
900 #   define PERL_NEED_MY_HTOLE64
901 #   define PERL_NEED_MY_LETOH64
902 #   define PERL_NEED_MY_HTOBE64
903 #   define PERL_NEED_MY_BETOH64
904 #  endif
905 #  define PERL_NEED_MY_HTOLES
906 #  define PERL_NEED_MY_LETOHS
907 #  define PERL_NEED_MY_HTOBES
908 #  define PERL_NEED_MY_BETOHS
909 #  define PERL_NEED_MY_HTOLEI
910 #  define PERL_NEED_MY_LETOHI
911 #  define PERL_NEED_MY_HTOBEI
912 #  define PERL_NEED_MY_BETOHI
913 #  define PERL_NEED_MY_HTOLEL
914 #  define PERL_NEED_MY_LETOHL
915 #  define PERL_NEED_MY_HTOBEL
916 #  define PERL_NEED_MY_BETOHL
917 /*----------------------------------------------------------------------------*/
918 # endif /*                     end of byte-order macros                       */
919 /*----------------------------------------------------------------------------*/
920
921 /* The old value was hard coded at 1008. (4096-16) seems to be a bit faster,
922    at least on FreeBSD.  YMMV, so experiment.  */
923 #ifndef PERL_ARENA_SIZE
924 #define PERL_ARENA_SIZE 4080
925 #endif
926
927 /* Maximum level of recursion */
928 #ifndef PERL_SUB_DEPTH_WARN
929 #define PERL_SUB_DEPTH_WARN 100
930 #endif
931
932 #endif /* PERL_CORE */
933
934 /* We no longer default to creating a new SV for GvSV.
935    Do this before embed.  */
936 #ifndef PERL_CREATE_GVSV
937 #  ifndef PERL_DONT_CREATE_GVSV
938 #    define PERL_DONT_CREATE_GVSV
939 #  endif
940 #endif
941
942 #if !defined(HAS_WAITPID) && !defined(HAS_WAIT4) || defined(HAS_WAITPID_RUNTIME)
943 #define PERL_USES_PL_PIDSTATUS
944 #endif
945
946 #if !defined(OS2) && !defined(WIN32) && !defined(DJGPP) && !defined(EPOC) && !defined(__SYMBIAN32__)
947 #define PERL_DEFAULT_DO_EXEC3_IMPLEMENTATION
948 #endif
949
950 /* Cannot include embed.h here on Win32 as win32.h has not 
951    yet been included and defines some config variables e.g. HAVE_INTERP_INTERN
952  */
953 #if !defined(PERL_FOR_X2P) && !(defined(WIN32)||defined(VMS))
954 #  include "embed.h"
955 #  ifndef PERL_MAD
956 #    undef op_getmad
957 #    define op_getmad(arg,pegop,slot) NOOP
958 #  endif
959 #endif
960
961 #define MEM_SIZE Size_t
962
963 /* Round all values passed to malloc up, by default to a multiple of
964    sizeof(size_t)
965 */
966 #ifndef PERL_STRLEN_ROUNDUP_QUANTUM
967 #define PERL_STRLEN_ROUNDUP_QUANTUM Size_t_size
968 #endif
969
970 #if defined(STANDARD_C) && defined(I_STDDEF)
971 #   include <stddef.h>
972 #   define STRUCT_OFFSET(s,m)  offsetof(s,m)
973 #else
974 #   define STRUCT_OFFSET(s,m)  (Size_t)(&(((s *)0)->m))
975 #endif
976
977 #ifndef __SYMBIAN32__
978 #  if defined(I_STRING) || defined(__cplusplus)
979 #     include <string.h>
980 #  else
981 #     include <strings.h>
982 #  endif
983 #endif
984
985 /* This comes after <stdlib.h> so we don't try to change the standard
986  * library prototypes; we'll use our own in proto.h instead. */
987
988 #ifdef MYMALLOC
989 #  ifdef PERL_POLLUTE_MALLOC
990 #   ifndef PERL_EXTMALLOC_DEF
991 #    define Perl_malloc         malloc
992 #    define Perl_calloc         calloc
993 #    define Perl_realloc        realloc
994 #    define Perl_mfree          free
995 #   endif
996 #  else
997 #    define EMBEDMYMALLOC       /* for compatibility */
998 #  endif
999
1000 #  define safemalloc  Perl_malloc
1001 #  define safecalloc  Perl_calloc
1002 #  define saferealloc Perl_realloc
1003 #  define safefree    Perl_mfree
1004 #  define CHECK_MALLOC_TOO_LATE_FOR_(code)      STMT_START {            \
1005         if (!PL_tainting && MallocCfg_ptr[MallocCfg_cfg_env_read])      \
1006                 code;                                                   \
1007     } STMT_END
1008 #  define CHECK_MALLOC_TOO_LATE_FOR(ch)                         \
1009         CHECK_MALLOC_TOO_LATE_FOR_(MALLOC_TOO_LATE_FOR(ch))
1010 #  define panic_write2(s)               write(2, s, strlen(s))
1011 #  define CHECK_MALLOC_TAINT(newval)                            \
1012         CHECK_MALLOC_TOO_LATE_FOR_(                             \
1013                 if (newval) {                                   \
1014                   panic_write2("panic: tainting with $ENV{PERL_MALLOC_OPT}\n");\
1015                   exit(1); })
1016 #  define MALLOC_CHECK_TAINT(argc,argv,env)     STMT_START {    \
1017         if (doing_taint(argc,argv,env)) {                       \
1018                 MallocCfg_ptr[MallocCfg_skip_cfg_env] = 1;      \
1019     }} STMT_END;
1020 #else  /* MYMALLOC */
1021 #  define safemalloc  safesysmalloc
1022 #  define safecalloc  safesyscalloc
1023 #  define saferealloc safesysrealloc
1024 #  define safefree    safesysfree
1025 #  define CHECK_MALLOC_TOO_LATE_FOR(ch)         ((void)0)
1026 #  define CHECK_MALLOC_TAINT(newval)            ((void)0)
1027 #  define MALLOC_CHECK_TAINT(argc,argv,env)
1028 #endif /* MYMALLOC */
1029
1030 /* diag_listed_as: "-T" is on the #! line, it must also be used on the command line */
1031 #define TOO_LATE_FOR_(ch,what)  Perl_croak(aTHX_ "\"-%c\" is on the #! line, it must also be used on the command line%s", (char)(ch), what)
1032 #define TOO_LATE_FOR(ch)        TOO_LATE_FOR_(ch, "")
1033 #define MALLOC_TOO_LATE_FOR(ch) TOO_LATE_FOR_(ch, " with $ENV{PERL_MALLOC_OPT}")
1034 #define MALLOC_CHECK_TAINT2(argc,argv)  MALLOC_CHECK_TAINT(argc,argv,NULL)
1035
1036 #if !defined(HAS_STRCHR) && defined(HAS_INDEX) && !defined(strchr)
1037 #define strchr index
1038 #define strrchr rindex
1039 #endif
1040
1041 #ifdef I_MEMORY
1042 #  include <memory.h>
1043 #endif
1044
1045 #ifdef HAS_MEMCPY
1046 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
1047 #    ifndef memcpy
1048         extern char * memcpy (char*, char*, int);
1049 #    endif
1050 #  endif
1051 #else
1052 #   ifndef memcpy
1053 #       ifdef HAS_BCOPY
1054 #           define memcpy(d,s,l) bcopy(s,d,l)
1055 #       else
1056 #           define memcpy(d,s,l) my_bcopy(s,d,l)
1057 #       endif
1058 #   endif
1059 #endif /* HAS_MEMCPY */
1060
1061 #ifdef HAS_MEMSET
1062 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
1063 #    ifndef memset
1064         extern char *memset (char*, int, int);
1065 #    endif
1066 #  endif
1067 #else
1068 #  undef  memset
1069 #  define memset(d,c,l) my_memset(d,c,l)
1070 #endif /* HAS_MEMSET */
1071
1072 #if !defined(HAS_MEMMOVE) && !defined(memmove)
1073 #   if defined(HAS_BCOPY) && defined(HAS_SAFE_BCOPY)
1074 #       define memmove(d,s,l) bcopy(s,d,l)
1075 #   else
1076 #       if defined(HAS_MEMCPY) && defined(HAS_SAFE_MEMCPY)
1077 #           define memmove(d,s,l) memcpy(d,s,l)
1078 #       else
1079 #           define memmove(d,s,l) my_bcopy(s,d,l)
1080 #       endif
1081 #   endif
1082 #endif
1083
1084 #if defined(mips) && defined(ultrix) && !defined(__STDC__)
1085 #   undef HAS_MEMCMP
1086 #endif
1087
1088 #if defined(HAS_MEMCMP) && defined(HAS_SANE_MEMCMP)
1089 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
1090 #    ifndef memcmp
1091         extern int memcmp (char*, char*, int);
1092 #    endif
1093 #  endif
1094 #  ifdef BUGGY_MSC
1095 #    pragma function(memcmp)
1096 #  endif
1097 #else
1098 #   ifndef memcmp
1099 #       define memcmp   my_memcmp
1100 #   endif
1101 #endif /* HAS_MEMCMP && HAS_SANE_MEMCMP */
1102
1103 #ifndef memzero
1104 #   ifdef HAS_MEMSET
1105 #       define memzero(d,l) memset(d,0,l)
1106 #   else
1107 #       ifdef HAS_BZERO
1108 #           define memzero(d,l) bzero(d,l)
1109 #       else
1110 #           define memzero(d,l) my_bzero(d,l)
1111 #       endif
1112 #   endif
1113 #endif
1114
1115 #ifndef PERL_MICRO
1116 #ifndef memchr
1117 #   ifndef HAS_MEMCHR
1118 #       define memchr(s,c,n) ninstr((char*)(s), ((char*)(s)) + n, &(c), &(c) + 1)
1119 #   endif
1120 #endif
1121 #endif
1122
1123 #ifndef HAS_BCMP
1124 #   ifndef bcmp
1125 #       define bcmp(s1,s2,l) memcmp(s1,s2,l)
1126 #   endif
1127 #endif /* !HAS_BCMP */
1128
1129 #ifdef I_NETINET_IN
1130 #   include <netinet/in.h>
1131 #endif
1132
1133 #ifdef I_ARPA_INET
1134 #   include <arpa/inet.h>
1135 #endif
1136
1137 #if defined(SF_APPEND) && defined(USE_SFIO) && defined(I_SFIO)
1138 /* <sfio.h> defines SF_APPEND and <sys/stat.h> might define SF_APPEND
1139  * (the neo-BSD seem to do this).  */
1140 #   undef SF_APPEND
1141 #endif
1142
1143 #ifdef I_SYS_STAT
1144 #   include <sys/stat.h>
1145 #endif
1146
1147 /* Microsoft VC's sys/stat.h defines all S_Ixxx macros except S_IFIFO.
1148    This definition should ideally go into win32/win32.h, but S_IFIFO is
1149    used later here in perl.h before win32/win32.h is being included. */
1150 #if !defined(S_IFIFO) && defined(_S_IFIFO)
1151 #   define S_IFIFO _S_IFIFO
1152 #endif
1153
1154 /* The stat macros for Amdahl UTS, Unisoft System V/88 (and derivatives
1155    like UTekV) are broken, sometimes giving false positives.  Undefine
1156    them here and let the code below set them to proper values.
1157
1158    The ghs macro stands for GreenHills Software C-1.8.5 which
1159    is the C compiler for sysV88 and the various derivatives.
1160    This header file bug is corrected in gcc-2.5.8 and later versions.
1161    --Kaveh Ghazi (ghazi@noc.rutgers.edu) 10/3/94.  */
1162
1163 #if defined(uts) || (defined(m88k) && defined(ghs))
1164 #   undef S_ISDIR
1165 #   undef S_ISCHR
1166 #   undef S_ISBLK
1167 #   undef S_ISREG
1168 #   undef S_ISFIFO
1169 #   undef S_ISLNK
1170 #endif
1171
1172 #ifdef I_TIME
1173 #   include <time.h>
1174 #endif
1175
1176 #ifdef I_SYS_TIME
1177 #   ifdef I_SYS_TIME_KERNEL
1178 #       define KERNEL
1179 #   endif
1180 #   include <sys/time.h>
1181 #   ifdef I_SYS_TIME_KERNEL
1182 #       undef KERNEL
1183 #   endif
1184 #endif
1185
1186 #if defined(HAS_TIMES) && defined(I_SYS_TIMES)
1187 #    include <sys/times.h>
1188 #endif
1189
1190 #if defined(HAS_STRERROR) && (!defined(HAS_MKDIR) || !defined(HAS_RMDIR))
1191 #   undef HAS_STRERROR
1192 #endif
1193
1194 #include <errno.h>
1195
1196 #if defined(WIN32) && defined(PERL_IMPLICIT_SYS)
1197 #  define WIN32SCK_IS_STDSCK            /* don't pull in custom wsock layer */
1198 #endif
1199
1200 /* In Tru64 use the 4.4BSD struct msghdr, not the 4.3 one.
1201  * This is important for using IPv6. 
1202  * For OSF/1 3.2, however, defining _SOCKADDR_LEN would be
1203  * a bad idea since it breaks send() and recv(). */
1204 #if defined(__osf__) && defined(__alpha) && !defined(_SOCKADDR_LEN) && !defined(DEC_OSF1_3_X)
1205 #   define _SOCKADDR_LEN
1206 #endif
1207
1208 #if defined(HAS_SOCKET) && !defined(VMS) && !defined(WIN32) /* VMS/WIN32 handle sockets via vmsish.h/win32.h */
1209 # include <sys/socket.h>
1210 # if defined(USE_SOCKS) && defined(I_SOCKS)
1211 #   if !defined(INCLUDE_PROTOTYPES)
1212 #       define INCLUDE_PROTOTYPES /* for <socks.h> */
1213 #       define PERL_SOCKS_NEED_PROTOTYPES
1214 #   endif
1215 #   include <socks.h>
1216 #   ifdef PERL_SOCKS_NEED_PROTOTYPES /* keep cpp space clean */
1217 #       undef INCLUDE_PROTOTYPES
1218 #       undef PERL_SOCKS_NEED_PROTOTYPES
1219 #   endif
1220 # endif
1221 # ifdef I_NETDB
1222 #  ifdef NETWARE
1223 #   include<stdio.h>
1224 #  endif
1225 #  include <netdb.h>
1226 # endif
1227 # ifndef ENOTSOCK
1228 #  ifdef I_NET_ERRNO
1229 #   include <net/errno.h>
1230 #  endif
1231 # endif
1232 #endif
1233
1234 /* sockatmark() is so new (2001) that many places might have it hidden
1235  * behind some -D_BLAH_BLAH_SOURCE guard.  The __THROW magic is required
1236  * e.g. in Gentoo, see http://bugs.gentoo.org/show_bug.cgi?id=12605 */
1237 #if defined(HAS_SOCKATMARK) && !defined(HAS_SOCKATMARK_PROTO)
1238 # if defined(__THROW) && defined(__GLIBC__)
1239 int sockatmark(int) __THROW;
1240 # else
1241 int sockatmark(int);
1242 # endif
1243 #endif
1244
1245 #if defined(__osf__) && defined(__cplusplus) && !defined(_XOPEN_SOURCE_EXTENDED) /* Tru64 "cxx" (C++), see hints/dec_osf.sh for why the _XOPEN_SOURCE_EXTENDED cannot be defined. */
1246 EXTERN_C int fchdir(int);
1247 EXTERN_C int flock(int, int);
1248 EXTERN_C int fseeko(FILE *, off_t, int);
1249 EXTERN_C off_t ftello(FILE *);
1250 #endif
1251
1252 #if defined(__SUNPRO_CC) /* SUNWspro CC (C++) */
1253 EXTERN_C char *crypt(const char *, const char *);
1254 EXTERN_C char **environ;
1255 #endif
1256
1257 #if defined(__cplusplus)
1258 #  if defined(__OpenBSD__) || defined(__FreeBSD__) || defined(__NetBSD__)
1259 EXTERN_C char **environ;
1260 #  elif defined(__CYGWIN__)
1261 EXTERN_C char *crypt(const char *, const char *);
1262 #endif
1263 #endif
1264
1265 #ifdef SETERRNO
1266 # undef SETERRNO  /* SOCKS might have defined this */
1267 #endif
1268
1269 #ifdef VMS
1270 #   define SETERRNO(errcode,vmserrcode) \
1271         STMT_START {                    \
1272             set_errno(errcode);         \
1273             set_vaxc_errno(vmserrcode); \
1274         } STMT_END
1275 #   define dSAVEDERRNO    int saved_errno; unsigned saved_vms_errno
1276 #   define dSAVE_ERRNO    int saved_errno = errno; unsigned saved_vms_errno = vaxc$errno
1277 #   define SAVE_ERRNO     ( saved_errno = errno, saved_vms_errno = vaxc$errno )
1278 #   define RESTORE_ERRNO  SETERRNO(saved_errno, saved_vms_errno)
1279
1280 #   define LIB_INVARG           LIB$_INVARG
1281 #   define RMS_DIR              RMS$_DIR
1282 #   define RMS_FAC              RMS$_FAC
1283 #   define RMS_FEX              RMS$_FEX
1284 #   define RMS_FNF              RMS$_FNF
1285 #   define RMS_IFI              RMS$_IFI
1286 #   define RMS_ISI              RMS$_ISI
1287 #   define RMS_PRV              RMS$_PRV
1288 #   define SS_ACCVIO            SS$_ACCVIO
1289 #   define SS_DEVOFFLINE        SS$_DEVOFFLINE
1290 #   define SS_IVCHAN            SS$_IVCHAN
1291 #   define SS_NORMAL            SS$_NORMAL
1292 #else
1293 #   define SETERRNO(errcode,vmserrcode) (errno = (errcode))
1294 #   define dSAVEDERRNO    int saved_errno
1295 #   define dSAVE_ERRNO    int saved_errno = errno
1296 #   define SAVE_ERRNO     (saved_errno = errno)
1297 #   define RESTORE_ERRNO  (errno = saved_errno)
1298
1299 #   define LIB_INVARG           0
1300 #   define RMS_DIR              0
1301 #   define RMS_FAC              0
1302 #   define RMS_FEX              0
1303 #   define RMS_FNF              0
1304 #   define RMS_IFI              0
1305 #   define RMS_ISI              0
1306 #   define RMS_PRV              0
1307 #   define SS_ACCVIO            0
1308 #   define SS_DEVOFFLINE        0
1309 #   define SS_IVCHAN            0
1310 #   define SS_NORMAL            0
1311 #endif
1312
1313 #define ERRSV GvSV(PL_errgv)
1314 #ifdef PERL_CORE
1315 # define DEFSV (0 + GvSVn(PL_defgv))
1316 #else
1317 # define DEFSV GvSVn(PL_defgv)
1318 #endif
1319 #define DEFSV_set(sv) (GvSV(PL_defgv) = (sv))
1320 #define SAVE_DEFSV SAVESPTR(GvSV(PL_defgv))
1321
1322 #define ERRHV GvHV(PL_errgv)    /* XXX unused, here for compatibility */
1323
1324 #ifndef errno
1325         extern int errno;     /* ANSI allows errno to be an lvalue expr.
1326                                * For example in multithreaded environments
1327                                * something like this might happen:
1328                                * extern int *_errno(void);
1329                                * #define errno (*_errno()) */
1330 #endif
1331
1332 #ifdef HAS_STRERROR
1333 #       ifdef VMS
1334         char *strerror (int,...);
1335 #       else
1336 #ifndef DONT_DECLARE_STD
1337         char *strerror (int);
1338 #endif
1339 #       endif
1340 #       ifndef Strerror
1341 #           define Strerror strerror
1342 #       endif
1343 #else
1344 #    ifdef HAS_SYS_ERRLIST
1345         extern int sys_nerr;
1346         extern char *sys_errlist[];
1347 #       ifndef Strerror
1348 #           define Strerror(e) \
1349                 ((e) < 0 || (e) >= sys_nerr ? "(unknown)" : sys_errlist[e])
1350 #       endif
1351 #   endif
1352 #endif
1353
1354 #ifdef I_SYS_IOCTL
1355 #   ifndef _IOCTL_
1356 #       include <sys/ioctl.h>
1357 #   endif
1358 #endif
1359
1360 #if defined(mc300) || defined(mc500) || defined(mc700) || defined(mc6000)
1361 #   ifdef HAS_SOCKETPAIR
1362 #       undef HAS_SOCKETPAIR
1363 #   endif
1364 #   ifdef I_NDBM
1365 #       undef I_NDBM
1366 #   endif
1367 #endif
1368
1369 #ifndef HAS_SOCKETPAIR
1370 #   ifdef HAS_SOCKET
1371 #       define socketpair Perl_my_socketpair
1372 #   endif
1373 #endif
1374
1375 #if INTSIZE == 2
1376 #   define htoni htons
1377 #   define ntohi ntohs
1378 #else
1379 #   define htoni htonl
1380 #   define ntohi ntohl
1381 #endif
1382
1383 /* Configure already sets Direntry_t */
1384 #if defined(I_DIRENT)
1385 #   include <dirent.h>
1386     /* NeXT needs dirent + sys/dir.h */
1387 #   if  defined(I_SYS_DIR) && (defined(NeXT) || defined(__NeXT__))
1388 #       include <sys/dir.h>
1389 #   endif
1390 #else
1391 #   ifdef I_SYS_NDIR
1392 #       include <sys/ndir.h>
1393 #   else
1394 #       ifdef I_SYS_DIR
1395 #           ifdef hp9000s500
1396 #               include <ndir.h>        /* may be wrong in the future */
1397 #           else
1398 #               include <sys/dir.h>
1399 #           endif
1400 #       endif
1401 #   endif
1402 #endif
1403
1404 #ifdef PERL_MICRO
1405 #   ifndef DIR
1406 #      define DIR void
1407 #   endif
1408 #endif
1409
1410 #ifdef FPUTS_BOTCH
1411 /* work around botch in SunOS 4.0.1 and 4.0.2 */
1412 #   ifndef fputs
1413 #       define fputs(sv,fp) fprintf(fp,"%s",sv)
1414 #   endif
1415 #endif
1416
1417 /*
1418  * The following gobbledygook brought to you on behalf of __STDC__.
1419  * (I could just use #ifndef __STDC__, but this is more bulletproof
1420  * in the face of half-implementations.)
1421  */
1422
1423 #if defined(I_SYSMODE) && !defined(PERL_MICRO)
1424 #include <sys/mode.h>
1425 #endif
1426
1427 #ifndef S_IFMT
1428 #   ifdef _S_IFMT
1429 #       define S_IFMT _S_IFMT
1430 #   else
1431 #       define S_IFMT 0170000
1432 #   endif
1433 #endif
1434
1435 #ifndef S_ISDIR
1436 #   define S_ISDIR(m) ((m & S_IFMT) == S_IFDIR)
1437 #endif
1438
1439 #ifndef S_ISCHR
1440 #   define S_ISCHR(m) ((m & S_IFMT) == S_IFCHR)
1441 #endif
1442
1443 #ifndef S_ISBLK
1444 #   ifdef S_IFBLK
1445 #       define S_ISBLK(m) ((m & S_IFMT) == S_IFBLK)
1446 #   else
1447 #       define S_ISBLK(m) (0)
1448 #   endif
1449 #endif
1450
1451 #ifndef S_ISREG
1452 #   define S_ISREG(m) ((m & S_IFMT) == S_IFREG)
1453 #endif
1454
1455 #ifndef S_ISFIFO
1456 #   ifdef S_IFIFO
1457 #       define S_ISFIFO(m) ((m & S_IFMT) == S_IFIFO)
1458 #   else
1459 #       define S_ISFIFO(m) (0)
1460 #   endif
1461 #endif
1462
1463 #ifndef S_ISLNK
1464 #   ifdef _S_ISLNK
1465 #       define S_ISLNK(m) _S_ISLNK(m)
1466 #   else
1467 #       ifdef _S_IFLNK
1468 #           define S_ISLNK(m) ((m & S_IFMT) == _S_IFLNK)
1469 #       else
1470 #           ifdef S_IFLNK
1471 #               define S_ISLNK(m) ((m & S_IFMT) == S_IFLNK)
1472 #           else
1473 #               define S_ISLNK(m) (0)
1474 #           endif
1475 #       endif
1476 #   endif
1477 #endif
1478
1479 #ifndef S_ISSOCK
1480 #   ifdef _S_ISSOCK
1481 #       define S_ISSOCK(m) _S_ISSOCK(m)
1482 #   else
1483 #       ifdef _S_IFSOCK
1484 #           define S_ISSOCK(m) ((m & S_IFMT) == _S_IFSOCK)
1485 #       else
1486 #           ifdef S_IFSOCK
1487 #               define S_ISSOCK(m) ((m & S_IFMT) == S_IFSOCK)
1488 #           else
1489 #               define S_ISSOCK(m) (0)
1490 #           endif
1491 #       endif
1492 #   endif
1493 #endif
1494
1495 #ifndef S_IRUSR
1496 #   ifdef S_IREAD
1497 #       define S_IRUSR S_IREAD
1498 #       define S_IWUSR S_IWRITE
1499 #       define S_IXUSR S_IEXEC
1500 #   else
1501 #       define S_IRUSR 0400
1502 #       define S_IWUSR 0200
1503 #       define S_IXUSR 0100
1504 #   endif
1505 #endif
1506
1507 #ifndef S_IRGRP
1508 #   ifdef S_IRUSR
1509 #       define S_IRGRP (S_IRUSR>>3)
1510 #       define S_IWGRP (S_IWUSR>>3)
1511 #       define S_IXGRP (S_IXUSR>>3)
1512 #   else
1513 #       define S_IRGRP 0040
1514 #       define S_IWGRP 0020
1515 #       define S_IXGRP 0010
1516 #   endif
1517 #endif
1518
1519 #ifndef S_IROTH
1520 #   ifdef S_IRUSR
1521 #       define S_IROTH (S_IRUSR>>6)
1522 #       define S_IWOTH (S_IWUSR>>6)
1523 #       define S_IXOTH (S_IXUSR>>6)
1524 #   else
1525 #       define S_IROTH 0040
1526 #       define S_IWOTH 0020
1527 #       define S_IXOTH 0010
1528 #   endif
1529 #endif
1530
1531 #ifndef S_ISUID
1532 #   define S_ISUID 04000
1533 #endif
1534
1535 #ifndef S_ISGID
1536 #   define S_ISGID 02000
1537 #endif
1538
1539 #ifndef S_IRWXU
1540 #   define S_IRWXU (S_IRUSR|S_IWUSR|S_IXUSR)
1541 #endif
1542
1543 #ifndef S_IRWXG
1544 #   define S_IRWXG (S_IRGRP|S_IWGRP|S_IXGRP)
1545 #endif
1546
1547 #ifndef S_IRWXO
1548 #   define S_IRWXO (S_IROTH|S_IWOTH|S_IXOTH)
1549 #endif
1550
1551 /* BeOS 5.0 and Haiku R1 seem to define S_IREAD and S_IWRITE in <posix/fcntl.h>
1552  * which would get included through <sys/file.h >, but that is 3000
1553  * lines in the future.  --jhi */
1554
1555 #if !defined(S_IREAD) && !(defined(__BEOS__) || defined(__HAIKU__))
1556 #   define S_IREAD S_IRUSR
1557 #endif
1558
1559 #if !defined(S_IWRITE) && !(defined(__BEOS__) || defined(__HAIKU__))
1560 #   define S_IWRITE S_IWUSR
1561 #endif
1562
1563 #ifndef S_IEXEC
1564 #   define S_IEXEC S_IXUSR
1565 #endif
1566
1567 #ifdef ff_next
1568 #   undef ff_next
1569 #endif
1570
1571 #if defined(cray) || defined(gould) || defined(i860) || defined(pyr)
1572 #   define SLOPPYDIVIDE
1573 #endif
1574
1575 #ifdef UV
1576 #undef UV
1577 #endif
1578
1579 #ifdef  SPRINTF_E_BUG
1580 #  define sprintf UTS_sprintf_wrap
1581 #endif
1582
1583 /* For the times when you want the return value of sprintf, and you want it
1584    to be the length. Can't have a thread variable passed in, because C89 has
1585    no varargs macros.
1586 */
1587 #ifdef SPRINTF_RETURNS_STRLEN
1588 #  define my_sprintf sprintf
1589 #else
1590 #  define my_sprintf Perl_my_sprintf
1591 #endif
1592
1593 /*
1594  * If we have v?snprintf() and the C99 variadic macros, we can just
1595  * use just the v?snprintf().  It is nice to try to trap the buffer
1596  * overflow, however, so if we are DEBUGGING, and we cannot use the
1597  * gcc statement expressions, then use the function wrappers which try
1598  * to trap the overflow.  If we can use the gcc statement expressions,
1599  * we can try that even with the version that uses the C99 variadic
1600  * macros.
1601  */
1602
1603 /* Note that we do not check against snprintf()/vsnprintf() returning
1604  * negative values because that is non-standard behaviour and we use
1605  * snprintf/vsnprintf only iff HAS_VSNPRINTF has been defined, and
1606  * that should be true only if the snprintf()/vsnprintf() are true
1607  * to the standard. */
1608
1609 #if defined(HAS_SNPRINTF) && defined(HAS_C99_VARIADIC_MACROS) && !(defined(DEBUGGING) && !defined(PERL_USE_GCC_BRACE_GROUPS)) && !defined(PERL_GCC_PEDANTIC)
1610 #  ifdef PERL_USE_GCC_BRACE_GROUPS
1611 #      define my_snprintf(buffer, len, ...) ({ int __len__ = snprintf(buffer, len, __VA_ARGS__); if ((len) > 0 && (Size_t)__len__ >= (len)) Perl_croak_nocontext("panic: snprintf buffer overflow"); __len__; })
1612 #      define PERL_MY_SNPRINTF_GUARDED
1613 #  else
1614 #    define my_snprintf(buffer, len, ...) snprintf(buffer, len, __VA_ARGS__)
1615 #  endif
1616 #else
1617 #  define my_snprintf  Perl_my_snprintf
1618 #  define PERL_MY_SNPRINTF_GUARDED
1619 #endif
1620
1621 #if defined(HAS_VSNPRINTF) && defined(HAS_C99_VARIADIC_MACROS) && !(defined(DEBUGGING) && !defined(PERL_USE_GCC_BRACE_GROUPS)) && !defined(PERL_GCC_PEDANTIC)
1622 #  ifdef PERL_USE_GCC_BRACE_GROUPS
1623 #      define my_vsnprintf(buffer, len, ...) ({ int __len__ = vsnprintf(buffer, len, __VA_ARGS__); if ((len) > 0 && (Size_t)__len__ >= (len)) Perl_croak_nocontext("panic: vsnprintf buffer overflow"); __len__; })
1624 #      define PERL_MY_VSNPRINTF_GUARDED
1625 #  else
1626 #    define my_vsnprintf(buffer, len, ...) vsnprintf(buffer, len, __VA_ARGS__)
1627 #  endif
1628 #else
1629 #  define my_vsnprintf Perl_my_vsnprintf
1630 #  define PERL_MY_VSNPRINTF_GUARDED
1631 #endif
1632
1633 #ifdef HAS_STRLCAT
1634 #  define my_strlcat    strlcat
1635 #else
1636 #  define my_strlcat    Perl_my_strlcat
1637 #endif
1638
1639 #ifdef HAS_STRLCPY
1640 #  define my_strlcpy    strlcpy
1641 #else
1642 #  define my_strlcpy    Perl_my_strlcpy
1643 #endif
1644
1645 /* Configure gets this right but the UTS compiler gets it wrong.
1646    -- Hal Morris <hom00@utsglobal.com> */
1647 #ifdef UTS
1648 #  undef  UVTYPE
1649 #  define UVTYPE unsigned
1650 #endif
1651
1652 /*
1653     The IV type is supposed to be long enough to hold any integral
1654     value or a pointer.
1655     --Andy Dougherty    August 1996
1656 */
1657
1658 typedef IVTYPE IV;
1659 typedef UVTYPE UV;
1660
1661 #if defined(USE_64_BIT_INT) && defined(HAS_QUAD)
1662 #  if QUADKIND == QUAD_IS_INT64_T && defined(INT64_MAX)
1663 #    define IV_MAX INT64_MAX
1664 #    define IV_MIN INT64_MIN
1665 #    define UV_MAX UINT64_MAX
1666 #    ifndef UINT64_MIN
1667 #      define UINT64_MIN 0
1668 #    endif
1669 #    define UV_MIN UINT64_MIN
1670 #  else
1671 #    define IV_MAX PERL_QUAD_MAX
1672 #    define IV_MIN PERL_QUAD_MIN
1673 #    define UV_MAX PERL_UQUAD_MAX
1674 #    define UV_MIN PERL_UQUAD_MIN
1675 #  endif
1676 #  define IV_IS_QUAD
1677 #  define UV_IS_QUAD
1678 #else
1679 #  if defined(INT32_MAX) && IVSIZE == 4
1680 #    define IV_MAX INT32_MAX
1681 #    define IV_MIN INT32_MIN
1682 #    ifndef UINT32_MAX_BROKEN /* e.g. HP-UX with gcc messes this up */
1683 #        define UV_MAX UINT32_MAX
1684 #    else
1685 #        define UV_MAX 4294967295U
1686 #    endif
1687 #    ifndef UINT32_MIN
1688 #      define UINT32_MIN 0
1689 #    endif
1690 #    define UV_MIN UINT32_MIN
1691 #  else
1692 #    define IV_MAX PERL_LONG_MAX
1693 #    define IV_MIN PERL_LONG_MIN
1694 #    define UV_MAX PERL_ULONG_MAX
1695 #    define UV_MIN PERL_ULONG_MIN
1696 #  endif
1697 #  if IVSIZE == 8
1698 #    define IV_IS_QUAD
1699 #    define UV_IS_QUAD
1700 #    ifndef HAS_QUAD
1701 #      define HAS_QUAD
1702 #    endif
1703 #  else
1704 #    undef IV_IS_QUAD
1705 #    undef UV_IS_QUAD
1706 #    undef HAS_QUAD
1707 #  endif
1708 #endif
1709
1710 #ifndef HAS_QUAD
1711 # undef PERL_NEED_MY_HTOLE64
1712 # undef PERL_NEED_MY_LETOH64
1713 # undef PERL_NEED_MY_HTOBE64
1714 # undef PERL_NEED_MY_BETOH64
1715 #endif
1716
1717 #if defined(uts) || defined(UTS)
1718 #       undef UV_MAX
1719 #       define UV_MAX (4294967295u)
1720 #endif
1721
1722 #define IV_DIG (BIT_DIGITS(IVSIZE * 8))
1723 #define UV_DIG (BIT_DIGITS(UVSIZE * 8))
1724
1725 #ifndef NO_PERL_PRESERVE_IVUV
1726 #define PERL_PRESERVE_IVUV      /* We like our integers to stay integers. */
1727 #endif
1728
1729 /*
1730  *  The macros INT2PTR and NUM2PTR are (despite their names)
1731  *  bi-directional: they will convert int/float to or from pointers.
1732  *  However the conversion to int/float are named explicitly:
1733  *  PTR2IV, PTR2UV, PTR2NV.
1734  *
1735  *  For int conversions we do not need two casts if pointers are
1736  *  the same size as IV and UV.   Otherwise we need an explicit
1737  *  cast (PTRV) to avoid compiler warnings.
1738  */
1739 #if (IVSIZE == PTRSIZE) && (UVSIZE == PTRSIZE)
1740 #  define PTRV                  UV
1741 #  define INT2PTR(any,d)        (any)(d)
1742 #else
1743 #  if PTRSIZE == LONGSIZE
1744 #    define PTRV                unsigned long
1745 #    define PTR2ul(p)           (unsigned long)(p)
1746 #  else
1747 #    define PTRV                unsigned
1748 #  endif
1749 #endif
1750
1751 #ifndef INT2PTR
1752 #  define INT2PTR(any,d)        (any)(PTRV)(d)
1753 #endif
1754
1755 #ifndef PTR2ul
1756 #  define PTR2ul(p)     INT2PTR(unsigned long,p)        
1757 #endif
1758
1759 #define NUM2PTR(any,d)  (any)(PTRV)(d)
1760 #define PTR2IV(p)       INT2PTR(IV,p)
1761 #define PTR2UV(p)       INT2PTR(UV,p)
1762 #define PTR2NV(p)       NUM2PTR(NV,p)
1763 #define PTR2nat(p)      (PTRV)(p)       /* pointer to integer of PTRSIZE */
1764
1765 /* According to strict ANSI C89 one cannot freely cast between
1766  * data pointers and function (code) pointers.  There are at least
1767  * two ways around this.  One (used below) is to do two casts,
1768  * first the other pointer to an (unsigned) integer, and then
1769  * the integer to the other pointer.  The other way would be
1770  * to use unions to "overlay" the pointers.  For an example of
1771  * the latter technique, see union dirpu in struct xpvio in sv.h.
1772  * The only feasible use is probably temporarily storing
1773  * function pointers in a data pointer (such as a void pointer). */
1774
1775 #define DPTR2FPTR(t,p) ((t)PTR2nat(p))  /* data pointer to function pointer */
1776 #define FPTR2DPTR(t,p) ((t)PTR2nat(p))  /* function pointer to data pointer */
1777
1778 #ifdef USE_LONG_DOUBLE
1779 #  if defined(HAS_LONG_DOUBLE) && LONG_DOUBLESIZE == DOUBLESIZE
1780 #      define LONG_DOUBLE_EQUALS_DOUBLE
1781 #  endif
1782 #  if !(defined(HAS_LONG_DOUBLE) && (LONG_DOUBLESIZE > DOUBLESIZE))
1783 #     undef USE_LONG_DOUBLE /* Ouch! */
1784 #  endif
1785 #endif
1786
1787 #ifdef OVR_DBL_DIG
1788 /* Use an overridden DBL_DIG */
1789 # ifdef DBL_DIG
1790 #  undef DBL_DIG
1791 # endif
1792 # define DBL_DIG OVR_DBL_DIG
1793 #else
1794 /* The following is all to get DBL_DIG, in order to pick a nice
1795    default value for printing floating point numbers in Gconvert
1796    (see config.h). (It also has other uses, such as figuring out if
1797    a given precision of printing can be done with a double instead of
1798    a long double - Allen).
1799 */
1800 #ifdef I_LIMITS
1801 #include <limits.h>
1802 #endif
1803 #ifdef I_FLOAT
1804 #include <float.h>
1805 #endif
1806 #ifndef HAS_DBL_DIG
1807 #define DBL_DIG 15   /* A guess that works lots of places */
1808 #endif
1809 #endif
1810
1811 #ifdef OVR_LDBL_DIG
1812 /* Use an overridden LDBL_DIG */
1813 # ifdef LDBL_DIG
1814 #  undef LDBL_DIG
1815 # endif
1816 # define LDBL_DIG OVR_LDBL_DIG
1817 #else
1818 /* The following is all to get LDBL_DIG, in order to pick a nice
1819    default value for printing floating point numbers in Gconvert.
1820    (see config.h)
1821 */
1822 # ifdef I_LIMITS
1823 #   include <limits.h>
1824 # endif
1825 # ifdef I_FLOAT
1826 #  include <float.h>
1827 # endif
1828 # ifndef HAS_LDBL_DIG
1829 #  if LONG_DOUBLESIZE == 10
1830 #   define LDBL_DIG 18 /* assume IEEE */
1831 #  else
1832 #   if LONG_DOUBLESIZE == 12
1833 #    define LDBL_DIG 18 /* gcc? */
1834 #   else
1835 #    if LONG_DOUBLESIZE == 16
1836 #     define LDBL_DIG 33 /* assume IEEE */
1837 #    else
1838 #     if LONG_DOUBLESIZE == DOUBLESIZE
1839 #      define LDBL_DIG DBL_DIG /* bummer */
1840 #     endif
1841 #    endif
1842 #   endif
1843 #  endif
1844 # endif
1845 #endif
1846
1847 /*
1848  * This is for making sure we have a good DBL_MAX value, if possible,
1849  * either for usage as NV_MAX or for usage in figuring out if we can
1850  * fit a given long double into a double, if bug-fixing makes it
1851  * necessary to do so. - Allen <allens@cpan.org>
1852  */
1853
1854 #ifdef I_LIMITS
1855 #  include <limits.h>
1856 #endif
1857
1858 #ifdef I_VALUES
1859 #  if !(defined(DBL_MIN) && defined(DBL_MAX) && defined(I_LIMITS))
1860 #    include <values.h>
1861 #    if defined(MAXDOUBLE) && !defined(DBL_MAX)
1862 #      define DBL_MAX MAXDOUBLE
1863 #    endif
1864 #    if defined(MINDOUBLE) && !defined(DBL_MIN)
1865 #      define DBL_MIN MINDOUBLE
1866 #    endif
1867 #  endif
1868 #endif /* defined(I_VALUES) */
1869
1870 typedef NVTYPE NV;
1871
1872 #ifdef I_IEEEFP
1873 #   include <ieeefp.h>
1874 #endif
1875
1876 #ifdef USE_LONG_DOUBLE
1877 #   ifdef I_SUNMATH
1878 #       include <sunmath.h>
1879 #   endif
1880 #   define NV_DIG LDBL_DIG
1881 #   ifdef LDBL_MANT_DIG
1882 #       define NV_MANT_DIG LDBL_MANT_DIG
1883 #   endif
1884 #   ifdef LDBL_MIN
1885 #       define NV_MIN LDBL_MIN
1886 #   endif
1887 #   ifdef LDBL_MAX
1888 #       define NV_MAX LDBL_MAX
1889 #   endif
1890 #   ifdef LDBL_MIN_10_EXP
1891 #       define NV_MIN_10_EXP LDBL_MIN_10_EXP
1892 #   endif
1893 #   ifdef LDBL_MAX_10_EXP
1894 #       define NV_MAX_10_EXP LDBL_MAX_10_EXP
1895 #   endif
1896 #   ifdef LDBL_EPSILON
1897 #       define NV_EPSILON LDBL_EPSILON
1898 #   endif
1899 #   ifdef LDBL_MAX
1900 #       define NV_MAX LDBL_MAX
1901 /* Having LDBL_MAX doesn't necessarily mean that we have LDBL_MIN... -Allen */
1902 #   else
1903 #       ifdef HUGE_VALL
1904 #           define NV_MAX HUGE_VALL
1905 #       else
1906 #           ifdef HUGE_VAL
1907 #               define NV_MAX ((NV)HUGE_VAL)
1908 #           endif
1909 #       endif
1910 #   endif
1911 #   ifdef HAS_SQRTL
1912 #       define Perl_cos cosl
1913 #       define Perl_sin sinl
1914 #       define Perl_sqrt sqrtl
1915 #       define Perl_exp expl
1916 #       define Perl_log logl
1917 #       define Perl_atan2 atan2l
1918 #       define Perl_pow powl
1919 #       define Perl_floor floorl
1920 #       define Perl_ceil ceill
1921 #       define Perl_fmod fmodl
1922 #   endif
1923 /* e.g. libsunmath doesn't have modfl and frexpl as of mid-March 2000 */
1924 #   ifdef HAS_MODFL
1925 #       define Perl_modf(x,y) modfl(x,y)
1926 /* eg glibc 2.2 series seems to provide modfl on ppc and arm, but has no
1927    prototype in <math.h> */
1928 #       ifndef HAS_MODFL_PROTO
1929 EXTERN_C long double modfl(long double, long double *);
1930 #       endif
1931 #   else
1932 #       if defined(HAS_AINTL) && defined(HAS_COPYSIGNL)
1933         extern long double Perl_my_modfl(long double x, long double *ip);
1934 #           define Perl_modf(x,y) Perl_my_modfl(x,y)
1935 #       endif
1936 #   endif
1937 #   ifdef HAS_FREXPL
1938 #       define Perl_frexp(x,y) frexpl(x,y)
1939 #   else
1940 #       if defined(HAS_ILOGBL) && defined(HAS_SCALBNL)
1941         extern long double Perl_my_frexpl(long double x, int *e);
1942 #           define Perl_frexp(x,y) Perl_my_frexpl(x,y)
1943 #       endif
1944 #   endif
1945 #   ifndef Perl_isnan
1946 #       ifdef HAS_ISNANL
1947 #           define Perl_isnan(x) isnanl(x)
1948 #       endif
1949 #   endif
1950 #   ifndef Perl_isinf
1951 #       ifdef HAS_FINITEL
1952 #           define Perl_isinf(x) !(finitel(x)||Perl_isnan(x))
1953 #       endif
1954 #   endif
1955 #else
1956 #   define NV_DIG DBL_DIG
1957 #   ifdef DBL_MANT_DIG
1958 #       define NV_MANT_DIG DBL_MANT_DIG
1959 #   endif
1960 #   ifdef DBL_MIN
1961 #       define NV_MIN DBL_MIN
1962 #   endif
1963 #   ifdef DBL_MAX
1964 #       define NV_MAX DBL_MAX
1965 #   endif
1966 #   ifdef DBL_MIN_10_EXP
1967 #       define NV_MIN_10_EXP DBL_MIN_10_EXP
1968 #   endif
1969 #   ifdef DBL_MAX_10_EXP
1970 #       define NV_MAX_10_EXP DBL_MAX_10_EXP
1971 #   endif
1972 #   ifdef DBL_EPSILON
1973 #       define NV_EPSILON DBL_EPSILON
1974 #   endif
1975 #   ifdef DBL_MAX               /* XXX Does DBL_MAX imply having DBL_MIN? */
1976 #       define NV_MAX DBL_MAX
1977 #       define NV_MIN DBL_MIN
1978 #   else
1979 #       ifdef HUGE_VAL
1980 #           define NV_MAX HUGE_VAL
1981 #       endif
1982 #   endif
1983 #   define Perl_cos cos
1984 #   define Perl_sin sin
1985 #   define Perl_sqrt sqrt
1986 #   define Perl_exp exp
1987 #   define Perl_log log
1988 #   define Perl_atan2 atan2
1989 #   define Perl_pow pow
1990 #   define Perl_floor floor
1991 #   define Perl_ceil ceil
1992 #   define Perl_fmod fmod
1993 #   define Perl_modf(x,y) modf(x,y)
1994 #   define Perl_frexp(x,y) frexp(x,y)
1995 #endif
1996
1997 /* rumor has it that Win32 has _fpclass() */
1998
1999 /* SGI has fpclassl... but not with the same result values,
2000  * and it's via a typedef (not via #define), so will need to redo Configure
2001  * to use. Not worth the trouble, IMO, at least until the below is used
2002  * more places. Also has fp_class_l, BTW, via fp_class.h. Feel free to check
2003  * with me for the SGI manpages, SGI testing, etcetera, if you want to
2004  * try getting this to work with IRIX. - Allen <allens@cpan.org> */
2005
2006 #if !defined(Perl_fp_class) && (defined(HAS_FPCLASS)||defined(HAS_FPCLASSL))
2007 #    ifdef I_IEEFP
2008 #        include <ieeefp.h>
2009 #    endif
2010 #    ifdef I_FP
2011 #        include <fp.h>
2012 #    endif
2013 #    if defined(USE_LONG_DOUBLE) && defined(HAS_FPCLASSL)
2014 #        define Perl_fp_class()         fpclassl(x)
2015 #    else
2016 #        define Perl_fp_class()         fpclass(x)
2017 #    endif
2018 #    define Perl_fp_class_snan(x)       (Perl_fp_class(x)==FP_CLASS_SNAN)
2019 #    define Perl_fp_class_qnan(x)       (Perl_fp_class(x)==FP_CLASS_QNAN)
2020 #    define Perl_fp_class_nan(x)        (Perl_fp_class(x)==FP_CLASS_SNAN||Perl_fp_class(x)==FP_CLASS_QNAN)
2021 #    define Perl_fp_class_ninf(x)       (Perl_fp_class(x)==FP_CLASS_NINF)
2022 #    define Perl_fp_class_pinf(x)       (Perl_fp_class(x)==FP_CLASS_PINF)
2023 #    define Perl_fp_class_inf(x)        (Perl_fp_class(x)==FP_CLASS_NINF||Perl_fp_class(x)==FP_CLASS_PINF)
2024 #    define Perl_fp_class_nnorm(x)      (Perl_fp_class(x)==FP_CLASS_NNORM)
2025 #    define Perl_fp_class_pnorm(x)      (Perl_fp_class(x)==FP_CLASS_PNORM)
2026 #    define Perl_fp_class_norm(x)       (Perl_fp_class(x)==FP_CLASS_NNORM||Perl_fp_class(x)==FP_CLASS_PNORM)
2027 #    define Perl_fp_class_ndenorm(x)    (Perl_fp_class(x)==FP_CLASS_NDENORM)
2028 #    define Perl_fp_class_pdenorm(x)    (Perl_fp_class(x)==FP_CLASS_PDENORM)
2029 #    define Perl_fp_class_denorm(x)     (Perl_fp_class(x)==FP_CLASS_NDENORM||Perl_fp_class(x)==FP_CLASS_PDENORM)
2030 #    define Perl_fp_class_nzero(x)      (Perl_fp_class(x)==FP_CLASS_NZERO)
2031 #    define Perl_fp_class_pzero(x)      (Perl_fp_class(x)==FP_CLASS_PZERO)
2032 #    define Perl_fp_class_zero(x)       (Perl_fp_class(x)==FP_CLASS_NZERO||Perl_fp_class(x)==FP_CLASS_PZERO)
2033 #endif
2034
2035 #if !defined(Perl_fp_class) && defined(HAS_FP_CLASS) && !defined(PERL_MICRO)
2036 #    include <math.h>
2037 #    if !defined(FP_SNAN) && defined(I_FP_CLASS)
2038 #        include <fp_class.h>
2039 #    endif
2040 #    define Perl_fp_class(x)            fp_class(x)
2041 #    define Perl_fp_class_snan(x)       (fp_class(x)==FP_SNAN)
2042 #    define Perl_fp_class_qnan(x)       (fp_class(x)==FP_QNAN)
2043 #    define Perl_fp_class_nan(x)        (fp_class(x)==FP_SNAN||fp_class(x)==FP_QNAN)
2044 #    define Perl_fp_class_ninf(x)       (fp_class(x)==FP_NEG_INF)
2045 #    define Perl_fp_class_pinf(x)       (fp_class(x)==FP_POS_INF)
2046 #    define Perl_fp_class_inf(x)        (fp_class(x)==FP_NEG_INF||fp_class(x)==FP_POS_INF)
2047 #    define Perl_fp_class_nnorm(x)      (fp_class(x)==FP_NEG_NORM)
2048 #    define Perl_fp_class_pnorm(x)      (fp_class(x)==FP_POS_NORM)
2049 #    define Perl_fp_class_norm(x)       (fp_class(x)==FP_NEG_NORM||fp_class(x)==FP_POS_NORM)
2050 #    define Perl_fp_class_ndenorm(x)    (fp_class(x)==FP_NEG_DENORM)
2051 #    define Perl_fp_class_pdenorm(x)    (fp_class(x)==FP_POS_DENORM)
2052 #    define Perl_fp_class_denorm(x)     (fp_class(x)==FP_NEG_DENORM||fp_class(x)==FP_POS_DENORM)
2053 #    define Perl_fp_class_nzero(x)      (fp_class(x)==FP_NEG_ZERO)
2054 #    define Perl_fp_class_pzero(x)      (fp_class(x)==FP_POS_ZERO)
2055 #    define Perl_fp_class_zero(x)       (fp_class(x)==FP_NEG_ZERO||fp_class(x)==FP_POS_ZERO)
2056 #endif
2057
2058 #if !defined(Perl_fp_class) && defined(HAS_FPCLASSIFY)
2059 #    include <math.h>
2060 #    define Perl_fp_class(x)            fpclassify(x)
2061 #    define Perl_fp_class_nan(x)        (fp_classify(x)==FP_SNAN||fp_classify(x)==FP_QNAN)
2062 #    define Perl_fp_class_inf(x)        (fp_classify(x)==FP_INFINITE)
2063 #    define Perl_fp_class_norm(x)       (fp_classify(x)==FP_NORMAL)
2064 #    define Perl_fp_class_denorm(x)     (fp_classify(x)==FP_SUBNORMAL)
2065 #    define Perl_fp_class_zero(x)       (fp_classify(x)==FP_ZERO)
2066 #endif
2067
2068 #if !defined(Perl_fp_class) && defined(HAS_CLASS)
2069 #    include <math.h>
2070 #    ifndef _cplusplus
2071 #        define Perl_fp_class(x)        class(x)
2072 #    else
2073 #        define Perl_fp_class(x)        _class(x)
2074 #    endif
2075 #    define Perl_fp_class_snan(x)       (Perl_fp_class(x)==FP_NANS)
2076 #    define Perl_fp_class_qnan(x)       (Perl_fp_class(x)==FP_NANQ)
2077 #    define Perl_fp_class_nan(x)        (Perl_fp_class(x)==FP_SNAN||Perl_fp_class(x)==FP_QNAN)
2078 #    define Perl_fp_class_ninf(x)       (Perl_fp_class(x)==FP_MINUS_INF)
2079 #    define Perl_fp_class_pinf(x)       (Perl_fp_class(x)==FP_PLUS_INF)
2080 #    define Perl_fp_class_inf(x)        (Perl_fp_class(x)==FP_MINUS_INF||Perl_fp_class(x)==FP_PLUS_INF)
2081 #    define Perl_fp_class_nnorm(x)      (Perl_fp_class(x)==FP_MINUS_NORM)
2082 #    define Perl_fp_class_pnorm(x)      (Perl_fp_class(x)==FP_PLUS_NORM)
2083 #    define Perl_fp_class_norm(x)       (Perl_fp_class(x)==FP_MINUS_NORM||Perl_fp_class(x)==FP_PLUS_NORM)
2084 #    define Perl_fp_class_ndenorm(x)    (Perl_fp_class(x)==FP_MINUS_DENORM)
2085 #    define Perl_fp_class_pdenorm(x)    (Perl_fp_class(x)==FP_PLUS_DENORM)
2086 #    define Perl_fp_class_denorm(x)     (Perl_fp_class(x)==FP_MINUS_DENORM||Perl_fp_class(x)==FP_PLUS_DENORM)
2087 #    define Perl_fp_class_nzero(x)      (Perl_fp_class(x)==FP_MINUS_ZERO)
2088 #    define Perl_fp_class_pzero(x)      (Perl_fp_class(x)==FP_PLUS_ZERO)
2089 #    define Perl_fp_class_zero(x)       (Perl_fp_class(x)==FP_MINUS_ZERO||Perl_fp_class(x)==FP_PLUS_ZERO)
2090 #endif
2091
2092 /* rumor has it that Win32 has _isnan() */
2093
2094 #ifndef Perl_isnan
2095 #   ifdef HAS_ISNAN
2096 #       define Perl_isnan(x) isnan((NV)x)
2097 #   else
2098 #       ifdef Perl_fp_class_nan
2099 #           define Perl_isnan(x) Perl_fp_class_nan(x)
2100 #       else
2101 #           ifdef HAS_UNORDERED
2102 #               define Perl_isnan(x) unordered((x), 0.0)
2103 #           else
2104 #               define Perl_isnan(x) ((x)!=(x))
2105 #           endif
2106 #       endif
2107 #   endif
2108 #endif
2109
2110 #ifdef UNDER_CE
2111 int isnan(double d);
2112 #endif
2113
2114 #ifndef Perl_isinf
2115 #   ifdef HAS_ISINF
2116 #       define Perl_isinf(x) isinf((NV)x)
2117 #   else
2118 #       ifdef Perl_fp_class_inf
2119 #           define Perl_isinf(x) Perl_fp_class_inf(x)
2120 #       else
2121 #           define Perl_isinf(x) ((x)==NV_INF)
2122 #       endif
2123 #   endif
2124 #endif
2125
2126 #ifndef Perl_isfinite
2127 #   ifdef HAS_FINITE
2128 #       define Perl_isfinite(x) finite((NV)x)
2129 #   else
2130 #       ifdef HAS_ISFINITE
2131 #           define Perl_isfinite(x) isfinite(x)
2132 #       else
2133 #           ifdef Perl_fp_class_finite
2134 #               define Perl_isfinite(x) Perl_fp_class_finite(x)
2135 #           else
2136 #               define Perl_isfinite(x) !(Perl_is_inf(x)||Perl_is_nan(x))
2137 #           endif
2138 #       endif
2139 #   endif
2140 #endif
2141
2142 /* The default is to use Perl's own atof() implementation (in numeric.c).
2143  * Usually that is the one to use but for some platforms (e.g. UNICOS)
2144  * it is however best to use the native implementation of atof.
2145  * You can experiment with using your native one by -DUSE_PERL_ATOF=0.
2146  * Some good tests to try out with either setting are t/base/num.t,
2147  * t/op/numconvert.t, and t/op/pack.t. Note that if using long doubles
2148  * you may need to be using a different function than atof! */
2149
2150 #ifndef USE_PERL_ATOF
2151 #   ifndef _UNICOS
2152 #       define USE_PERL_ATOF
2153 #   endif
2154 #else
2155 #   if USE_PERL_ATOF == 0
2156 #       undef USE_PERL_ATOF
2157 #   endif
2158 #endif
2159
2160 #ifdef USE_PERL_ATOF
2161 #   define Perl_atof(s) Perl_my_atof(s)
2162 #   define Perl_atof2(s, n) Perl_my_atof2(aTHX_ (s), &(n))
2163 #else
2164 #   define Perl_atof(s) (NV)atof(s)
2165 #   define Perl_atof2(s, n) ((n) = atof(s))
2166 #endif
2167
2168 /* Previously these definitions used hardcoded figures.
2169  * It is hoped these formula are more portable, although
2170  * no data one way or another is presently known to me.
2171  * The "PERL_" names are used because these calculated constants
2172  * do not meet the ANSI requirements for LONG_MAX, etc., which
2173  * need to be constants acceptable to #if - kja
2174  *    define PERL_LONG_MAX        2147483647L
2175  *    define PERL_LONG_MIN        (-LONG_MAX - 1)
2176  *    define PERL ULONG_MAX       4294967295L
2177  */
2178
2179 #ifdef I_LIMITS  /* Needed for cast_xxx() functions below. */
2180 #  include <limits.h>
2181 #endif
2182 /* Included values.h above if necessary; still including limits.h down here,
2183  * despite doing above, because math.h might have overriden... XXX - Allen */
2184
2185 /*
2186  * Try to figure out max and min values for the integral types.  THE CORRECT
2187  * SOLUTION TO THIS MESS: ADAPT enquire.c FROM GCC INTO CONFIGURE.  The
2188  * following hacks are used if neither limits.h or values.h provide them:
2189  * U<TYPE>_MAX: for types >= int: ~(unsigned TYPE)0
2190  *              for types <  int:  (unsigned TYPE)~(unsigned)0
2191  *      The argument to ~ must be unsigned so that later signed->unsigned
2192  *      conversion can't modify the value's bit pattern (e.g. -0 -> +0),
2193  *      and it must not be smaller than int because ~ does integral promotion.
2194  * <type>_MAX: (<type>) (U<type>_MAX >> 1)
2195  * <type>_MIN: -<type>_MAX - <is_twos_complement_architecture: (3 & -1) == 3>.
2196  *      The latter is a hack which happens to work on some machines but
2197  *      does *not* catch any random system, or things like integer types
2198  *      with NaN if that is possible.
2199  *
2200  * All of the types are explicitly cast to prevent accidental loss of
2201  * numeric range, and in the hope that they will be less likely to confuse
2202  * over-eager optimizers.
2203  *
2204  */
2205
2206 #define PERL_UCHAR_MIN ((unsigned char)0)
2207
2208 #ifdef UCHAR_MAX
2209 #  define PERL_UCHAR_MAX ((unsigned char)UCHAR_MAX)
2210 #else
2211 #  ifdef MAXUCHAR
2212 #    define PERL_UCHAR_MAX ((unsigned char)MAXUCHAR)
2213 #  else
2214 #    define PERL_UCHAR_MAX       ((unsigned char)~(unsigned)0)
2215 #  endif
2216 #endif
2217
2218 /*
2219  * CHAR_MIN and CHAR_MAX are not included here, as the (char) type may be
2220  * ambiguous. It may be equivalent to (signed char) or (unsigned char)
2221  * depending on local options. Until Configure detects this (or at least
2222  * detects whether the "signed" keyword is available) the CHAR ranges
2223  * will not be included. UCHAR functions normally.
2224  *                                                           - kja
2225  */
2226
2227 #define PERL_USHORT_MIN ((unsigned short)0)
2228
2229 #ifdef USHORT_MAX
2230 #  define PERL_USHORT_MAX ((unsigned short)USHORT_MAX)
2231 #else
2232 #  ifdef MAXUSHORT
2233 #    define PERL_USHORT_MAX ((unsigned short)MAXUSHORT)
2234 #  else
2235 #    ifdef USHRT_MAX
2236 #      define PERL_USHORT_MAX ((unsigned short)USHRT_MAX)
2237 #    else
2238 #      define PERL_USHORT_MAX       ((unsigned short)~(unsigned)0)
2239 #    endif
2240 #  endif
2241 #endif
2242
2243 #ifdef SHORT_MAX
2244 #  define PERL_SHORT_MAX ((short)SHORT_MAX)
2245 #else
2246 #  ifdef MAXSHORT    /* Often used in <values.h> */
2247 #    define PERL_SHORT_MAX ((short)MAXSHORT)
2248 #  else
2249 #    ifdef SHRT_MAX
2250 #      define PERL_SHORT_MAX ((short)SHRT_MAX)
2251 #    else
2252 #      define PERL_SHORT_MAX      ((short) (PERL_USHORT_MAX >> 1))
2253 #    endif
2254 #  endif
2255 #endif
2256
2257 #ifdef SHORT_MIN
2258 #  define PERL_SHORT_MIN ((short)SHORT_MIN)
2259 #else
2260 #  ifdef MINSHORT
2261 #    define PERL_SHORT_MIN ((short)MINSHORT)
2262 #  else
2263 #    ifdef SHRT_MIN
2264 #      define PERL_SHORT_MIN ((short)SHRT_MIN)
2265 #    else
2266 #      define PERL_SHORT_MIN        (-PERL_SHORT_MAX - ((3 & -1) == 3))
2267 #    endif
2268 #  endif
2269 #endif
2270
2271 #ifdef UINT_MAX
2272 #  define PERL_UINT_MAX ((unsigned int)UINT_MAX)
2273 #else
2274 #  ifdef MAXUINT
2275 #    define PERL_UINT_MAX ((unsigned int)MAXUINT)
2276 #  else
2277 #    define PERL_UINT_MAX       (~(unsigned int)0)
2278 #  endif
2279 #endif
2280
2281 #define PERL_UINT_MIN ((unsigned int)0)
2282
2283 #ifdef INT_MAX
2284 #  define PERL_INT_MAX ((int)INT_MAX)
2285 #else
2286 #  ifdef MAXINT    /* Often used in <values.h> */
2287 #    define PERL_INT_MAX ((int)MAXINT)
2288 #  else
2289 #    define PERL_INT_MAX        ((int)(PERL_UINT_MAX >> 1))
2290 #  endif
2291 #endif
2292
2293 #ifdef INT_MIN
2294 #  define PERL_INT_MIN ((int)INT_MIN)
2295 #else
2296 #  ifdef MININT
2297 #    define PERL_INT_MIN ((int)MININT)
2298 #  else
2299 #    define PERL_INT_MIN        (-PERL_INT_MAX - ((3 & -1) == 3))
2300 #  endif
2301 #endif
2302
2303 #ifdef ULONG_MAX
2304 #  define PERL_ULONG_MAX ((unsigned long)ULONG_MAX)
2305 #else
2306 #  ifdef MAXULONG
2307 #    define PERL_ULONG_MAX ((unsigned long)MAXULONG)
2308 #  else
2309 #    define PERL_ULONG_MAX       (~(unsigned long)0)
2310 #  endif
2311 #endif
2312
2313 #define PERL_ULONG_MIN ((unsigned long)0L)
2314
2315 #ifdef LONG_MAX
2316 #  define PERL_LONG_MAX ((long)LONG_MAX)
2317 #else
2318 #  ifdef MAXLONG    /* Often used in <values.h> */
2319 #    define PERL_LONG_MAX ((long)MAXLONG)
2320 #  else
2321 #    define PERL_LONG_MAX        ((long) (PERL_ULONG_MAX >> 1))
2322 #  endif
2323 #endif
2324
2325 #ifdef LONG_MIN
2326 #  define PERL_LONG_MIN ((long)LONG_MIN)
2327 #else
2328 #  ifdef MINLONG
2329 #    define PERL_LONG_MIN ((long)MINLONG)
2330 #  else
2331 #    define PERL_LONG_MIN        (-PERL_LONG_MAX - ((3 & -1) == 3))
2332 #  endif
2333 #endif
2334
2335 #ifdef UV_IS_QUAD
2336
2337 #    define PERL_UQUAD_MAX      (~(UV)0)
2338 #    define PERL_UQUAD_MIN      ((UV)0)
2339 #    define PERL_QUAD_MAX       ((IV) (PERL_UQUAD_MAX >> 1))
2340 #    define PERL_QUAD_MIN       (-PERL_QUAD_MAX - ((3 & -1) == 3))
2341
2342 #endif
2343
2344 #ifdef MYMALLOC
2345 #  include "malloc_ctl.h"
2346 #endif
2347
2348 struct RExC_state_t;
2349 struct _reg_trie_data;
2350
2351 typedef MEM_SIZE STRLEN;
2352
2353 #ifdef PERL_MAD
2354 typedef struct token TOKEN;
2355 typedef struct madprop MADPROP;
2356 typedef struct nexttoken NEXTTOKE;
2357 #endif
2358 typedef struct op OP;
2359 typedef struct cop COP;
2360 typedef struct unop UNOP;
2361 typedef struct binop BINOP;
2362 typedef struct listop LISTOP;
2363 typedef struct logop LOGOP;
2364 typedef struct pmop PMOP;
2365 typedef struct svop SVOP;
2366 typedef struct padop PADOP;
2367 typedef struct pvop PVOP;
2368 typedef struct loop LOOP;
2369
2370 typedef struct interpreter PerlInterpreter;
2371
2372 /* Amdahl's <ksync.h> has struct sv */
2373 /* SGI's <sys/sema.h> has struct sv */
2374 #if defined(UTS) || defined(__sgi)
2375 #   define STRUCT_SV perl_sv
2376 #else
2377 #   define STRUCT_SV sv
2378 #endif
2379 typedef struct STRUCT_SV SV;
2380 typedef struct av AV;
2381 typedef struct hv HV;
2382 typedef struct cv CV;
2383 typedef struct regexp ORANGE;   /* This is the body structure.  */
2384 typedef struct p5rx REGEXP;
2385 typedef struct gp GP;
2386 typedef struct gv GV;
2387 typedef struct io IO;
2388 typedef struct context PERL_CONTEXT;
2389 typedef struct block BLOCK;
2390
2391 typedef struct magic MAGIC;
2392 typedef struct xpv XPV;
2393 typedef struct xpviv XPVIV;
2394 typedef struct xpvuv XPVUV;
2395 typedef struct xpvnv XPVNV;
2396 typedef struct xpvmg XPVMG;
2397 typedef struct xpvlv XPVLV;
2398 typedef struct xpvav XPVAV;
2399 typedef struct xpvhv XPVHV;
2400 typedef struct xpvgv XPVGV;
2401 typedef struct xpvcv XPVCV;
2402 typedef struct xpvbm XPVBM;
2403 typedef struct xpvfm XPVFM;
2404 typedef struct xpvio XPVIO;
2405 typedef struct mgvtbl MGVTBL;
2406 typedef union any ANY;
2407 typedef struct ptr_tbl_ent PTR_TBL_ENT_t;
2408 typedef struct ptr_tbl PTR_TBL_t;
2409 typedef struct clone_params CLONE_PARAMS;
2410
2411 #include "handy.h"
2412
2413 #if defined(USE_LARGE_FILES) && !defined(NO_64_BIT_RAWIO)
2414 #   if LSEEKSIZE == 8 && !defined(USE_64_BIT_RAWIO)
2415 #       define USE_64_BIT_RAWIO /* implicit */
2416 #   endif
2417 #endif
2418
2419 /* Notice the use of HAS_FSEEKO: now we are obligated to always use
2420  * fseeko/ftello if possible.  Don't go #defining ftell to ftello yourself,
2421  * however, because operating systems like to do that themself. */
2422 #ifndef FSEEKSIZE
2423 #   ifdef HAS_FSEEKO
2424 #       define FSEEKSIZE LSEEKSIZE
2425 #   else
2426 #       define FSEEKSIZE LONGSIZE
2427 #   endif
2428 #endif
2429
2430 #if defined(USE_LARGE_FILES) && !defined(NO_64_BIT_STDIO)
2431 #   if FSEEKSIZE == 8 && !defined(USE_64_BIT_STDIO)
2432 #       define USE_64_BIT_STDIO /* implicit */
2433 #   endif
2434 #endif
2435
2436 #ifdef USE_64_BIT_RAWIO
2437 #   ifdef HAS_OFF64_T
2438 #       undef Off_t
2439 #       define Off_t off64_t
2440 #       undef LSEEKSIZE
2441 #       define LSEEKSIZE 8
2442 #   endif
2443 /* Most 64-bit environments have defines like _LARGEFILE_SOURCE that
2444  * will trigger defines like the ones below.  Some 64-bit environments,
2445  * however, do not.  Therefore we have to explicitly mix and match. */
2446 #   if defined(USE_OPEN64)
2447 #       define open open64
2448 #   endif
2449 #   if defined(USE_LSEEK64)
2450 #       define lseek lseek64
2451 #   else
2452 #       if defined(USE_LLSEEK)
2453 #           define lseek llseek
2454 #       endif
2455 #   endif
2456 #   if defined(USE_STAT64)
2457 #       define stat stat64
2458 #   endif
2459 #   if defined(USE_FSTAT64)
2460 #       define fstat fstat64
2461 #   endif
2462 #   if defined(USE_LSTAT64)
2463 #       define lstat lstat64
2464 #   endif
2465 #   if defined(USE_FLOCK64)
2466 #       define flock flock64
2467 #   endif
2468 #   if defined(USE_LOCKF64)
2469 #       define lockf lockf64
2470 #   endif
2471 #   if defined(USE_FCNTL64)
2472 #       define fcntl fcntl64
2473 #   endif
2474 #   if defined(USE_TRUNCATE64)
2475 #       define truncate truncate64
2476 #   endif
2477 #   if defined(USE_FTRUNCATE64)
2478 #       define ftruncate ftruncate64
2479 #   endif
2480 #endif
2481
2482 #ifdef USE_64_BIT_STDIO
2483 #   ifdef HAS_FPOS64_T
2484 #       undef Fpos_t
2485 #       define Fpos_t fpos64_t
2486 #   endif
2487 /* Most 64-bit environments have defines like _LARGEFILE_SOURCE that
2488  * will trigger defines like the ones below.  Some 64-bit environments,
2489  * however, do not. */
2490 #   if defined(USE_FOPEN64)
2491 #       define fopen fopen64
2492 #   endif
2493 #   if defined(USE_FSEEK64)
2494 #       define fseek fseek64 /* don't do fseeko here, see perlio.c */
2495 #   endif
2496 #   if defined(USE_FTELL64)
2497 #       define ftell ftell64 /* don't do ftello here, see perlio.c */
2498 #   endif
2499 #   if defined(USE_FSETPOS64)
2500 #       define fsetpos fsetpos64
2501 #   endif
2502 #   if defined(USE_FGETPOS64)
2503 #       define fgetpos fgetpos64
2504 #   endif
2505 #   if defined(USE_TMPFILE64)
2506 #       define tmpfile tmpfile64
2507 #   endif
2508 #   if defined(USE_FREOPEN64)
2509 #       define freopen freopen64
2510 #   endif
2511 #endif
2512
2513 #if defined(OS2)
2514 #  include "iperlsys.h"
2515 #endif
2516
2517 #if defined(__OPEN_VM)
2518 #   include "vmesa/vmesaish.h"
2519 #   define ISHISH "vmesa"
2520 #endif
2521
2522 #ifdef DOSISH
2523 #   if defined(OS2)
2524 #       include "os2ish.h"
2525 #   else
2526 #       include "dosish.h"
2527 #   endif
2528 #   define ISHISH "dos"
2529 #endif
2530
2531 #if defined(VMS)
2532 #   include "vmsish.h"
2533 #   include "embed.h"
2534 #  ifndef PERL_MAD
2535 #    undef op_getmad
2536 #    define op_getmad(arg,pegop,slot) NOOP
2537 #  endif
2538 #   define ISHISH "vms"
2539 #endif
2540
2541 #if defined(PLAN9)
2542 #   include "./plan9/plan9ish.h"
2543 #   define ISHISH "plan9"
2544 #endif
2545
2546 #if defined(MPE)
2547 #  include "mpeix/mpeixish.h"
2548 #  define ISHISH "mpeix"
2549 #endif
2550
2551 #if defined(__VOS__)
2552 #   ifdef __GNUC__
2553 #     include "./vos/vosish.h"
2554 #   else
2555 #     include "vos/vosish.h"
2556 #   endif
2557 #   define ISHISH "vos"
2558 #endif
2559
2560 #if defined(EPOC)
2561 #   include "epocish.h"
2562 #   define ISHISH "epoc"
2563 #endif
2564
2565 #ifdef __SYMBIAN32__
2566 #   include "symbian/symbianish.h"
2567 #   include "embed.h"
2568 #  ifndef PERL_MAD
2569 #    undef op_getmad
2570 #    define op_getmad(arg,pegop,slot) NOOP
2571 #  endif
2572 #   define ISHISH "symbian"
2573 #endif
2574
2575
2576 #if defined(__HAIKU__)
2577 #   include "haiku/haikuish.h"
2578 #   define ISHISH "haiku"
2579 #elif defined(__BEOS__)
2580 #   include "beos/beosish.h"
2581 #   define ISHISH "beos"
2582 #endif
2583
2584 #ifndef ISHISH
2585 #   include "unixish.h"
2586 #   define ISHISH "unix"
2587 #endif
2588
2589 /* NSIG logic from Configure --> */
2590 /* Strange style to avoid deeply-nested #if/#else/#endif */
2591 #ifndef NSIG
2592 #  ifdef _NSIG
2593 #    define NSIG (_NSIG)
2594 #  endif
2595 #endif
2596
2597 #ifndef NSIG
2598 #  ifdef SIGMAX
2599 #    define NSIG (SIGMAX+1)
2600 #  endif
2601 #endif
2602
2603 #ifndef NSIG
2604 #  ifdef SIG_MAX
2605 #    define NSIG (SIG_MAX+1)
2606 #  endif
2607 #endif
2608
2609 #ifndef NSIG
2610 #  ifdef _SIG_MAX
2611 #    define NSIG (_SIG_MAX+1)
2612 #  endif
2613 #endif
2614
2615 #ifndef NSIG
2616 #  ifdef MAXSIG
2617 #    define NSIG (MAXSIG+1)
2618 #  endif
2619 #endif
2620
2621 #ifndef NSIG
2622 #  ifdef MAX_SIG
2623 #    define NSIG (MAX_SIG+1)
2624 #  endif
2625 #endif
2626
2627 #ifndef NSIG
2628 #  ifdef SIGARRAYSIZE
2629 #    define NSIG SIGARRAYSIZE /* Assume ary[SIGARRAYSIZE] */
2630 #  endif
2631 #endif
2632
2633 #ifndef NSIG
2634 #  ifdef _sys_nsig
2635 #    define NSIG (_sys_nsig) /* Solaris 2.5 */
2636 #  endif
2637 #endif
2638
2639 /* Default to some arbitrary number that's big enough to get most
2640    of the common signals.
2641 */
2642 #ifndef NSIG
2643 #    define NSIG 50
2644 #endif
2645 /* <-- NSIG logic from Configure */
2646
2647 #ifndef NO_ENVIRON_ARRAY
2648 #  define USE_ENVIRON_ARRAY
2649 #endif
2650
2651 /*
2652  * initialise to avoid floating-point exceptions from overflow, etc
2653  */
2654 #ifndef PERL_FPU_INIT
2655 #  ifdef HAS_FPSETMASK
2656 #    if HAS_FLOATINGPOINT_H
2657 #      include <floatingpoint.h>
2658 #    endif
2659 /* Some operating systems have this as a macro, which in turn expands to a comma
2660    expression, and the last sub-expression is something that gets calculated,
2661    and then they have the gall to warn that a value computed is not used. Hence
2662    cast to void.  */
2663 #    define PERL_FPU_INIT (void)fpsetmask(0)
2664 #  else
2665 #    if defined(SIGFPE) && defined(SIG_IGN) && !defined(PERL_MICRO)
2666 #      define PERL_FPU_INIT       PL_sigfpe_saved = (Sighandler_t) signal(SIGFPE, SIG_IGN)
2667 #      define PERL_FPU_PRE_EXEC   { Sigsave_t xfpe; rsignal_save(SIGFPE, PL_sigfpe_saved, &xfpe);
2668 #      define PERL_FPU_POST_EXEC    rsignal_restore(SIGFPE, &xfpe); }
2669 #    else
2670 #      define PERL_FPU_INIT
2671
2672 #    endif
2673 #  endif
2674 #endif
2675 #ifndef PERL_FPU_PRE_EXEC
2676 #  define PERL_FPU_PRE_EXEC   {
2677 #  define PERL_FPU_POST_EXEC  }
2678 #endif
2679
2680 #ifndef PERL_SYS_INIT3_BODY
2681 #  define PERL_SYS_INIT3_BODY(argvp,argcp,envp) PERL_SYS_INIT_BODY(argvp,argcp)
2682 #endif
2683
2684 /*
2685 =for apidoc Am|void|PERL_SYS_INIT|int argc|char** argv
2686 Provides system-specific tune up of the C runtime environment necessary to
2687 run Perl interpreters. This should be called only once, before creating
2688 any Perl interpreters.
2689
2690 =for apidoc Am|void|PERL_SYS_INIT3|int argc|char** argv|char** env
2691 Provides system-specific tune up of the C runtime environment necessary to
2692 run Perl interpreters. This should be called only once, before creating
2693 any Perl interpreters.
2694
2695 =for apidoc Am|void|PERL_SYS_TERM|
2696 Provides system-specific clean up of the C runtime environment after
2697 running Perl interpreters. This should be called only once, after
2698 freeing any remaining Perl interpreters.
2699
2700 =cut
2701  */
2702
2703 #define PERL_SYS_INIT(argc, argv)       Perl_sys_init(argc, argv)
2704 #define PERL_SYS_INIT3(argc, argv, env) Perl_sys_init3(argc, argv, env)
2705 #define PERL_SYS_TERM()                 Perl_sys_term()
2706
2707 #ifndef PERL_WRITE_MSG_TO_CONSOLE
2708 #  define PERL_WRITE_MSG_TO_CONSOLE(io, msg, len) PerlIO_write(io, msg, len)
2709 #endif
2710
2711 #ifndef MAXPATHLEN
2712 #  ifdef PATH_MAX
2713 #    ifdef _POSIX_PATH_MAX
2714 #       if PATH_MAX > _POSIX_PATH_MAX
2715 /* POSIX 1990 (and pre) was ambiguous about whether PATH_MAX
2716  * included the null byte or not.  Later amendments of POSIX,
2717  * XPG4, the Austin Group, and the Single UNIX Specification
2718  * all explicitly include the null byte in the PATH_MAX.
2719  * Ditto for _POSIX_PATH_MAX. */
2720 #         define MAXPATHLEN PATH_MAX
2721 #       else
2722 #         define MAXPATHLEN _POSIX_PATH_MAX
2723 #       endif
2724 #    else
2725 #      define MAXPATHLEN (PATH_MAX+1)
2726 #    endif
2727 #  else
2728 #    ifdef _POSIX_PATH_MAX
2729 #       define MAXPATHLEN _POSIX_PATH_MAX
2730 #    else
2731 #       define MAXPATHLEN 1024  /* Err on the large side. */
2732 #    endif
2733 #  endif
2734 #endif
2735
2736 /* In case Configure was not used (we are using a "canned config"
2737  * such as Win32, or a cross-compilation setup, for example) try going
2738  * by the gcc major and minor versions.  One useful URL is
2739  * http://www.ohse.de/uwe/articles/gcc-attributes.html,
2740  * but contrary to this information warn_unused_result seems
2741  * not to be in gcc 3.3.5, at least. --jhi
2742  * Also, when building extensions with an installed perl, this allows
2743  * the user to upgrade gcc and get the right attributes, rather than
2744  * relying on the list generated at Configure time.  --AD
2745  * Set these up now otherwise we get confused when some of the <*thread.h>
2746  * includes below indirectly pull in <perlio.h> (which needs to know if we
2747  * have HASATTRIBUTE_FORMAT).
2748  */
2749
2750 #ifndef PERL_MICRO
2751 #if defined __GNUC__ && !defined(__INTEL_COMPILER)
2752 #  if __GNUC__ == 3 && __GNUC_MINOR__ >= 1 || __GNUC__ > 3 /* 3.1 -> */
2753 #    define HASATTRIBUTE_DEPRECATED
2754 #  endif
2755 #  if __GNUC__ >= 3 /* 3.0 -> */ /* XXX Verify this version */
2756 #    define HASATTRIBUTE_FORMAT
2757 #    if defined __MINGW32__
2758 #      define PRINTF_FORMAT_NULL_OK
2759 #    endif
2760 #  endif
2761 #  if __GNUC__ >= 3 /* 3.0 -> */
2762 #    define HASATTRIBUTE_MALLOC
2763 #  endif
2764 #  if __GNUC__ == 3 && __GNUC_MINOR__ >= 3 || __GNUC__ > 3 /* 3.3 -> */
2765 #    define HASATTRIBUTE_NONNULL
2766 #  endif
2767 #  if __GNUC__ == 2 && __GNUC_MINOR__ >= 5 || __GNUC__ > 2 /* 2.5 -> */
2768 #    define HASATTRIBUTE_NORETURN
2769 #  endif
2770 #  if __GNUC__ >= 3 /* gcc 3.0 -> */
2771 #    define HASATTRIBUTE_PURE
2772 #  endif
2773 #  if __GNUC__ == 3 && __GNUC_MINOR__ >= 4 || __GNUC__ > 3 /* 3.4 -> */
2774 #    define HASATTRIBUTE_UNUSED
2775 #  endif
2776 #  if __GNUC__ == 3 && __GNUC_MINOR__ == 3 && !defined(__cplusplus)
2777 #    define HASATTRIBUTE_UNUSED /* gcc-3.3, but not g++-3.3. */
2778 #  endif
2779 #  if __GNUC__ == 3 && __GNUC_MINOR__ >= 4 || __GNUC__ > 3 /* 3.4 -> */
2780 #    define HASATTRIBUTE_WARN_UNUSED_RESULT
2781 #  endif
2782 #endif
2783 #endif /* #ifndef PERL_MICRO */ 
2784
2785 /* USE_5005THREADS needs to be after unixish.h as <pthread.h> includes
2786  * <sys/signal.h> which defines NSIG - which will stop inclusion of <signal.h>
2787  * this results in many functions being undeclared which bothers C++
2788  * May make sense to have threads after "*ish.h" anyway
2789  */
2790
2791 #if defined(USE_ITHREADS)
2792 #  ifdef NETWARE
2793 #   include <nw5thread.h>
2794 #  else
2795 #  ifdef FAKE_THREADS
2796 #    include "fakethr.h"
2797 #  else
2798 #    ifdef WIN32
2799 #      include <win32thread.h>
2800 #    else
2801 #      ifdef OS2
2802 #        include "os2thread.h"
2803 #      else
2804 #        ifdef I_MACH_CTHREADS
2805 #          include <mach/cthreads.h>
2806 #          if (defined(NeXT) || defined(__NeXT__)) && defined(PERL_POLLUTE_MALLOC)
2807 #            define MUTEX_INIT_CALLS_MALLOC
2808 #          endif
2809 typedef cthread_t       perl_os_thread;
2810 typedef mutex_t         perl_mutex;
2811 typedef condition_t     perl_cond;
2812 typedef void *          perl_key;
2813 #        else /* Posix threads */
2814 #          ifdef I_PTHREAD
2815 #            include <pthread.h>
2816 #          endif
2817 typedef pthread_t       perl_os_thread;
2818 typedef pthread_mutex_t perl_mutex;
2819 typedef pthread_cond_t  perl_cond;
2820 typedef pthread_key_t   perl_key;
2821 #        endif /* I_MACH_CTHREADS */
2822 #      endif /* OS2 */
2823 #    endif /* WIN32 */
2824 #  endif /* FAKE_THREADS */
2825 #endif  /* NETWARE */
2826 #endif /* USE_ITHREADS */
2827
2828 #if defined(WIN32)
2829 #  include "win32.h"
2830 #endif
2831
2832 #ifdef NETWARE
2833 #  include "netware.h"
2834 #endif
2835
2836 #define STATUS_UNIX     PL_statusvalue
2837 #ifdef VMS
2838 #   define STATUS_NATIVE        PL_statusvalue_vms
2839 /*
2840  * vaxc$errno is only guaranteed to be valid if errno == EVMSERR, otherwise
2841  * its contents can not be trusted.  Unfortunately, Perl seems to check
2842  * it on exit, so it when PL_statusvalue_vms is updated, vaxc$errno should
2843  * be updated also.
2844  */
2845 #  include <stsdef.h>
2846 #  include <ssdef.h>
2847 /* Presume this because if VMS changes it, it will require a new
2848  * set of APIs for waiting on children for binary compatibility.
2849  */
2850 #  define child_offset_bits (8)
2851 #  ifndef C_FAC_POSIX
2852 #  define C_FAC_POSIX 0x35A000
2853 #  endif
2854
2855 /*  STATUS_EXIT - validates and returns a NATIVE exit status code for the
2856  * platform from the existing UNIX or Native status values.
2857  */
2858
2859 #   define STATUS_EXIT \
2860         (((I32)PL_statusvalue_vms == -1 ? SS$_ABORT : PL_statusvalue_vms) | \
2861            (VMSISH_HUSHED ? STS$M_INHIB_MSG : 0))
2862
2863
2864 /* STATUS_NATIVE_CHILD_SET - Calculate UNIX status that matches the child
2865  * exit code and shifts the UNIX value over the correct number of bits to
2866  * be a child status.  Usually the number of bits is 8, but that could be
2867  * platform dependent.  The NATIVE status code is presumed to have either
2868  * from a child process.
2869  */
2870
2871 /* This is complicated.  The child processes return a true native VMS
2872    status which must be saved.  But there is an assumption in Perl that
2873    the UNIX child status has some relationship to errno values, so
2874    Perl tries to translate it to text in some of the tests.  
2875    In order to get the string translation correct, for the error, errno
2876    must be EVMSERR, but that generates a different text message
2877    than what the test programs are expecting.  So an errno value must
2878    be derived from the native status value when an error occurs.
2879    That will hide the true native status message.  With this version of
2880    perl, the true native child status can always be retrieved so that
2881    is not a problem.  But in this case, Pl_statusvalue and errno may
2882    have different values in them.
2883  */
2884
2885 #   define STATUS_NATIVE_CHILD_SET(n) \
2886         STMT_START {                                                    \
2887             I32 evalue = (I32)n;                                        \
2888             if (evalue == EVMSERR) {                                    \
2889               PL_statusvalue_vms = vaxc$errno;                          \
2890               PL_statusvalue = evalue;                                  \
2891             } else {                                                    \
2892               PL_statusvalue_vms = evalue;                              \
2893               if (evalue == -1) {                                       \
2894                 PL_statusvalue = -1;                                    \
2895                 PL_statusvalue_vms = SS$_ABORT; /* Should not happen */ \
2896               } else                                                    \
2897                 PL_statusvalue = Perl_vms_status_to_unix(evalue, 1);    \
2898               set_vaxc_errno(evalue);                                   \
2899               if ((PL_statusvalue_vms & C_FAC_POSIX) == C_FAC_POSIX)    \
2900                   set_errno(EVMSERR);                                   \
2901               else set_errno(Perl_vms_status_to_unix(evalue, 0));       \
2902               PL_statusvalue = PL_statusvalue << child_offset_bits;     \
2903             }                                                           \
2904         } STMT_END
2905
2906 #   ifdef VMSISH_STATUS
2907 #       define STATUS_CURRENT   (VMSISH_STATUS ? STATUS_NATIVE : STATUS_UNIX)
2908 #   else
2909 #       define STATUS_CURRENT   STATUS_UNIX
2910 #   endif
2911
2912   /* STATUS_UNIX_SET - takes a UNIX/POSIX errno value and attempts to update
2913    * the NATIVE status to an equivalent value.  Can not be used to translate
2914    * exit code values as exit code values are not guaranteed to have any
2915    * relationship at all to errno values.
2916    * This is used when Perl is forcing errno to have a specific value.
2917    */
2918 #   define STATUS_UNIX_SET(n)                           \
2919         STMT_START {                                    \
2920             I32 evalue = (I32)n;                        \
2921             PL_statusvalue = evalue;                    \
2922             if (PL_statusvalue != -1) {                 \
2923                 if (PL_statusvalue != EVMSERR) {        \
2924                   PL_statusvalue &= 0xFFFF;             \
2925                   if (MY_POSIX_EXIT)                    \
2926                     PL_statusvalue_vms=PL_statusvalue ? SS$_ABORT : SS$_NORMAL;\
2927                   else PL_statusvalue_vms = Perl_unix_status_to_vms(evalue); \
2928                 }                                       \
2929                 else {                                  \
2930                   PL_statusvalue_vms = vaxc$errno;      \
2931                 }                                       \
2932             }                                           \
2933             else PL_statusvalue_vms = SS$_ABORT;        \
2934             set_vaxc_errno(PL_statusvalue_vms);         \
2935         } STMT_END
2936
2937   /* STATUS_UNIX_EXIT_SET - Takes a UNIX/POSIX exit code and sets
2938    * the NATIVE error status based on it.
2939    *
2940    * When in the default mode to comply with the Perl VMS documentation,
2941    * 0 is a success and any other code sets the NATIVE status to a failure
2942    * code of SS$_ABORT.
2943    *
2944    * In the new POSIX EXIT mode, native status will be set so that the
2945    * actual exit code will can be retrieved by the calling program or
2946    * shell.
2947    *
2948    * If the exit code is not clearly a UNIX parent or child exit status,
2949    * it will be passed through as a VMS status.
2950    */
2951
2952 #   define STATUS_UNIX_EXIT_SET(n)                      \
2953         STMT_START {                                    \
2954             I32 evalue = (I32)n;                        \
2955             PL_statusvalue = evalue;                    \
2956             if (MY_POSIX_EXIT) { \
2957               if (evalue <= 0xFF00) {           \
2958                   if (evalue > 0xFF)                    \
2959                     evalue = (evalue >> child_offset_bits) & 0xFF; \
2960                   PL_statusvalue_vms =          \
2961                     (C_FAC_POSIX | (evalue << 3 ) |     \
2962                     ((evalue == 1) ? (STS$K_ERROR | STS$M_INHIB_MSG) : 1)); \
2963               } else /* forgive them Perl, for they have sinned */ \
2964                 PL_statusvalue_vms = evalue; \
2965             } else { \
2966               if (evalue == 0)                  \
2967                 PL_statusvalue_vms = SS$_NORMAL;        \
2968               else if (evalue <= 0xFF00) \
2969                 PL_statusvalue_vms = SS$_ABORT; \
2970               else { /* forgive them Perl, for they have sinned */ \
2971                   if (evalue != EVMSERR) PL_statusvalue_vms = evalue; \
2972                   else PL_statusvalue_vms = vaxc$errno; \
2973                   /* And obviously used a VMS status value instead of UNIX */ \
2974                   PL_statusvalue = EVMSERR;             \
2975               } \
2976               set_vaxc_errno(PL_statusvalue_vms);       \
2977             }                                           \
2978         } STMT_END
2979
2980
2981   /* STATUS_EXIT_SET - Takes a NATIVE/UNIX/POSIX exit code
2982    * and sets the NATIVE error status based on it.  This special case
2983    * is needed to maintain compatibility with past VMS behavior.
2984    *
2985    * In the default mode on VMS, this number is passed through as
2986    * both the NATIVE and UNIX status.  Which makes it different
2987    * that the STATUS_UNIX_EXIT_SET.
2988    *
2989    * In the new POSIX EXIT mode, native status will be set so that the
2990    * actual exit code will can be retrieved by the calling program or
2991    * shell.
2992    *
2993    * A POSIX exit code is from 0 to 255.  If the exit code is higher
2994    * than this, it needs to be assumed that it is a VMS exit code and
2995    * passed through.
2996    */
2997
2998 #   define STATUS_EXIT_SET(n)                           \
2999         STMT_START {                                    \
3000             I32 evalue = (I32)n;                        \
3001             PL_statusvalue = evalue;                    \
3002             if (MY_POSIX_EXIT)                          \
3003                 if (evalue > 255) PL_statusvalue_vms = evalue; else {   \
3004                   PL_statusvalue_vms = \
3005                     (C_FAC_POSIX | (evalue << 3 ) |     \
3006                      ((evalue == 1) ? (STS$K_ERROR | STS$M_INHIB_MSG) : 1));} \
3007             else                                        \
3008                 PL_statusvalue_vms = evalue ? evalue : SS$_NORMAL; \
3009             set_vaxc_errno(PL_statusvalue_vms);         \
3010         } STMT_END
3011
3012
3013  /* This macro forces a success status */
3014 #   define STATUS_ALL_SUCCESS   \
3015         (PL_statusvalue = 0, PL_statusvalue_vms = SS$_NORMAL)
3016
3017  /* This macro forces a failure status */
3018 #   define STATUS_ALL_FAILURE   (PL_statusvalue = 1, \
3019      vaxc$errno = PL_statusvalue_vms = MY_POSIX_EXIT ? \
3020         (C_FAC_POSIX | (1 << 3) | STS$K_ERROR | STS$M_INHIB_MSG) : SS$_ABORT)
3021
3022 #else
3023 #   define STATUS_NATIVE        PL_statusvalue_posix
3024 #   if defined(WCOREDUMP)
3025 #       define STATUS_NATIVE_CHILD_SET(n)                  \
3026             STMT_START {                                   \
3027                 PL_statusvalue_posix = (n);                \
3028                 if (PL_statusvalue_posix == -1)            \
3029                     PL_statusvalue = -1;                   \
3030                 else {                                     \
3031                     PL_statusvalue =                       \
3032                         (WIFEXITED(PL_statusvalue_posix) ? (WEXITSTATUS(PL_statusvalue_posix) << 8) : 0) |  \
3033                         (WIFSIGNALED(PL_statusvalue_posix) ? (WTERMSIG(PL_statusvalue_posix) & 0x7F) : 0) | \
3034                         (WIFSIGNALED(PL_statusvalue_posix) && WCOREDUMP(PL_statusvalue_posix) ? 0x80 : 0);  \
3035                 }                                          \
3036             } STMT_END
3037 #   elif defined(WIFEXITED)
3038 #       define STATUS_NATIVE_CHILD_SET(n)                  \
3039             STMT_START {                                   \
3040                 PL_statusvalue_posix = (n);                \
3041                 if (PL_statusvalue_posix == -1)            \
3042                     PL_statusvalue = -1;                   \
3043                 else {                                     \
3044                     PL_statusvalue =                       \
3045                         (WIFEXITED(PL_statusvalue_posix) ? (WEXITSTATUS(PL_statusvalue_posix) << 8) : 0) |  \
3046                         (WIFSIGNALED(PL_statusvalue_posix) ? (WTERMSIG(PL_statusvalue_posix) & 0x7F) : 0);  \
3047                 }                                          \
3048             } STMT_END
3049 #   else
3050 #       define STATUS_NATIVE_CHILD_SET(n)                  \
3051             STMT_START {                                   \
3052                 PL_statusvalue_posix = (n);                \
3053                 if (PL_statusvalue_posix == -1)            \
3054                     PL_statusvalue = -1;                   \
3055                 else {                                     \
3056                     PL_statusvalue =                       \
3057                         PL_statusvalue_posix & 0xFFFF;     \
3058                 }                                          \
3059             } STMT_END
3060 #   endif
3061 #   define STATUS_UNIX_SET(n)           \
3062         STMT_START {                    \
3063             PL_statusvalue = (n);               \
3064             if (PL_statusvalue != -1)   \
3065                 PL_statusvalue &= 0xFFFF;       \
3066         } STMT_END
3067 #   define STATUS_UNIX_EXIT_SET(n) STATUS_UNIX_SET(n)
3068 #   define STATUS_EXIT_SET(n) STATUS_UNIX_SET(n)
3069 #   define STATUS_CURRENT STATUS_UNIX
3070 #   define STATUS_EXIT STATUS_UNIX
3071 #   define STATUS_ALL_SUCCESS   (PL_statusvalue = 0, PL_statusvalue_posix = 0)
3072 #   define STATUS_ALL_FAILURE   (PL_statusvalue = 1, PL_statusvalue_posix = 1)
3073 #endif
3074
3075 /* flags in PL_exit_flags for nature of exit() */
3076 #define PERL_EXIT_EXPECTED      0x01
3077 #define PERL_EXIT_DESTRUCT_END  0x02  /* Run END in perl_destruct */
3078
3079 #ifndef MEMBER_TO_FPTR
3080 #  define MEMBER_TO_FPTR(name)          name
3081 #endif
3082
3083 #ifndef PERL_CORE
3084 /* format to use for version numbers in file/directory names */
3085 /* XXX move to Configure? */
3086 /* This was only ever used for the current version, and that can be done at
3087    compile time, as PERL_FS_VERSION, so should we just delete it?  */
3088 #  ifndef PERL_FS_VER_FMT
3089 #    define PERL_FS_VER_FMT     "%d.%d.%d"
3090 #  endif
3091 #endif
3092
3093 #ifndef PERL_FS_VERSION
3094 #  define PERL_FS_VERSION       PERL_VERSION_STRING
3095 #endif
3096
3097 /* This defines a way to flush all output buffers.  This may be a
3098  * performance issue, so we allow people to disable it.  Also, if
3099  * we are using stdio, there are broken implementations of fflush(NULL)
3100  * out there, Solaris being the most prominent.
3101  */
3102 #ifndef PERL_FLUSHALL_FOR_CHILD
3103 # if defined(USE_PERLIO) || defined(FFLUSH_NULL) || defined(USE_SFIO)
3104 #  define PERL_FLUSHALL_FOR_CHILD       PerlIO_flush((PerlIO*)NULL)
3105 # else
3106 #  ifdef FFLUSH_ALL
3107 #   define PERL_FLUSHALL_FOR_CHILD      my_fflush_all()
3108 #  else
3109 #   define PERL_FLUSHALL_FOR_CHILD      NOOP
3110 #  endif
3111 # endif
3112 #endif
3113
3114 #ifndef PERL_WAIT_FOR_CHILDREN
3115 #  define PERL_WAIT_FOR_CHILDREN        NOOP
3116 #endif
3117
3118 /* the traditional thread-unsafe notion of "current interpreter". */
3119 #ifndef PERL_SET_INTERP
3120 #  define PERL_SET_INTERP(i)            (PL_curinterp = (PerlInterpreter*)(i))
3121 #endif
3122
3123 #ifndef PERL_GET_INTERP
3124 #  define PERL_GET_INTERP               (PL_curinterp)
3125 #endif
3126
3127 #if defined(PERL_IMPLICIT_CONTEXT) && !defined(PERL_GET_THX)
3128 #  ifdef MULTIPLICITY
3129 #    define PERL_GET_THX                ((PerlInterpreter *)PERL_GET_CONTEXT)
3130 #  endif
3131 #  define PERL_SET_THX(t)               PERL_SET_CONTEXT(t)
3132 #endif
3133
3134 /* 
3135     This replaces the previous %_ "hack" by the "%p" hacks.
3136     All that is required is that the perl source does not
3137     use "%-p" or "%-<number>p" or "%<number>p" formats.  
3138     These formats will still work in perl code.   
3139     See comments in sv.c for futher details.
3140
3141     Robin Barker 2005-07-14
3142
3143     No longer use %1p for VDf = %vd.  RMB 2007-10-19 
3144 */
3145
3146 #ifndef SVf_
3147 #  define SVf_(n) "-" STRINGIFY(n) "p"
3148 #endif
3149
3150 #ifndef SVf
3151 #  define SVf "-p"
3152 #endif
3153
3154 #ifndef SVf32
3155 #  define SVf32 SVf_(32)
3156 #endif
3157
3158 #ifndef SVf256
3159 #  define SVf256 SVf_(256)
3160 #endif
3161
3162 #define SVfARG(p) ((void*)(p))
3163
3164 #ifdef PERL_CORE
3165 /* not used; but needed for backward compatibilty with XS code? - RMB */ 
3166 #  undef VDf
3167 #else
3168 #  ifndef VDf
3169 #    define VDf "vd"
3170 #  endif
3171 #endif
3172
3173 #ifdef PERL_CORE
3174 /* not used; but needed for backward compatibilty with XS code? - RMB */ 
3175 #  undef UVf
3176 #else
3177 #  ifndef UVf
3178 #    define UVf UVuf
3179 #  endif
3180 #endif
3181
3182 #ifdef HASATTRIBUTE_DEPRECATED
3183 #  define __attribute__deprecated__         __attribute__((deprecated))
3184 #endif
3185 #ifdef HASATTRIBUTE_FORMAT
3186 #  define __attribute__format__(x,y,z)      __attribute__((format(x,y,z)))
3187 #endif
3188 #ifdef HASATTRIBUTE_MALLOC
3189 #  define __attribute__malloc__             __attribute__((__malloc__))
3190 #endif
3191 #ifdef HASATTRIBUTE_NONNULL
3192 #  define __attribute__nonnull__(a)         __attribute__((nonnull(a)))
3193 #endif
3194 #ifdef HASATTRIBUTE_NORETURN
3195 #  define __attribute__noreturn__           __attribute__((noreturn))
3196 #endif
3197 #ifdef HASATTRIBUTE_PURE
3198 #  define __attribute__pure__               __attribute__((pure))
3199 #endif
3200 #ifdef HASATTRIBUTE_UNUSED
3201 #  define __attribute__unused__             __attribute__((unused))
3202 #endif
3203 #ifdef HASATTRIBUTE_WARN_UNUSED_RESULT
3204 #  define __attribute__warn_unused_result__ __attribute__((warn_unused_result))
3205 #endif
3206
3207 /* If we haven't defined the attributes yet, define them to blank. */
3208 #ifndef __attribute__deprecated__
3209 #  define __attribute__deprecated__
3210 #endif
3211 #ifndef __attribute__format__
3212 #  define __attribute__format__(x,y,z)
3213 #endif
3214 #ifndef __attribute__malloc__
3215 #  define __attribute__malloc__
3216 #endif
3217 #ifndef __attribute__nonnull__
3218 #  define __attribute__nonnull__(a)
3219 #endif
3220 #ifndef __attribute__noreturn__
3221 #  define __attribute__noreturn__
3222 #endif
3223 #ifndef __attribute__pure__
3224 #  define __attribute__pure__
3225 #endif
3226 #ifndef __attribute__unused__
3227 #  define __attribute__unused__
3228 #endif
3229 #ifndef __attribute__warn_unused_result__
3230 #  define __attribute__warn_unused_result__
3231 #endif
3232
3233 /* For functions that are marked as __attribute__noreturn__, it's not
3234    appropriate to call return.  In either case, include the lint directive.
3235  */
3236 #ifdef HASATTRIBUTE_NORETURN
3237 #  define NORETURN_FUNCTION_END /* NOTREACHED */
3238 #else
3239 #  define NORETURN_FUNCTION_END /* NOTREACHED */ return 0
3240 #endif
3241
3242 /* Some OS warn on NULL format to printf */
3243 #ifdef PRINTF_FORMAT_NULL_OK
3244 #  define __attribute__format__null_ok__(x,y,z)  __attribute__format__(x,y,z)
3245 #else
3246 #  define __attribute__format__null_ok__(x,y,z)  
3247 #endif
3248
3249 #ifdef HAS_BUILTIN_EXPECT
3250 #  define EXPECT(expr,val)                  __builtin_expect(expr,val)
3251 #else
3252 #  define EXPECT(expr,val)                  (expr)
3253 #endif
3254 #define LIKELY(cond)                        EXPECT(cond,1)
3255 #define UNLIKELY(cond)                      EXPECT(cond,0)
3256 #ifdef HAS_BUILTIN_CHOOSE_EXPR
3257 /* placeholder */
3258 #endif
3259
3260 /* Some unistd.h's give a prototype for pause() even though
3261    HAS_PAUSE ends up undefined.  This causes the #define
3262    below to be rejected by the compiler.  Sigh.
3263 */
3264 #ifdef HAS_PAUSE
3265 #define Pause   pause
3266 #else
3267 #define Pause() sleep((32767<<16)+32767)
3268 #endif
3269
3270 #ifndef IOCPARM_LEN
3271 #   ifdef IOCPARM_MASK
3272         /* on BSDish systems we're safe */
3273 #       define IOCPARM_LEN(x)  (((x) >> 16) & IOCPARM_MASK)
3274 #   else
3275 #       if defined(_IOC_SIZE) && defined(__GLIBC__)
3276         /* on Linux systems we're safe; except when we're not [perl #38223] */
3277 #           define IOCPARM_LEN(x) (_IOC_SIZE(x) < 256 ? 256 : _IOC_SIZE(x))
3278 #       else
3279         /* otherwise guess at what's safe */
3280 #           define IOCPARM_LEN(x)       256
3281 #       endif
3282 #   endif
3283 #endif
3284
3285 #if defined(__CYGWIN__)
3286 /* USEMYBINMODE
3287  *   This symbol, if defined, indicates that the program should
3288  *   use the routine my_binmode(FILE *fp, char iotype, int mode) to insure
3289  *   that a file is in "binary" mode -- that is, that no translation
3290  *   of bytes occurs on read or write operations.
3291  */
3292 #  define USEMYBINMODE /**/
3293 #  include <io.h> /* for setmode() prototype */
3294 #  define my_binmode(fp, iotype, mode) \
3295             (PerlLIO_setmode(fileno(fp), mode) != -1 ? TRUE : FALSE)
3296 #endif
3297
3298 #ifdef __CYGWIN__
3299 void init_os_extras(void);
3300 #endif
3301
3302 #ifdef UNION_ANY_DEFINITION
3303 UNION_ANY_DEFINITION;
3304 #else
3305 union any {
3306     void*       any_ptr;
3307     I32         any_i32;
3308     IV          any_iv;
3309     long        any_long;
3310     bool        any_bool;
3311     void        (*any_dptr) (void*);
3312     void        (*any_dxptr) (pTHX_ void*);
3313 };
3314 #endif
3315
3316 typedef I32 (*filter_t) (pTHX_ int, SV *, int);
3317
3318 #define FILTER_READ(idx, sv, len)  filter_read(idx, sv, len)
3319 #define FILTER_DATA(idx) \
3320             (PL_parser ? AvARRAY(PL_parser->rsfp_filters)[idx] : NULL)
3321 #define FILTER_ISREADER(idx) \
3322             (PL_parser && PL_parser->rsfp_filters \
3323                 && idx >= AvFILLp(PL_parser->rsfp_filters))
3324 #define PERL_FILTER_EXISTS(i) \
3325             (PL_parser && PL_parser->rsfp_filters \
3326                 && (i) <= av_len(PL_parser->rsfp_filters))
3327
3328 #if defined(_AIX) && !defined(_AIX43)
3329 #if defined(USE_REENTRANT) || defined(_REENTRANT) || defined(_THREAD_SAFE)
3330 /* We cannot include <crypt.h> to get the struct crypt_data
3331  * because of setkey prototype problems when threading */
3332 typedef        struct crypt_data {     /* straight from /usr/include/crypt.h */
3333     /* From OSF, Not needed in AIX
3334        char C[28], D[28];
3335     */
3336     char E[48];
3337     char KS[16][48];
3338     char block[66];
3339     char iobuf[16];
3340 } CRYPTD;
3341 #endif /* threading */
3342 #endif /* AIX */
3343
3344 #if !defined(OS2)
3345 #  include "iperlsys.h"
3346 #endif
3347
3348 #ifdef __LIBCATAMOUNT__
3349 #undef HAS_PASSWD  /* unixish.h but not unixish enough. */ 
3350 #undef HAS_GROUP
3351 #define FAKE_BIT_BUCKET
3352 #endif
3353
3354 /* [perl #22371] Algorimic Complexity Attack on Perl 5.6.1, 5.8.0.
3355  * Note that the USE_HASH_SEED and USE_HASH_SEED_EXPLICIT are *NOT*
3356  * defined by Configure, despite their names being similar to the
3357  * other defines like USE_ITHREADS.  Configure in fact knows nothing
3358  * about the randomised hashes.  Therefore to enable/disable the hash
3359  * randomisation defines use the Configure -Accflags=... instead. */
3360 #if !defined(NO_HASH_SEED) && !defined(USE_HASH_SEED) && !defined(USE_HASH_SEED_EXPLICIT)
3361 #  define USE_HASH_SEED
3362 #endif
3363
3364 /* Win32 defines a type 'WORD' in windef.h. This conflicts with the enumerator
3365  * 'WORD' defined in perly.h. The yytokentype enum is only a debugging aid, so
3366  * it's not really needed.
3367  */
3368 #if defined(WIN32)
3369 #  define YYTOKENTYPE
3370 #endif
3371 #include "perly.h"
3372
3373 #ifdef PERL_MAD
3374 struct nexttoken {
3375     YYSTYPE next_val;   /* value of next token, if any */
3376     I32 next_type;      /* type of next token */
3377     MADPROP *next_mad;  /* everything else about that token */
3378 };
3379 #endif
3380
3381 /* macros to define bit-fields in structs. */
3382 #ifndef PERL_BITFIELD8
3383 #  define PERL_BITFIELD8 unsigned
3384 #endif
3385 #ifndef PERL_BITFIELD16
3386 #  define PERL_BITFIELD16 unsigned
3387 #endif
3388 #ifndef PERL_BITFIELD32
3389 #  define PERL_BITFIELD32 unsigned
3390 #endif
3391
3392 #include "sv.h"
3393 #include "regexp.h"
3394 #include "util.h"
3395 #include "form.h"
3396 #include "gv.h"
3397 #include "pad.h"
3398 #include "cv.h"
3399 #include "opnames.h"
3400 #include "op.h"
3401 #include "hv.h"
3402 #include "cop.h"
3403 #include "av.h"
3404 #include "mg.h"
3405 #include "scope.h"
3406 #include "warnings.h"
3407 #include "utf8.h"
3408
3409 /* defined in sv.c, but also used in [ach]v.c */
3410 #undef _XPV_ALLOCATED_HEAD
3411 #undef _XPV_HEAD
3412 #undef _XPVMG_HEAD
3413 #undef _XPVCV_COMMON
3414
3415 typedef struct _sublex_info SUBLEXINFO;
3416 struct _sublex_info {
3417     U8 super_state;     /* lexer state to save */
3418     U16 sub_inwhat;     /* "lex_inwhat" to use */
3419     OP *sub_op;         /* "lex_op" to use */
3420     char *super_bufptr; /* PL_parser->bufptr that was */
3421     char *super_bufend; /* PL_parser->bufend that was */
3422 };
3423
3424 #include "parser.h"
3425
3426 typedef struct magic_state MGS; /* struct magic_state defined in mg.c */
3427
3428 struct scan_data_t;             /* Used in S_* functions in regcomp.c */
3429 struct regnode_charclass_class; /* Used in S_* functions in regcomp.c */
3430
3431 /* Keep next first in this structure, because sv_free_arenas take
3432    advantage of this to share code between the pte arenas and the SV
3433    body arenas  */
3434 struct ptr_tbl_ent {
3435     struct ptr_tbl_ent*         next;
3436     const void*                 oldval;
3437     void*                       newval;
3438 };
3439
3440 struct ptr_tbl {
3441     struct ptr_tbl_ent**        tbl_ary;
3442     UV                          tbl_max;
3443     UV                          tbl_items;
3444 };
3445
3446 #if defined(iAPX286) || defined(M_I286) || defined(I80286)
3447 #   define I286
3448 #endif
3449
3450 #if defined(htonl) && !defined(HAS_HTONL)
3451 #define HAS_HTONL
3452 #endif
3453 #if defined(htons) && !defined(HAS_HTONS)
3454 #define HAS_HTONS
3455 #endif
3456 #if defined(ntohl) && !defined(HAS_NTOHL)
3457 #define HAS_NTOHL
3458 #endif
3459 #if defined(ntohs) && !defined(HAS_NTOHS)
3460 #define HAS_NTOHS
3461 #endif
3462 #ifndef HAS_HTONL
3463 #if (BYTEORDER & 0xffff) != 0x4321
3464 #define HAS_HTONS
3465 #define HAS_HTONL
3466 #define HAS_NTOHS
3467 #define HAS_NTOHL
3468 #define MYSWAP
3469 #define htons my_swap
3470 #define htonl my_htonl
3471 #define ntohs my_swap
3472 #define ntohl my_ntohl
3473 #endif
3474 #else
3475 #if (BYTEORDER & 0xffff) == 0x4321
3476 #undef HAS_HTONS
3477 #undef HAS_HTONL
3478 #undef HAS_NTOHS
3479 #undef HAS_NTOHL
3480 #endif
3481 #endif
3482
3483 /*
3484  * Little-endian byte order functions - 'v' for 'VAX', or 'reVerse'.
3485  * -DWS
3486  */
3487 #if BYTEORDER != 0x1234
3488 # define HAS_VTOHL
3489 # define HAS_VTOHS
3490 # define HAS_HTOVL
3491 # define HAS_HTOVS
3492 # if BYTEORDER == 0x4321 || BYTEORDER == 0x87654321
3493 #  define vtohl(x)      ((((x)&0xFF)<<24)       \
3494                         +(((x)>>24)&0xFF)       \
3495                         +(((x)&0x0000FF00)<<8)  \
3496                         +(((x)&0x00FF0000)>>8)  )
3497 #  define vtohs(x)      ((((x)&0xFF)<<8) + (((x)>>8)&0xFF))
3498 #  define htovl(x)      vtohl(x)
3499 #  define htovs(x)      vtohs(x)
3500 # endif
3501         /* otherwise default to functions in util.c */
3502 #ifndef htovs
3503 short htovs(short n);
3504 short vtohs(short n);
3505 long htovl(long n);
3506 long vtohl(long n);
3507 #endif
3508 #endif
3509
3510 /* *MAX Plus 1. A floating point value.
3511    Hopefully expressed in a way that dodgy floating point can't mess up.
3512    >> 2 rather than 1, so that value is safely less than I32_MAX after 1
3513    is added to it
3514    May find that some broken compiler will want the value cast to I32.
3515    [after the shift, as signed >> may not be as secure as unsigned >>]
3516 */
3517 #define I32_MAX_P1 (2.0 * (1 + (((U32)I32_MAX) >> 1)))
3518 #define U32_MAX_P1 (4.0 * (1 + ((U32_MAX) >> 2)))
3519 /* For compilers that can't correctly cast NVs over 0x7FFFFFFF (or
3520    0x7FFFFFFFFFFFFFFF) to an unsigned integer. In the future, sizeof(UV)
3521    may be greater than sizeof(IV), so don't assume that half max UV is max IV.
3522 */
3523 #define U32_MAX_P1_HALF (2.0 * (1 + ((U32_MAX) >> 2)))
3524
3525 #define UV_MAX_P1 (4.0 * (1 + ((UV_MAX) >> 2)))
3526 #define IV_MAX_P1 (2.0 * (1 + (((UV)IV_MAX) >> 1)))
3527 #define UV_MAX_P1_HALF (2.0 * (1 + ((UV_MAX) >> 2)))
3528
3529 /* This may look like unnecessary jumping through hoops, but converting
3530    out of range floating point values to integers *is* undefined behaviour,
3531    and it is starting to bite.
3532 */
3533 #ifndef CAST_INLINE
3534 #define I_32(what) (cast_i32((NV)(what)))
3535 #define U_32(what) (cast_ulong((NV)(what)))
3536 #define I_V(what) (cast_iv((NV)(what)))
3537 #define U_V(what) (cast_uv((NV)(what)))
3538 #else
3539 #define I_32(n) ((n) < I32_MAX_P1 ? ((n) < I32_MIN ? I32_MIN : (I32) (n)) \
3540                   : ((n) < U32_MAX_P1 ? (I32)(U32) (n) \
3541                      : ((n) > 0 ? (I32) U32_MAX : 0 /* NaN */)))
3542 #define U_32(n) ((n) < 0.0 ? ((n) < I32_MIN ? (UV) I32_MIN : (U32)(I32) (n)) \
3543                   : ((n) < U32_MAX_P1 ? (U32) (n) \
3544                      : ((n) > 0 ? U32_MAX : 0 /* NaN */)))
3545 #define I_V(n) ((n) < IV_MAX_P1 ? ((n) < IV_MIN ? IV_MIN : (IV) (n)) \
3546                   : ((n) < UV_MAX_P1 ? (IV)(UV) (n) \
3547                      : ((n) > 0 ? (IV)UV_MAX : 0 /* NaN */)))
3548 #define U_V(n) ((n) < 0.0 ? ((n) < IV_MIN ? (UV) IV_MIN : (UV)(IV) (n)) \
3549                   : ((n) < UV_MAX_P1 ? (UV) (n) \
3550                      : ((n) > 0 ? UV_MAX : 0 /* NaN */)))
3551 #endif
3552
3553 #define U_S(what) ((U16)U_32(what))
3554 #define U_I(what) ((unsigned int)U_32(what))
3555 #define U_L(what) U_32(what)
3556
3557 #ifdef HAS_SIGNBIT
3558 #  define Perl_signbit signbit
3559 #endif
3560
3561 /* These do not care about the fractional part, only about the range. */
3562 #define NV_WITHIN_IV(nv) (I_V(nv) >= IV_MIN && I_V(nv) <= IV_MAX)
3563 #define NV_WITHIN_UV(nv) ((nv)>=0.0 && U_V(nv) >= UV_MIN && U_V(nv) <= UV_MAX)
3564
3565 /* Used with UV/IV arguments: */
3566                                         /* XXXX: need to speed it up */
3567 #define CLUMP_2UV(iv)   ((iv) < 0 ? 0 : (UV)(iv))
3568 #define CLUMP_2IV(uv)   ((uv) > (UV)IV_MAX ? IV_MAX : (IV)(uv))
3569
3570 #ifndef MAXSYSFD
3571 #   define MAXSYSFD 2
3572 #endif
3573
3574 #ifndef __cplusplus
3575 #if !(defined(UNDER_CE) || defined(SYMBIAN))
3576 Uid_t getuid (void);
3577 Uid_t geteuid (void);
3578 Gid_t getgid (void);
3579 Gid_t getegid (void);
3580 #endif
3581 #endif
3582
3583 #ifndef Perl_debug_log
3584 #  define Perl_debug_log        PerlIO_stderr()
3585 #endif
3586
3587 #ifndef Perl_error_log
3588 #  define Perl_error_log        (PL_stderrgv                    \
3589                                  && isGV(PL_stderrgv)           \
3590                                  && GvIOp(PL_stderrgv)          \
3591                                  && IoOFP(GvIOp(PL_stderrgv))   \
3592                                  ? IoOFP(GvIOp(PL_stderrgv))    \
3593                                  : PerlIO_stderr())
3594 #endif
3595
3596
3597 #define DEBUG_p_FLAG            0x00000001 /*      1 */
3598 #define DEBUG_s_FLAG            0x00000002 /*      2 */
3599 #define DEBUG_l_FLAG            0x00000004 /*      4 */
3600 #define DEBUG_t_FLAG            0x00000008 /*      8 */
3601 #define DEBUG_o_FLAG            0x00000010 /*     16 */
3602 #define DEBUG_c_FLAG            0x00000020 /*     32 */
3603 #define DEBUG_P_FLAG            0x00000040 /*     64 */
3604 #define DEBUG_m_FLAG            0x00000080 /*    128 */
3605 #define DEBUG_f_FLAG            0x00000100 /*    256 */
3606 #define DEBUG_r_FLAG            0x00000200 /*    512 */
3607 #define DEBUG_x_FLAG            0x00000400 /*   1024 */
3608 #define DEBUG_u_FLAG            0x00000800 /*   2048 */
3609 /* U is reserved for Unofficial, exploratory hacking */
3610 #define DEBUG_U_FLAG            0x00001000 /*   4096 */
3611 #define DEBUG_H_FLAG            0x00002000 /*   8192 */
3612 #define DEBUG_X_FLAG            0x00004000 /*  16384 */
3613 #define DEBUG_D_FLAG            0x00008000 /*  32768 */
3614 /* 0x00010000 is unused, used to be S */
3615 #define DEBUG_T_FLAG            0x00020000 /* 131072 */
3616 #define DEBUG_R_FLAG            0x00040000 /* 262144 */
3617 #define DEBUG_J_FLAG            0x00080000 /* 524288 */
3618 #define DEBUG_v_FLAG            0x00100000 /*1048576 */
3619 #define DEBUG_C_FLAG            0x00200000 /*2097152 */
3620 #define DEBUG_A_FLAG            0x00400000 /*4194304 */
3621 #define DEBUG_q_FLAG            0x00800000 /*8388608 */
3622 #define DEBUG_MASK              0x00FEEFFF /* mask of all the standard flags */
3623
3624 #define DEBUG_DB_RECURSE_FLAG   0x40000000
3625 #define DEBUG_TOP_FLAG          0x80000000 /* XXX what's this for ??? Signal
3626                                               that something was done? */
3627
3628 #  define DEBUG_p_TEST_ (PL_debug & DEBUG_p_FLAG)
3629 #  define DEBUG_s_TEST_ (PL_debug & DEBUG_s_FLAG)
3630 #  define DEBUG_l_TEST_ (PL_debug & DEBUG_l_FLAG)
3631 #  define DEBUG_t_TEST_ (PL_debug & DEBUG_t_FLAG)
3632 #  define DEBUG_o_TEST_ (PL_debug & DEBUG_o_FLAG)
3633 #  define DEBUG_c_TEST_ (PL_debug & DEBUG_c_FLAG)
3634 #  define DEBUG_P_TEST_ (PL_debug & DEBUG_P_FLAG)
3635 #  define DEBUG_m_TEST_ (PL_debug & DEBUG_m_FLAG)
3636 #  define DEBUG_f_TEST_ (PL_debug & DEBUG_f_FLAG)
3637 #  define DEBUG_r_TEST_ (PL_debug & DEBUG_r_FLAG)
3638 #  define DEBUG_x_TEST_ (PL_debug & DEBUG_x_FLAG)
3639 #  define DEBUG_u_TEST_ (PL_debug & DEBUG_u_FLAG)
3640 #  define DEBUG_U_TEST_ (PL_debug & DEBUG_U_FLAG)
3641 #  define DEBUG_H_TEST_ (PL_debug & DEBUG_H_FLAG)
3642 #  define DEBUG_X_TEST_ (PL_debug & DEBUG_X_FLAG)
3643 #  define DEBUG_D_TEST_ (PL_debug & DEBUG_D_FLAG)
3644 #  define DEBUG_T_TEST_ (PL_debug & DEBUG_T_FLAG)
3645 #  define DEBUG_R_TEST_ (PL_debug & DEBUG_R_FLAG)
3646 #  define DEBUG_J_TEST_ (PL_debug & DEBUG_J_FLAG)
3647 #  define DEBUG_v_TEST_ (PL_debug & DEBUG_v_FLAG)
3648 #  define DEBUG_C_TEST_ (PL_debug & DEBUG_C_FLAG)
3649 #  define DEBUG_A_TEST_ (PL_debug & DEBUG_A_FLAG)
3650 #  define DEBUG_q_TEST_ (PL_debug & DEBUG_q_FLAG)
3651 #  define DEBUG_Xv_TEST_ (DEBUG_X_TEST_ && DEBUG_v_TEST_)
3652 #  define DEBUG_Uv_TEST_ (DEBUG_U_TEST_ && DEBUG_v_TEST_)
3653
3654 #ifdef DEBUGGING
3655
3656 #  define DEBUG_p_TEST DEBUG_p_TEST_
3657 #  define DEBUG_s_TEST DEBUG_s_TEST_
3658 #  define DEBUG_l_TEST DEBUG_l_TEST_
3659 #  define DEBUG_t_TEST DEBUG_t_TEST_
3660 #  define DEBUG_o_TEST DEBUG_o_TEST_
3661 #  define DEBUG_c_TEST DEBUG_c_TEST_
3662 #  define DEBUG_P_TEST DEBUG_P_TEST_
3663 #  define DEBUG_m_TEST DEBUG_m_TEST_
3664 #  define DEBUG_f_TEST DEBUG_f_TEST_
3665 #  define DEBUG_r_TEST DEBUG_r_TEST_
3666 #  define DEBUG_x_TEST DEBUG_x_TEST_
3667 #  define DEBUG_u_TEST DEBUG_u_TEST_
3668 #  define DEBUG_U_TEST DEBUG_U_TEST_
3669 #  define DEBUG_H_TEST DEBUG_H_TEST_
3670 #  define DEBUG_X_TEST DEBUG_X_TEST_
3671 #  define DEBUG_D_TEST DEBUG_D_TEST_
3672 #  define DEBUG_T_TEST DEBUG_T_TEST_
3673 #  define DEBUG_R_TEST DEBUG_R_TEST_
3674 #  define DEBUG_J_TEST DEBUG_J_TEST_
3675 #  define DEBUG_v_TEST DEBUG_v_TEST_
3676 #  define DEBUG_C_TEST DEBUG_C_TEST_
3677 #  define DEBUG_A_TEST DEBUG_A_TEST_
3678 #  define DEBUG_q_TEST DEBUG_q_TEST_
3679 #  define DEBUG_Xv_TEST DEBUG_Xv_TEST_
3680 #  define DEBUG_Uv_TEST DEBUG_Uv_TEST_
3681
3682 #  define PERL_DEB(a)                  a
3683 #  define PERL_DEBUG(a) if (PL_debug)  a
3684 #  define DEBUG_p(a) if (DEBUG_p_TEST) a
3685 #  define DEBUG_s(a) if (DEBUG_s_TEST) a
3686 #  define DEBUG_l(a) if (DEBUG_l_TEST) a
3687 #  define DEBUG_t(a) if (DEBUG_t_TEST) a
3688 #  define DEBUG_o(a) if (DEBUG_o_TEST) a
3689 #  define DEBUG_c(a) if (DEBUG_c_TEST) a
3690 #  define DEBUG_P(a) if (DEBUG_P_TEST) a
3691
3692      /* Temporarily turn off memory debugging in case the a
3693       * does memory allocation, either directly or indirectly. */
3694 #  define DEBUG_m(a)  \
3695     STMT_START {                                                        \
3696         if (PERL_GET_INTERP) { dTHX; if (DEBUG_m_TEST) {PL_debug&=~DEBUG_m_FLAG; a; PL_debug|=DEBUG_m_FLAG;} } \
3697     } STMT_END
3698
3699 #  define DEBUG__(t, a) \
3700         STMT_START { \
3701                 if (t) STMT_START {a;} STMT_END; \
3702         } STMT_END
3703
3704 #  define DEBUG_f(a) DEBUG__(DEBUG_f_TEST, a)
3705 #ifndef PERL_EXT_RE_BUILD
3706 #  define DEBUG_r(a) DEBUG__(DEBUG_r_TEST, a)
3707 #else
3708 #  define DEBUG_r(a) STMT_START {a;} STMT_END
3709 #endif /* PERL_EXT_RE_BUILD */
3710 #  define DEBUG_x(a) DEBUG__(DEBUG_x_TEST, a)
3711 #  define DEBUG_u(a) DEBUG__(DEBUG_u_TEST, a)
3712 #  define DEBUG_U(a) DEBUG__(DEBUG_U_TEST, a)
3713 #  define DEBUG_H(a) DEBUG__(DEBUG_H_TEST, a)
3714 #  define DEBUG_X(a) DEBUG__(DEBUG_X_TEST, a)
3715 #  define DEBUG_D(a) DEBUG__(DEBUG_D_TEST, a)
3716 #  define DEBUG_Xv(a) DEBUG__(DEBUG_Xv_TEST, a)
3717 #  define DEBUG_Uv(a) DEBUG__(DEBUG_Uv_TEST, a)
3718
3719 #  define DEBUG_T(a) DEBUG__(DEBUG_T_TEST, a)
3720 #  define DEBUG_R(a) DEBUG__(DEBUG_R_TEST, a)
3721 #  define DEBUG_v(a) DEBUG__(DEBUG_v_TEST, a)
3722 #  define DEBUG_C(a) DEBUG__(DEBUG_C_TEST, a)
3723 #  define DEBUG_A(a) DEBUG__(DEBUG_A_TEST, a)
3724 #  define DEBUG_q(a) DEBUG__(DEBUG_q_TEST, a)
3725
3726 #else /* DEBUGGING */
3727
3728 #  define DEBUG_p_TEST (0)
3729 #  define DEBUG_s_TEST (0)
3730 #  define DEBUG_l_TEST (0)
3731 #  define DEBUG_t_TEST (0)
3732 #  define DEBUG_o_TEST (0)
3733 #  define DEBUG_c_TEST (0)
3734 #  define DEBUG_P_TEST (0)
3735 #  define DEBUG_m_TEST (0)
3736 #  define DEBUG_f_TEST (0)
3737 #  define DEBUG_r_TEST (0)
3738 #  define DEBUG_x_TEST (0)
3739 #  define DEBUG_u_TEST (0)
3740 #  define DEBUG_U_TEST (0)
3741 #  define DEBUG_H_TEST (0)
3742 #  define DEBUG_X_TEST (0)
3743 #  define DEBUG_D_TEST (0)
3744 #  define DEBUG_T_TEST (0)
3745 #  define DEBUG_R_TEST (0)
3746 #  define DEBUG_J_TEST (0)
3747 #  define DEBUG_v_TEST (0)
3748 #  define DEBUG_C_TEST (0)
3749 #  define DEBUG_A_TEST (0)
3750 #  define DEBUG_q_TEST (0)
3751 #  define DEBUG_Xv_TEST (0)
3752 #  define DEBUG_Uv_TEST (0)
3753
3754 #  define PERL_DEB(a)
3755 #  define PERL_DEBUG(a)
3756 #  define DEBUG_p(a)
3757 #  define DEBUG_s(a)
3758 #  define DEBUG_l(a)
3759 #  define DEBUG_t(a)
3760 #  define DEBUG_o(a)
3761 #  define DEBUG_c(a)
3762 #  define DEBUG_P(a)
3763 #  define DEBUG_m(a)
3764 #  define DEBUG_f(a)
3765 #  define DEBUG_r(a)
3766 #  define DEBUG_x(a)
3767 #  define DEBUG_u(a)
3768 #  define DEBUG_U(a)
3769 #  define DEBUG_H(a)
3770 #  define DEBUG_X(a)
3771 #  define DEBUG_D(a)
3772 #  define DEBUG_T(a)
3773 #  define DEBUG_R(a)
3774 #  define DEBUG_v(a)
3775 #  define DEBUG_C(a)
3776 #  define DEBUG_A(a)
3777 #  define DEBUG_q(a)
3778 #  define DEBUG_Xv(a)
3779 #  define DEBUG_Uv(a)
3780 #endif /* DEBUGGING */
3781
3782
3783 #define DEBUG_SCOPE(where) \
3784     DEBUG_l(WITH_THR(Perl_deb(aTHX_ "%s scope %ld at %s:%d\n",  \
3785                     where, (long)PL_scopestack_ix, __FILE__, __LINE__)));
3786
3787
3788
3789
3790 /* These constants should be used in preference to raw characters
3791  * when using magic. Note that some perl guts still assume
3792  * certain character properties of these constants, namely that
3793  * isUPPER() and toLOWER() may do useful mappings.
3794  *
3795  * Update the magic_names table in dump.c when adding/amending these
3796  */
3797
3798 #define PERL_MAGIC_sv             '\0' /* Special scalar variable */
3799 #define PERL_MAGIC_overload       'A' /* %OVERLOAD hash */
3800 #define PERL_MAGIC_overload_elem  'a' /* %OVERLOAD hash element */
3801 #define PERL_MAGIC_overload_table 'c' /* Holds overload table (AMT) on stash */
3802 #define PERL_MAGIC_bm             'B' /* Boyer-Moore (fast string search) */
3803 #define PERL_MAGIC_regdata        'D' /* Regex match position data
3804                                         (@+ and @- vars) */
3805 #define PERL_MAGIC_regdatum       'd' /* Regex match position data element */
3806 #define PERL_MAGIC_env            'E' /* %ENV hash */
3807 #define PERL_MAGIC_envelem        'e' /* %ENV hash element */
3808 #define PERL_MAGIC_fm             'f' /* Formline ('compiled' format) */
3809 #define PERL_MAGIC_regex_global   'g' /* m//g target / study()ed string */
3810 #define PERL_MAGIC_hints          'H' /* %^H hash */
3811 #define PERL_MAGIC_hintselem      'h' /* %^H hash element */
3812 #define PERL_MAGIC_isa            'I' /* @ISA array */
3813 #define PERL_MAGIC_isaelem        'i' /* @ISA array element */
3814 #define PERL_MAGIC_nkeys          'k' /* scalar(keys()) lvalue */
3815 #define PERL_MAGIC_dbfile         'L' /* Debugger %_<filename */
3816 #define PERL_MAGIC_dbline         'l' /* Debugger %_<filename element */
3817 #define PERL_MAGIC_shared         'N' /* Shared between threads */
3818 #define PERL_MAGIC_shared_scalar  'n' /* Shared between threads */
3819 #define PERL_MAGIC_collxfrm       'o' /* Locale transformation */
3820 #define PERL_MAGIC_tied           'P' /* Tied array or hash */
3821 #define PERL_MAGIC_tiedelem       'p' /* Tied array or hash element */
3822 #define PERL_MAGIC_tiedscalar     'q' /* Tied scalar or handle */
3823 #define PERL_MAGIC_qr             'r' /* precompiled qr// regex */
3824 #define PERL_MAGIC_sig            'S' /* %SIG hash */
3825 #define PERL_MAGIC_sigelem        's' /* %SIG hash element */
3826 #define PERL_MAGIC_taint          't' /* Taintedness */
3827 #define PERL_MAGIC_uvar           'U' /* Available for use by extensions */
3828 #define PERL_MAGIC_uvar_elem      'u' /* Reserved for use by extensions */
3829 #define PERL_MAGIC_vec            'v' /* vec() lvalue */
3830 #define PERL_MAGIC_vstring        'V' /* SV was vstring literal */
3831 #define PERL_MAGIC_utf8           'w' /* Cached UTF-8 information */
3832 #define PERL_MAGIC_substr         'x' /* substr() lvalue */
3833 #define PERL_MAGIC_defelem        'y' /* Shadow "foreach" iterator variable /
3834                                         smart parameter vivification */
3835 #define PERL_MAGIC_arylen         '#' /* Array length ($#ary) */
3836 #define PERL_MAGIC_pos            '.' /* pos() lvalue */
3837 #define PERL_MAGIC_backref        '<' /* for weak ref data */
3838 #define PERL_MAGIC_symtab         ':' /* extra data for symbol tables */
3839 #define PERL_MAGIC_rhash          '%' /* extra data for restricted hashes */
3840 #define PERL_MAGIC_arylen_p       '@' /* to move arylen out of XPVAV */
3841 #define PERL_MAGIC_ext            '~' /* Available for use by extensions */
3842
3843 #if defined(DEBUGGING) && defined(I_ASSERT)
3844 #  include <assert.h>
3845 #endif
3846
3847 /* Keep the old croak based assert for those who want it, and as a fallback if
3848    the platform is so heretically non-ANSI that it can't assert.  */
3849
3850 #define Perl_assert(what)       PERL_DEB(                               \
3851         ((what) ? ((void) 0) :                                          \
3852             (Perl_croak_nocontext("Assertion %s failed: file \"" __FILE__ \
3853                         "\", line %d", STRINGIFY(what), __LINE__),      \
3854             (void) 0)))
3855
3856 #ifndef assert
3857 #  define assert(what)  Perl_assert(what)
3858 #endif
3859
3860 struct ufuncs {
3861     I32 (*uf_val)(pTHX_ IV, SV*);
3862     I32 (*uf_set)(pTHX_ IV, SV*);
3863     IV uf_index;
3864 };
3865
3866 /* In pre-5.7-Perls the PERL_MAGIC_uvar magic didn't get the thread context.
3867  * XS code wanting to be backward compatible can do something
3868  * like the following:
3869
3870 #ifndef PERL_MG_UFUNC
3871 #define PERL_MG_UFUNC(name,ix,sv) I32 name(IV ix, SV *sv)
3872 #endif
3873
3874 static PERL_MG_UFUNC(foo_get, index, val)
3875 {
3876     sv_setsv(val, ...);
3877     return TRUE;
3878 }
3879
3880 -- Doug MacEachern
3881
3882 */
3883
3884 #ifndef PERL_MG_UFUNC
3885 #define PERL_MG_UFUNC(name,ix,sv) I32 name(pTHX_ IV ix, SV *sv)
3886 #endif
3887
3888 /* Fix these up for __STDC__ */
3889 #ifndef DONT_DECLARE_STD
3890 char *mktemp (char*);
3891 #ifndef atof
3892 double atof (const char*);
3893 #endif
3894 #endif
3895
3896 #ifndef STANDARD_C
3897 /* All of these are in stdlib.h or time.h for ANSI C */
3898 Time_t time();
3899 struct tm *gmtime(), *localtime();
3900 #if defined(OEMVS) || defined(__OPEN_VM)
3901 char *(strchr)(), *(strrchr)();
3902 char *(strcpy)(), *(strcat)();
3903 #else
3904 char *strchr(), *strrchr();
3905 char *strcpy(), *strcat();
3906 #endif
3907 #endif /* ! STANDARD_C */
3908
3909
3910 #ifdef I_MATH
3911 #    include <math.h>
3912 #else
3913 START_EXTERN_C
3914             double exp (double);
3915             double log (double);
3916             double log10 (double);
3917             double sqrt (double);
3918             double frexp (double,int*);
3919             double ldexp (double,int);
3920             double modf (double,double*);
3921             double sin (double);
3922             double cos (double);
3923             double atan2 (double,double);
3924             double pow (double,double);
3925 END_EXTERN_C
3926 #endif
3927
3928 #if !defined(NV_INF) && defined(USE_LONG_DOUBLE) && defined(LDBL_INFINITY)
3929 #  define NV_INF LDBL_INFINITY
3930 #endif
3931 #if !defined(NV_INF) && defined(DBL_INFINITY)
3932 #  define NV_INF (NV)DBL_INFINITY
3933 #endif
3934 #if !defined(NV_INF) && defined(INFINITY)
3935 #  define NV_INF (NV)INFINITY
3936 #endif
3937 #if !defined(NV_INF) && defined(INF)
3938 #  define NV_INF (NV)INF
3939 #endif
3940 #if !defined(NV_INF) && defined(USE_LONG_DOUBLE) && defined(HUGE_VALL)
3941 #  define NV_INF (NV)HUGE_VALL
3942 #endif
3943 #if !defined(NV_INF) && defined(HUGE_VAL)
3944 #  define NV_INF (NV)HUGE_VAL
3945 #endif
3946
3947 #if !defined(NV_NAN) && defined(USE_LONG_DOUBLE)
3948 #   if !defined(NV_NAN) && defined(LDBL_NAN)
3949 #       define NV_NAN LDBL_NAN
3950 #   endif
3951 #   if !defined(NV_NAN) && defined(LDBL_QNAN)
3952 #       define NV_NAN LDBL_QNAN
3953 #   endif
3954 #   if !defined(NV_NAN) && defined(LDBL_SNAN)
3955 #       define NV_NAN LDBL_SNAN
3956 #   endif
3957 #endif
3958 #if !defined(NV_NAN) && defined(DBL_NAN)
3959 #  define NV_NAN (NV)DBL_NAN
3960 #endif
3961 #if !defined(NV_NAN) && defined(DBL_QNAN)
3962 #  define NV_NAN (NV)DBL_QNAN
3963 #endif
3964 #if !defined(NV_NAN) && defined(DBL_SNAN)
3965 #  define NV_NAN (NV)DBL_SNAN
3966 #endif
3967 #if !defined(NV_NAN) && defined(QNAN)
3968 #  define NV_NAN (NV)QNAN
3969 #endif
3970 #if !defined(NV_NAN) && defined(SNAN)
3971 #  define NV_NAN (NV)SNAN
3972 #endif
3973 #if !defined(NV_NAN) && defined(NAN)
3974 #  define NV_NAN (NV)NAN
3975 #endif
3976
3977 #ifndef __cplusplus
3978 #  if defined(NeXT) || defined(__NeXT__) /* or whatever catches all NeXTs */
3979 char *crypt ();       /* Maybe more hosts will need the unprototyped version */
3980 #  else
3981 #    if !defined(WIN32) && !defined(VMS)
3982 #ifndef crypt
3983 char *crypt (const char*, const char*);
3984 #endif
3985 #    endif /* !WIN32 */
3986 #  endif /* !NeXT && !__NeXT__ */
3987 #  ifndef DONT_DECLARE_STD
3988 #    ifndef getenv
3989 char *getenv (const char*);
3990 #    endif /* !getenv */
3991 #    if !defined(HAS_LSEEK_PROTO) && !defined(EPOC) && !defined(__hpux)
3992 #      ifdef _FILE_OFFSET_BITS
3993 #        if _FILE_OFFSET_BITS == 64
3994 Off_t lseek (int,Off_t,int);
3995 #        endif
3996 #      endif
3997 #    endif
3998 #  endif /* !DONT_DECLARE_STD */
3999 #ifndef getlogin
4000 char *getlogin (void);
4001 #endif
4002 #endif /* !__cplusplus */
4003
4004 /* Fixme on VMS.  This needs to be a run-time, not build time options */
4005 /* Also rename() is affected by this */
4006 #ifdef UNLINK_ALL_VERSIONS /* Currently only makes sense for VMS */
4007 #define UNLINK unlnk
4008 I32 unlnk (pTHX_ const char*);
4009 #else
4010 #define UNLINK PerlLIO_unlink
4011 #endif
4012
4013 /* some versions of glibc are missing the setresuid() proto */
4014 #if defined(HAS_SETRESUID) && !defined(HAS_SETRESUID_PROTO)
4015 int setresuid(uid_t ruid, uid_t euid, uid_t suid);
4016 #endif
4017 /* some versions of glibc are missing the setresgid() proto */
4018 #if defined(HAS_SETRESGID) && !defined(HAS_SETRESGID_PROTO)
4019 int setresgid(gid_t rgid, gid_t egid, gid_t sgid);
4020 #endif
4021
4022 #ifndef HAS_SETREUID
4023 #  ifdef HAS_SETRESUID
4024 #    define setreuid(r,e) setresuid(r,e,(Uid_t)-1)
4025 #    define HAS_SETREUID
4026 #  endif
4027 #endif
4028 #ifndef HAS_SETREGID
4029 #  ifdef HAS_SETRESGID
4030 #    define setregid(r,e) setresgid(r,e,(Gid_t)-1)
4031 #    define HAS_SETREGID
4032 #  endif
4033 #endif
4034
4035 /* Sighandler_t defined in iperlsys.h */
4036
4037 #ifdef HAS_SIGACTION
4038 typedef struct sigaction Sigsave_t;
4039 #else
4040 typedef Sighandler_t Sigsave_t;
4041 #endif
4042
4043 #define SCAN_DEF 0
4044 #define SCAN_TR 1
4045 #define SCAN_REPL 2
4046
4047 #ifdef DEBUGGING
4048 # ifndef register
4049 #  define register
4050 # endif
4051 # define RUNOPS_DEFAULT Perl_runops_debug
4052 #else
4053 # define RUNOPS_DEFAULT Perl_runops_standard
4054 #endif
4055
4056 #ifdef USE_PERLIO
4057 EXTERN_C void PerlIO_teardown(void);
4058 # ifdef USE_ITHREADS
4059 #  define PERLIO_INIT MUTEX_INIT(&PL_perlio_mutex)
4060 #  define PERLIO_TERM                           \
4061         STMT_START {                            \
4062                 PerlIO_teardown();              \
4063                 MUTEX_DESTROY(&PL_perlio_mutex);\
4064         } STMT_END
4065 # else
4066 #  define PERLIO_INIT
4067 #  define PERLIO_TERM   PerlIO_teardown()
4068 # endif
4069 #else
4070 #  define PERLIO_INIT
4071 #  define PERLIO_TERM
4072 #endif
4073
4074 #ifdef MYMALLOC
4075 #  ifdef MUTEX_INIT_CALLS_MALLOC
4076 #    define MALLOC_INIT                                 \
4077         STMT_START {                                    \
4078                 PL_malloc_mutex = NULL;                 \
4079                 MUTEX_INIT(&PL_malloc_mutex);           \
4080         } STMT_END
4081 #    define MALLOC_TERM                                 \
4082         STMT_START {                                    \
4083                 perl_mutex tmp = PL_malloc_mutex;       \
4084                 PL_malloc_mutex = NULL;                 \
4085                 MUTEX_DESTROY(&tmp);                    \
4086         } STMT_END
4087 #  else
4088 #    define MALLOC_INIT MUTEX_INIT(&PL_malloc_mutex)
4089 #    define MALLOC_TERM MUTEX_DESTROY(&PL_malloc_mutex)
4090 #  endif
4091 #else
4092 #  define MALLOC_INIT
4093 #  define MALLOC_TERM
4094 #endif
4095
4096 #if defined(PERL_IMPLICIT_CONTEXT)
4097
4098 struct perl_memory_debug_header;
4099 struct perl_memory_debug_header {
4100   tTHX  interpreter;
4101 #  ifdef PERL_POISON
4102   MEM_SIZE size;
4103 #  endif
4104   struct perl_memory_debug_header *prev;
4105   struct perl_memory_debug_header *next;
4106 };
4107
4108 #  define sTHX  (sizeof(struct perl_memory_debug_header) + \
4109         (MEM_ALIGNBYTES - sizeof(struct perl_memory_debug_header) \
4110          %MEM_ALIGNBYTES) % MEM_ALIGNBYTES)
4111
4112 #else
4113 #  define sTHX  0
4114 #endif
4115
4116 #ifdef PERL_TRACK_MEMPOOL
4117 #  define INIT_TRACK_MEMPOOL(header, interp)                    \
4118         STMT_START {                                            \
4119                 (header).interpreter = (interp);                \
4120                 (header).prev = (header).next = &(header);      \
4121         } STMT_END
4122 #  else
4123 #  define INIT_TRACK_MEMPOOL(header, interp)
4124 #endif
4125
4126 #ifdef I_MALLOCMALLOC
4127 /* Needed for malloc_size(), malloc_good_size() on some systems */
4128 #  include <malloc/malloc.h>
4129 #endif
4130
4131 #ifdef MYMALLOC
4132 #  define Perl_safesysmalloc_size(where)        Perl_malloced_size(where)
4133 #else
4134 #  ifdef HAS_MALLOC_SIZE
4135 #    ifdef PERL_TRACK_MEMPOOL
4136 #       define Perl_safesysmalloc_size(where)                   \
4137             (malloc_size(((char *)(where)) - sTHX) - sTHX)
4138 #    else
4139 #       define Perl_safesysmalloc_size(where) malloc_size(where)
4140 #    endif
4141 #  endif
4142 #  ifdef HAS_MALLOC_GOOD_SIZE
4143 #    ifdef PERL_TRACK_MEMPOOL
4144 #       define Perl_malloc_good_size(how_much)                  \
4145             (malloc_good_size((how_much) + sTHX) - sTHX)
4146 #    else
4147 #       define Perl_malloc_good_size(how_much) malloc_good_size(how_much)
4148 #    endif
4149 #  else
4150 /* Having this as the identity operation makes some code simpler.  */
4151 #       define Perl_malloc_good_size(how_much)  (how_much)
4152 #  endif
4153 #endif
4154
4155 typedef int (CPERLscope(*runops_proc_t)) (pTHX);
4156 typedef void (CPERLscope(*share_proc_t)) (pTHX_ SV *sv);
4157 typedef int  (CPERLscope(*thrhook_proc_t)) (pTHX);
4158 typedef OP* (CPERLscope(*PPADDR_t)[]) (pTHX);
4159 typedef bool (CPERLscope(*destroyable_proc_t)) (pTHX_ SV *sv);
4160
4161 /* _ (for $_) must be first in the following list (DEFSV requires it) */
4162 #define THREADSV_NAMES "_123456789&`'+/.,\\\";^-%=|~:\001\005!@"
4163
4164 /* NeXT has problems with crt0.o globals */
4165 #if defined(__DYNAMIC__) && \
4166     (defined(NeXT) || defined(__NeXT__) || defined(PERL_DARWIN))
4167 #  if defined(NeXT) || defined(__NeXT)
4168 #    include <mach-o/dyld.h>
4169 #    define environ (*environ_pointer)
4170 EXT char *** environ_pointer;
4171 #  else
4172 #    if defined(PERL_DARWIN) && defined(PERL_CORE)
4173 #      include <crt_externs.h>  /* for the env array */
4174 #      define environ (*_NSGetEnviron())
4175 #    endif
4176 #  endif
4177 #else
4178    /* VMS and some other platforms don't use the environ array */
4179 #  ifdef USE_ENVIRON_ARRAY
4180 #    if !defined(DONT_DECLARE_STD) || \
4181         (defined(__svr4__) && defined(__GNUC__) && defined(sun)) || \
4182         defined(__sgi) || \
4183         defined(__DGUX)
4184 extern char **  environ;        /* environment variables supplied via exec */
4185 #    endif
4186 #  endif
4187 #endif
4188
4189 START_EXTERN_C
4190
4191 /* handy constants */
4192 EXTCONST char PL_warn_uninit[]
4193   INIT("Use of uninitialized value%s%s%s");
4194 EXTCONST char PL_warn_nosemi[]
4195   INIT("Semicolon seems to be missing");
4196 EXTCONST char PL_warn_reserved[]
4197   INIT("Unquoted string \"%s\" may clash with future reserved word");
4198 EXTCONST char PL_warn_nl[]
4199   INIT("Unsuccessful %s on filename containing newline");
4200 EXTCONST char PL_no_wrongref[]
4201   INIT("Can't use %s ref as %s ref");
4202 EXTCONST char PL_no_symref[]
4203   INIT("Can't use string (\"%.32s\") as %s ref while \"strict refs\" in use");
4204 EXTCONST char PL_no_symref_sv[]
4205   INIT("Can't use string (\"%" SVf32 "\") as %s ref while \"strict refs\" in use");
4206 EXTCONST char PL_no_usym[]
4207   INIT("Can't use an undefined value as %s reference");
4208 EXTCONST char PL_no_aelem[]
4209   INIT("Modification of non-creatable array value attempted, subscript %d");
4210 EXTCONST char PL_no_helem_sv[]
4211   INIT("Modification of non-creatable hash value attempted, subscript \"%"SVf"\"");
4212 EXTCONST char PL_no_modify[]
4213   INIT("Modification of a read-only value attempted");
4214 EXTCONST char PL_no_mem[]
4215   INIT("Out of memory!\n");
4216 EXTCONST char PL_no_security[]
4217   INIT("Insecure dependency in %s%s");
4218 EXTCONST char PL_no_sock_func[]
4219   INIT("Unsupported socket function \"%s\" called");
4220 EXTCONST char PL_no_dir_func[]
4221   INIT("Unsupported directory function \"%s\" called");
4222 EXTCONST char PL_no_func[]
4223   INIT("The %s function is unimplemented");
4224 EXTCONST char PL_no_myglob[]
4225   INIT("\"%s\" variable %s can't be in a package");
4226 EXTCONST char PL_no_localize_ref[]
4227   INIT("Can't localize through a reference");
4228 EXTCONST char PL_memory_wrap[]
4229   INIT("panic: memory wrap");
4230
4231 #ifdef CSH
4232 EXTCONST char PL_cshname[]
4233   INIT(CSH);
4234 #  define PL_cshlen     (sizeof(CSH "") - 1)
4235 #endif
4236
4237 EXTCONST char PL_uuemap[65]
4238   INIT("`!\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_");
4239
4240 #ifdef DOINIT
4241 EXTCONST char PL_uudmap[256] =
4242 #include "uudmap.h"
4243 ;
4244 EXTCONST char PL_bitcount[256] =
4245 #  include "bitcount.h"
4246 ;
4247 EXTCONST char* const PL_sig_name[] = { SIG_NAME };
4248 EXTCONST int         PL_sig_num[]  = { SIG_NUM };
4249 #else
4250 EXTCONST char PL_uudmap[256];
4251 EXTCONST char PL_bitcount[256];
4252 EXTCONST char* const PL_sig_name[];
4253 EXTCONST int         PL_sig_num[];
4254 #endif
4255
4256 /* fast conversion and case folding tables */
4257
4258 #ifdef DOINIT
4259 #ifdef EBCDIC
4260 EXTCONST unsigned char PL_fold[] = { /* fast EBCDIC case folding table */
4261     0,      1,      2,      3,      4,      5,      6,      7,
4262     8,      9,      10,     11,     12,     13,     14,     15,
4263     16,     17,     18,     19,     20,     21,     22,     23,
4264     24,     25,     26,     27,     28,     29,     30,     31,
4265     32,     33,     34,     35,     36,     37,     38,     39,
4266     40,     41,     42,     43,     44,     45,     46,     47,
4267     48,     49,     50,     51,     52,     53,     54,     55,
4268     56,     57,     58,     59,     60,     61,     62,     63,
4269     64,     65,     66,     67,     68,     69,     70,     71,
4270     72,     73,     74,     75,     76,     77,     78,     79,
4271     80,     81,     82,     83,     84,     85,     86,     87,
4272     88,     89,     90,     91,     92,     93,     94,     95,
4273     96,     97,     98,     99,     100,    101,    102,    103,
4274     104,    105,    106,    107,    108,    109,    110,    111,
4275     112,    113,    114,    115,    116,    117,    118,    119,
4276     120,    121,    122,    123,    124,    125,    126,    127,
4277     128,    'A',    'B',    'C',    'D',    'E',    'F',    'G',
4278     'H',    'I',    138,    139,    140,    141,    142,    143,
4279     144,    'J',    'K',    'L',    'M',    'N',    'O',    'P',
4280     'Q',    'R',    154,    155,    156,    157,    158,    159,
4281     160,    161,    'S',    'T',    'U',    'V',    'W',    'X',
4282     'Y',    'Z',    170,    171,    172,    173,    174,    175,
4283     176,    177,    178,    179,    180,    181,    182,    183,
4284     184,    185,    186,    187,    188,    189,    190,    191,
4285     192,    'a',    'b',    'c',    'd',    'e',    'f',    'g',
4286     'h',    'i',    202,    203,    204,    205,    206,    207,
4287     208,    'j',    'k',    'l',    'm',    'n',    'o',    'p',
4288     'q',    'r',    218,    219,    220,    221,    222,    223,
4289     224,    225,    's',    't',    'u',    'v',    'w',    'x',
4290     'y',    'z',    234,    235,    236,    237,    238,    239,
4291     240,    241,    242,    243,    244,    245,    246,    247,
4292     248,    249,    250,    251,    252,    253,    254,    255
4293 };
4294 #else   /* ascii rather than ebcdic */
4295 EXTCONST  unsigned char PL_fold[] = {
4296         0,      1,      2,      3,      4,      5,      6,      7,
4297         8,      9,      10,     11,     12,     13,     14,     15,
4298         16,     17,     18,     19,     20,     21,     22,     23,
4299         24,     25,     26,     27,     28,     29,     30,     31,
4300         32,     33,     34,     35,     36,     37,     38,     39,
4301         40,     41,     42,     43,     44,     45,     46,     47,
4302         48,     49,     50,     51,     52,     53,     54,     55,
4303         56,     57,     58,     59,     60,     61,     62,     63,
4304         64,     'a',    'b',    'c',    'd',    'e',    'f',    'g',
4305         'h',    'i',    'j',    'k',    'l',    'm',    'n',    'o',
4306         'p',    'q',    'r',    's',    't',    'u',    'v',    'w',
4307         'x',    'y',    'z',    91,     92,     93,     94,     95,
4308         96,     'A',    'B',    'C',    'D',    'E',    'F',    'G',
4309         'H',    'I',    'J',    'K',    'L',    'M',    'N',    'O',
4310         'P',    'Q',    'R',    'S',    'T',    'U',    'V',    'W',
4311         'X',    'Y',    'Z',    123,    124,    125,    126,    127,
4312         128,    129,    130,    131,    132,    133,    134,    135,
4313         136,    137,    138,    139,    140,    141,    142,    143,
4314         144,    145,    146,    147,    148,    149,    150,    151,
4315         152,    153,    154,    155,    156,    157,    158,    159,
4316         160,    161,    162,    163,    164,    165,    166,    167,
4317         168,    169,    170,    171,    172,    173,    174,    175,
4318         176,    177,    178,    179,    180,    181,    182,    183,
4319         184,    185,    186,    187,    188,    189,    190,    191,
4320         192,    193,    194,    195,    196,    197,    198,    199,
4321         200,    201,    202,    203,    204,    205,    206,    207,
4322         208,    209,    210,    211,    212,    213,    214,    215,
4323         216,    217,    218,    219,    220,    221,    222,    223,    
4324         224,    225,    226,    227,    228,    229,    230,    231,
4325         232,    233,    234,    235,    236,    237,    238,    239,
4326         240,    241,    242,    243,    244,    245,    246,    247,
4327         248,    249,    250,    251,    252,    253,    254,    255
4328 };
4329 #endif  /* !EBCDIC */
4330 #else
4331 EXTCONST unsigned char PL_fold[];
4332 #endif
4333
4334 #ifndef PERL_GLOBAL_STRUCT /* or perlvars.h */
4335 #ifdef DOINIT
4336 EXT unsigned char PL_fold_locale[] = { /* Unfortunately not EXTCONST. */
4337         0,      1,      2,      3,      4,      5,      6,      7,
4338         8,      9,      10,     11,     12,     13,     14,     15,
4339         16,     17,     18,     19,     20,     21,     22,     23,
4340         24,     25,     26,     27,     28,     29,     30,     31,
4341         32,     33,     34,     35,     36,     37,     38,     39,
4342         40,     41,     42,     43,     44,     45,     46,     47,
4343         48,     49,     50,     51,     52,     53,     54,     55,
4344         56,     57,     58,     59,     60,     61,     62,     63,
4345         64,     'a',    'b',    'c',    'd',    'e',    'f',    'g',
4346         'h',    'i',    'j',    'k',    'l',    'm',    'n',    'o',
4347         'p',    'q',    'r',    's',    't',    'u',    'v',    'w',
4348         'x',    'y',    'z',    91,     92,     93,     94,     95,
4349         96,     'A',    'B',    'C',    'D',    'E',    'F',    'G',
4350         'H',    'I',    'J',    'K',    'L',    'M',    'N',    'O',
4351         'P',    'Q',    'R',    'S',    'T',    'U',    'V',    'W',
4352         'X',    'Y',    'Z',    123,    124,    125,    126,    127,
4353         128,    129,    130,    131,    132,    133,    134,    135,
4354         136,    137,    138,    139,    140,    141,    142,    143,
4355         144,    145,    146,    147,    148,    149,    150,    151,
4356         152,    153,    154,    155,    156,    157,    158,    159,
4357         160,    161,    162,    163,    164,    165,    166,    167,
4358         168,    169,    170,    171,    172,    173,    174,    175,
4359         176,    177,    178,    179,    180,    181,    182,    183,
4360         184,    185,    186,    187,    188,    189,    190,    191,
4361         192,    193,    194,    195,    196,    197,    198,    199,
4362         200,    201,    202,    203,    204,    205,    206,    207,
4363         208,    209,    210,    211,    212,    213,    214,    215,
4364         216,    217,    218,    219,    220,    221,    222,    223,    
4365         224,    225,    226,    227,    228,    229,    230,    231,
4366         232,    233,    234,    235,    236,    237,    238,    239,
4367         240,    241,    242,    243,    244,    245,    246,    247,
4368         248,    249,    250,    251,    252,    253,    254,    255
4369 };
4370 #else
4371 EXT unsigned char PL_fold_locale[]; /* Unfortunately not EXTCONST. */
4372 #endif
4373 #endif /* !PERL_GLOBAL_STRUCT */
4374
4375 #ifdef DOINIT
4376 #ifdef EBCDIC
4377 EXTCONST unsigned char PL_freq[] = {/* EBCDIC frequencies for mixed English/C */
4378     1,      2,      84,     151,    154,    155,    156,    157,
4379     165,    246,    250,    3,      158,    7,      18,     29,
4380     40,     51,     62,     73,     85,     96,     107,    118,
4381     129,    140,    147,    148,    149,    150,    152,    153,
4382     255,      6,      8,      9,     10,     11,     12,     13,
4383      14,     15,     24,     25,     26,     27,     28,    226,
4384      29,     30,     31,     32,     33,     43,     44,     45,
4385      46,     47,     48,     49,     50,     76,     77,     78,
4386      79,     80,     81,     82,     83,     84,     85,     86,
4387      87,     94,     95,    234,    181,    233,    187,    190,
4388     180,     96,     97,     98,     99,    100,    101,    102,
4389     104,    112,    182,    174,    236,    232,    229,    103,
4390     228,    226,    114,    115,    116,    117,    118,    119,
4391     120,    121,    122,    235,    176,    230,    194,    162,
4392     130,    131,    132,    133,    134,    135,    136,    137,
4393     138,    139,    201,    205,    163,    217,    220,    224,
4394     5,      248,    227,    244,    242,    255,    241,    231,
4395     240,    253,    16,     197,    19,     20,     21,     187,
4396     23,     169,    210,    245,    237,    249,    247,    239,
4397     168,    252,    34,     196,    36,     37,     38,     39,
4398     41,     42,     251,    254,    238,    223,    221,    213,
4399     225,    177,    52,     53,     54,     55,     56,     57,
4400     58,     59,     60,     61,     63,     64,     65,     66,
4401     67,     68,     69,     70,     71,     72,     74,     75,
4402     205,    208,    186,    202,    200,    218,    198,    179,
4403     178,    214,    88,     89,     90,     91,     92,     93,
4404     217,    166,    170,    207,    199,    209,    206,    204,
4405     160,    212,    105,    106,    108,    109,    110,    111,
4406     203,    113,    216,    215,    192,    175,    193,    243,
4407     172,    161,    123,    124,    125,    126,    127,    128,
4408     222,    219,    211,    195,    188,    193,    185,    184,
4409     191,    183,    141,    142,    143,    144,    145,    146
4410 };
4411 #else  /* ascii rather than ebcdic */
4412 EXTCONST unsigned char PL_freq[] = {    /* letter frequencies for mixed English/C */
4413         1,      2,      84,     151,    154,    155,    156,    157,
4414         165,    246,    250,    3,      158,    7,      18,     29,
4415         40,     51,     62,     73,     85,     96,     107,    118,
4416         129,    140,    147,    148,    149,    150,    152,    153,
4417         255,    182,    224,    205,    174,    176,    180,    217,
4418         233,    232,    236,    187,    235,    228,    234,    226,
4419         222,    219,    211,    195,    188,    193,    185,    184,
4420         191,    183,    201,    229,    181,    220,    194,    162,
4421         163,    208,    186,    202,    200,    218,    198,    179,
4422         178,    214,    166,    170,    207,    199,    209,    206,
4423         204,    160,    212,    216,    215,    192,    175,    173,
4424         243,    172,    161,    190,    203,    189,    164,    230,
4425         167,    248,    227,    244,    242,    255,    241,    231,
4426         240,    253,    169,    210,    245,    237,    249,    247,
4427         239,    168,    252,    251,    254,    238,    223,    221,
4428         213,    225,    177,    197,    171,    196,    159,    4,
4429         5,      6,      8,      9,      10,     11,     12,     13,
4430         14,     15,     16,     17,     19,     20,     21,     22,
4431         23,     24,     25,     26,     27,     28,     30,     31,
4432         32,     33,     34,     35,     36,     37,     38,     39,
4433         41,     42,     43,     44,     45,     46,     47,     48,
4434         49,     50,     52,     53,     54,     55,     56,     57,
4435         58,     59,     60,     61,     63,     64,     65,     66,
4436         67,     68,     69,     70,     71,     72,     74,     75,
4437         76,     77,     78,     79,     80,     81,     82,     83,
4438         86,     87,     88,     89,     90,     91,     92,     93,
4439         94,     95,     97,     98,     99,     100,    101,    102,
4440         103,    104,    105,    106,    108,    109,    110,    111,
4441         112,    113,    114,    115,    116,    117,    119,    120,
4442         121,    122,    123,    124,    125,    126,    127,    128,
4443         130,    131,    132,    133,    134,    135,    136,    137,
4444         138,    139,    141,    142,    143,    144,    145,    146
4445 };
4446 #endif
4447 #else
4448 EXTCONST unsigned char PL_freq[];
4449 #endif
4450
4451 #ifdef DEBUGGING
4452 #ifdef DOINIT
4453 EXTCONST char* const PL_block_type[] = {
4454         "NULL",
4455         "WHEN",
4456         "BLOCK",
4457         "GIVEN",
4458         "LOOP_FOR",
4459         "LOOP_PLAIN",
4460         "LOOP_LAZYSV",
4461         "LOOP_LAZYIV",
4462         "SUB",
4463         "FORMAT",
4464         "EVAL",
4465         "SUBST"
4466 };
4467 #else
4468 EXTCONST char* PL_block_type[];
4469 #endif
4470 #endif
4471
4472 /* These are all the compile time options that affect binary compatibility.
4473    Other compile time options that are binary compatible are in perl.c
4474    Both are combined for the output of perl -V
4475    However, this string will be embedded in any shared perl library, which will
4476    allow us add a comparison check in perlmain.c in the near future.  */
4477 #ifdef DOINIT
4478 EXTCONST char PL_bincompat_options[] =
4479 #  ifdef DEBUG_LEAKING_SCALARS
4480                              " DEBUG_LEAKING_SCALARS"
4481 #  endif
4482 #  ifdef DEBUG_LEAKING_SCALARS_FORK_DUMP
4483                              " DEBUG_LEAKING_SCALARS_FORK_DUMP"
4484 #  endif
4485 #  ifdef FAKE_THREADS
4486                              " FAKE_THREADS"
4487 #  endif
4488 #  ifdef MULTIPLICITY
4489                              " MULTIPLICITY"
4490 #  endif
4491 #  ifdef MYMALLOC
4492                              " MYMALLOC"
4493 #  endif
4494 #  ifdef PERL_DEBUG_READONLY_OPS
4495                              " PERL_DEBUG_READONLY_OPS"
4496 #  endif
4497 #  ifdef PERL_GLOBAL_STRUCT
4498                              " PERL_GLOBAL_STRUCT"
4499 #  endif
4500 #  ifdef PERL_IMPLICIT_CONTEXT
4501                              " PERL_IMPLICIT_CONTEXT"
4502 #  endif
4503 #  ifdef PERL_IMPLICIT_SYS
4504                              " PERL_IMPLICIT_SYS"
4505 #  endif
4506 #  ifdef PERL_MAD
4507                              " PERL_MAD"
4508 #  endif
4509 #  ifdef PERL_NEED_APPCTX
4510                              " PERL_NEED_APPCTX"
4511 #  endif
4512 #  ifdef PERL_NEED_TIMESBASE
4513                              " PERL_NEED_TIMESBASE"
4514 #  endif
4515 #  ifdef PERL_OLD_COPY_ON_WRITE
4516                              " PERL_OLD_COPY_ON_WRITE"
4517 #  endif
4518 #  ifdef PERL_POISON
4519                              " PERL_POISON"
4520 #  endif
4521 #  ifdef PERL_TRACK_MEMPOOL
4522                              " PERL_TRACK_MEMPOOL"
4523 #  endif
4524 #  ifdef PERL_USES_PL_PIDSTATUS
4525                              " PERL_USES_PL_PIDSTATUS"
4526 #  endif
4527 #  ifdef PL_OP_SLAB_ALLOC
4528                              " PL_OP_SLAB_ALLOC"
4529 #  endif
4530 #  ifdef THREADS_HAVE_PIDS
4531                              " THREADS_HAVE_PIDS"
4532 #  endif
4533 #  ifdef USE_64_BIT_ALL
4534                              " USE_64_BIT_ALL"
4535 #  endif
4536 #  ifdef USE_64_BIT_INT
4537                              " USE_64_BIT_INT"
4538 #  endif
4539 #  ifdef USE_IEEE
4540                              " USE_IEEE"
4541 #  endif
4542 #  ifdef USE_ITHREADS
4543                              " USE_ITHREADS"
4544 #  endif
4545 #  ifdef USE_LARGE_FILES
4546                              " USE_LARGE_FILES"
4547 #  endif
4548 #  ifdef USE_LONG_DOUBLE
4549                              " USE_LONG_DOUBLE"
4550 #  endif
4551 #  ifdef USE_PERLIO
4552                              " USE_PERLIO"
4553 #  endif
4554 #  ifdef USE_REENTRANT_API
4555                              " USE_REENTRANT_API"
4556 #  endif
4557 #  ifdef USE_SFIO
4558                              " USE_SFIO"
4559 #  endif
4560 #  ifdef USE_SOCKS
4561                              " USE_SOCKS"
4562 #  endif
4563 #  ifdef VMS_DO_SOCKETS
4564                              " VMS_DO_SOCKETS"
4565 #    ifdef DECCRTL_SOCKETS
4566                              " DECCRTL_SOCKETS"
4567 #    endif
4568 #  endif
4569 #  ifdef VMS_WE_ARE_CASE_SENSITIVE
4570                              " VMS_SYMBOL_CASE_AS_IS"
4571 #  endif
4572   "";
4573 #else
4574 EXTCONST char PL_bincompat_options[];
4575 #endif
4576
4577 END_EXTERN_C
4578
4579 /*****************************************************************************/
4580 /* This lexer/parser stuff is currently global since yacc is hard to reenter */
4581 /*****************************************************************************/
4582 /* XXX This needs to be revisited, since BEGIN makes yacc re-enter... */
4583
4584 #ifdef __Lynx__
4585 /* LynxOS defines these in scsi.h which is included via ioctl.h */
4586 #ifdef FORMAT
4587 #undef FORMAT
4588 #endif
4589 #ifdef SPACE
4590 #undef SPACE
4591 #endif
4592 #endif
4593
4594 #define LEX_NOTPARSING          11      /* borrowed from toke.c */
4595
4596 typedef enum {
4597     XOPERATOR,
4598     XTERM,
4599     XREF,
4600     XSTATE,
4601     XBLOCK,
4602     XATTRBLOCK,
4603     XATTRTERM,
4604     XTERMBLOCK,
4605     XTERMORDORDOR /* evil hack */
4606     /* update exp_name[] in toke.c if adding to this enum */
4607 } expectation;
4608
4609 enum {          /* pass one of these to get_vtbl */
4610     want_vtbl_sv,
4611     want_vtbl_env,
4612     want_vtbl_envelem,
4613     want_vtbl_sig,
4614     want_vtbl_sigelem,
4615     want_vtbl_pack,
4616     want_vtbl_packelem,
4617     want_vtbl_dbline,
4618     want_vtbl_isa,
4619     want_vtbl_isaelem,
4620     want_vtbl_arylen,
4621     want_vtbl_glob,
4622     want_vtbl_mglob,
4623     want_vtbl_nkeys,
4624     want_vtbl_taint,
4625     want_vtbl_substr,
4626     want_vtbl_vec,
4627     want_vtbl_pos,
4628     want_vtbl_bm,
4629     want_vtbl_fm,
4630     want_vtbl_uvar,
4631     want_vtbl_defelem,
4632     want_vtbl_regexp,
4633     want_vtbl_collxfrm,
4634     want_vtbl_amagic,
4635     want_vtbl_amagicelem,
4636     want_vtbl_regdata,
4637     want_vtbl_regdatum,
4638     want_vtbl_backref,
4639     want_vtbl_utf8,
4640     want_vtbl_symtab,
4641     want_vtbl_arylen_p,
4642     want_vtbl_hintselem
4643 };
4644
4645
4646 /* Hints are now stored in a dedicated U32, so the bottom 8 bits are no longer
4647    special and there is no need for HINT_PRIVATE_MASK for COPs
4648    However, bitops store HINT_INTEGER in their op_private.  */
4649 #define HINT_INTEGER            0x00000001 /* integer pragma */
4650 #define HINT_STRICT_REFS        0x00000002 /* strict pragma */
4651 #define HINT_LOCALE             0x00000004 /* locale pragma */
4652 #define HINT_BYTES              0x00000008 /* bytes pragma */
4653 #define HINT_ARYBASE            0x00000010 /* $[ is non-zero */
4654                                 /* Note: 20,40,80 used for NATIVE_HINTS */
4655                                 /* currently defined by vms/vmsish.h */
4656
4657 #define HINT_BLOCK_SCOPE        0x00000100
4658 #define HINT_STRICT_SUBS        0x00000200 /* strict pragma */
4659 #define HINT_STRICT_VARS        0x00000400 /* strict pragma */
4660
4661 /* The HINT_NEW_* constants are used by the overload pragma */
4662 #define HINT_NEW_INTEGER        0x00001000
4663 #define HINT_NEW_FLOAT          0x00002000
4664 #define HINT_NEW_BINARY         0x00004000
4665 #define HINT_NEW_STRING         0x00008000
4666 #define HINT_NEW_RE             0x00010000
4667 #define HINT_LOCALIZE_HH        0x00020000 /* %^H needs to be copied */
4668 #define HINT_LEXICAL_IO_IN      0x00040000 /* ${^OPEN} is set for input */
4669 #define HINT_LEXICAL_IO_OUT     0x00080000 /* ${^OPEN} is set for output */
4670
4671 #define HINT_RE_TAINT           0x00100000 /* re pragma */
4672 #define HINT_RE_EVAL            0x00200000 /* re pragma */
4673
4674 #define HINT_FILETEST_ACCESS    0x00400000 /* filetest pragma */
4675 #define HINT_UTF8               0x00800000 /* utf8 pragma */
4676
4677 #define HINT_NO_AMAGIC          0x01000000 /* overloading pragma */
4678
4679 /* The following are stored in $^H{sort}, not in PL_hints */
4680 #define HINT_SORT_SORT_BITS     0x000000FF /* allow 256 different ones */
4681 #define HINT_SORT_QUICKSORT     0x00000001
4682 #define HINT_SORT_MERGESORT     0x00000002
4683 #define HINT_SORT_STABLE        0x00000100 /* sort styles (currently one) */
4684
4685 /* Various states of the input record separator SV (rs) */
4686 #define RsSNARF(sv)   (! SvOK(sv))
4687 #define RsSIMPLE(sv)  (SvOK(sv) && (! SvPOK(sv) || SvCUR(sv)))
4688 #define RsPARA(sv)    (SvPOK(sv) && ! SvCUR(sv))
4689 #define RsRECORD(sv)  (SvROK(sv) && (SvIV(SvRV(sv)) > 0))
4690
4691 /* A struct for keeping various DEBUGGING related stuff,
4692  * neatly packed.  Currently only scratch variables for
4693  * constructing debug output are included.  Needed always,
4694  * not just when DEBUGGING, though, because of the re extension. c*/
4695 struct perl_debug_pad {
4696   SV pad[3];
4697 };
4698
4699 #define PERL_DEBUG_PAD(i)       &(PL_debug_pad.pad[i])
4700 #define PERL_DEBUG_PAD_ZERO(i)  (SvPVX(PERL_DEBUG_PAD(i))[0] = 0, \
4701         (((XPV*) SvANY(PERL_DEBUG_PAD(i)))->xpv_cur = 0), \
4702         PERL_DEBUG_PAD(i))
4703
4704 /* Enable variables which are pointers to functions */
4705 typedef void (CPERLscope(*peep_t))(pTHX_ OP* o);
4706 typedef regexp*(CPERLscope(*regcomp_t)) (pTHX_ char* exp, char* xend, PMOP* pm);
4707 typedef I32 (CPERLscope(*regexec_t)) (pTHX_ regexp* prog, char* stringarg,
4708                                       char* strend, char* strbeg, I32 minend,
4709                                       SV* screamer, void* data, U32 flags);
4710 typedef char* (CPERLscope(*re_intuit_start_t)) (pTHX_ regexp *prog, SV *sv,
4711                                                 char *strpos, char *strend,
4712                                                 U32 flags,
4713                                                 re_scream_pos_data *d);
4714 typedef SV*     (CPERLscope(*re_intuit_string_t)) (pTHX_ regexp *prog);
4715 typedef void    (CPERLscope(*regfree_t)) (pTHX_ struct regexp* r);
4716 typedef regexp*(CPERLscope(*regdupe_t)) (pTHX_ const regexp* r, CLONE_PARAMS *param);
4717
4718 typedef void (*DESTRUCTORFUNC_NOCONTEXT_t) (void*);
4719 typedef void (*DESTRUCTORFUNC_t) (pTHX_ void*);
4720 typedef void (*SVFUNC_t) (pTHX_ SV* const);
4721 typedef I32  (*SVCOMPARE_t) (pTHX_ SV* const, SV* const);
4722 typedef void (*XSINIT_t) (pTHX);
4723 typedef void (*ATEXIT_t) (pTHX_ void*);
4724 typedef void (*XSUBADDR_t) (pTHX_ CV *);
4725
4726 /* Set up PERLVAR macros for populating structs */
4727 #define PERLVAR(var,type) type var;
4728 #define PERLVARA(var,n,type) type var[n];
4729 #define PERLVARI(var,type,init) type var;
4730 #define PERLVARIC(var,type,init) type var;
4731 #define PERLVARISC(var,init) const char var[sizeof(init)];
4732
4733 typedef OP* (CPERLscope(*Perl_ppaddr_t))(pTHX);
4734 typedef OP* (CPERLscope(*Perl_check_t)) (pTHX_ OP*);
4735 typedef void(CPERLscope(*Perl_ophook_t))(pTHX_ OP*);
4736
4737 /* Interpreter exitlist entry */
4738 typedef struct exitlistentry {
4739     void (*fn) (pTHX_ void*);
4740     void *ptr;
4741 } PerlExitListEntry;
4742
4743 /* if you only have signal() and it resets on each signal, FAKE_PERSISTENT_SIGNAL_HANDLERS fixes */
4744 /* These have to be before perlvars.h */
4745 #if !defined(HAS_SIGACTION) && defined(VMS)
4746 #  define  FAKE_PERSISTENT_SIGNAL_HANDLERS
4747 #endif
4748 /* if we're doing kill() with sys$sigprc on VMS, FAKE_DEFAULT_SIGNAL_HANDLERS */
4749 #if defined(KILL_BY_SIGPRC)
4750 #  define  FAKE_DEFAULT_SIGNAL_HANDLERS
4751 #endif
4752
4753 #define PERL_PATCHLEVEL_H_IMPLICIT
4754 #include "patchlevel.h"
4755 #undef PERL_PATCHLEVEL_H_IMPLICIT
4756
4757 #define PERL_VERSION_STRING     STRINGIFY(PERL_REVISION) "." \
4758                                 STRINGIFY(PERL_VERSION) "." \
4759                                 STRINGIFY(PERL_SUBVERSION)
4760
4761 #ifdef PERL_GLOBAL_STRUCT
4762 struct perl_vars {
4763 #  include "perlvars.h"
4764 };
4765
4766 #  ifdef PERL_CORE
4767 #    ifndef PERL_GLOBAL_STRUCT_PRIVATE
4768 EXT struct perl_vars PL_Vars;
4769 EXT struct perl_vars *PL_VarsPtr INIT(&PL_Vars);
4770 #      undef PERL_GET_VARS
4771 #      define PERL_GET_VARS() PL_VarsPtr
4772 #    endif /* !PERL_GLOBAL_STRUCT_PRIVATE */
4773 #  else /* PERL_CORE */
4774 #    if !defined(__GNUC__) || !defined(WIN32)
4775 EXT
4776 #    endif /* WIN32 */
4777 struct perl_vars *PL_VarsPtr;
4778 #    define PL_Vars (*((PL_VarsPtr) \
4779                        ? PL_VarsPtr : (PL_VarsPtr = Perl_GetVars(aTHX))))
4780 #  endif /* PERL_CORE */
4781 #endif /* PERL_GLOBAL_STRUCT */
4782
4783 #if defined(MULTIPLICITY)
4784 /* If we have multiple interpreters define a struct
4785    holding variables which must be per-interpreter
4786    If we don't have threads anything that would have
4787    be per-thread is per-interpreter.
4788 */
4789
4790 struct interpreter {
4791 #  include "intrpvar.h"
4792 };
4793
4794 #else
4795 struct interpreter {
4796     char broiled;
4797 };
4798 #endif /* MULTIPLICITY */
4799
4800 /* Done with PERLVAR macros for now ... */
4801 #undef PERLVAR
4802 #undef PERLVARA
4803 #undef PERLVARI
4804 #undef PERLVARIC
4805 #undef PERLVARISC
4806
4807 struct tempsym; /* defined in pp_pack.c */
4808
4809 #include "thread.h"
4810 #include "pp.h"
4811
4812 #ifndef PERL_CALLCONV
4813 #  ifdef __cplusplus
4814 #    define PERL_CALLCONV extern "C"
4815 #  else
4816 #    define PERL_CALLCONV
4817 #  endif
4818 #endif
4819 #undef PERL_CKDEF
4820 #undef PERL_PPDEF
4821 #define PERL_CKDEF(s)   PERL_CALLCONV OP *s (pTHX_ OP *o);
4822 #define PERL_PPDEF(s)   PERL_CALLCONV OP *s (pTHX);
4823
4824 #include "proto.h"
4825
4826 /* this has structure inits, so it cannot be included before here */
4827 #include "opcode.h"
4828
4829 /* The following must follow proto.h as #defines mess up syntax */
4830
4831 #if !defined(PERL_FOR_X2P)
4832 #  include "embedvar.h"
4833 #endif
4834 #ifndef PERL_MAD
4835 #  undef PL_madskills
4836 #  undef PL_xmlfp
4837 #  define PL_madskills 0
4838 #  define PL_xmlfp 0
4839 #endif
4840
4841 /* Now include all the 'global' variables
4842  * If we don't have threads or multiple interpreters
4843  * these include variables that would have been their struct-s
4844  */
4845
4846 #define PERLVAR(var,type) EXT type PL_##var;
4847 #define PERLVARA(var,n,type) EXT type PL_##var[n];
4848 #define PERLVARI(var,type,init) EXT type  PL_##var INIT(init);
4849 #define PERLVARIC(var,type,init) EXTCONST type PL_##var INIT(init);
4850 #define PERLVARISC(var,init) EXTCONST char PL_##var[sizeof(init)] INIT(init);
4851
4852 #if !defined(MULTIPLICITY)
4853 START_EXTERN_C
4854 #  include "intrpvar.h"
4855 END_EXTERN_C
4856 #endif
4857
4858 #ifdef PERL_CORE
4859 /* All core uses now exterminated. Ensure no zombies can return:  */
4860 #  undef PL_na
4861 #endif
4862
4863 #if defined(WIN32)
4864 /* Now all the config stuff is setup we can include embed.h */
4865 #  include "embed.h"
4866 #  ifndef PERL_MAD
4867 #    undef op_getmad
4868 #    define op_getmad(arg,pegop,slot) NOOP
4869 #  endif
4870 #endif
4871
4872 #ifndef PERL_GLOBAL_STRUCT
4873 START_EXTERN_C
4874
4875 #  include "perlvars.h"
4876
4877 END_EXTERN_C
4878 #endif
4879
4880 #undef PERLVAR
4881 #undef PERLVARA
4882 #undef PERLVARI
4883 #undef PERLVARIC
4884
4885 START_EXTERN_C
4886
4887 /* PERL_GLOBAL_STRUCT_PRIVATE wants to keep global data like the
4888  * magic vtables const, but this is incompatible with SWIG which
4889  * does want to modify the vtables. */
4890 #ifdef PERL_GLOBAL_STRUCT_PRIVATE
4891 #  define EXT_MGVTBL EXTCONST MGVTBL
4892 #else
4893 #  define EXT_MGVTBL EXT MGVTBL
4894 #endif
4895
4896 #ifdef DOINIT
4897 #  define MGVTBL_SET(var,a,b,c,d,e,f,g,h) EXT_MGVTBL var = {a,b,c,d,e,f,g,h}
4898 /* Like MGVTBL_SET but with the get magic having a const MG* */
4899 #  define MGVTBL_SET_CONST_MAGIC_GET(var,a,b,c,d,e,f,g,h) EXT_MGVTBL var \
4900     = {(int (*)(pTHX_ SV *, MAGIC *))a,b,c,d,e,f,g,h}
4901 #else
4902 #  define MGVTBL_SET(var,a,b,c,d,e,f,g,h) EXT_MGVTBL var
4903 #  define MGVTBL_SET_CONST_MAGIC_GET(var,a,b,c,d,e,f,g,h) EXT_MGVTBL var
4904 #endif
4905
4906 /* These all need to be 0, not NULL, as NULL can be (void*)0, which is a
4907  * pointer to data, whereas we're assigning pointers to functions, which are
4908  * not the same beast. ANSI doesn't allow the assignment from one to the other.
4909  * (although most, but not all, compilers are prepared to do it)
4910  */
4911 MGVTBL_SET(
4912     PL_vtbl_sv,
4913     MEMBER_TO_FPTR(Perl_magic_get),
4914     MEMBER_TO_FPTR(Perl_magic_set),
4915     MEMBER_TO_FPTR(Perl_magic_len),
4916     0,
4917     0,
4918     0,
4919     0,
4920     0
4921 );
4922
4923 MGVTBL_SET(
4924     PL_vtbl_env,
4925     0,
4926     MEMBER_TO_FPTR(Perl_magic_set_all_env),
4927     0,
4928     MEMBER_TO_FPTR(Perl_magic_clear_all_env),
4929     0,
4930     0,
4931     0,
4932     0
4933 );
4934
4935 MGVTBL_SET(
4936     PL_vtbl_envelem,
4937     0,
4938     MEMBER_TO_FPTR(Perl_magic_setenv),
4939     0,
4940     MEMBER_TO_FPTR(Perl_magic_clearenv),
4941     0,
4942     0,
4943     0,
4944     0
4945 );
4946
4947 /* For now, hints magic will also use vtbl_sig, because it is all 0  */
4948 MGVTBL_SET(
4949     PL_vtbl_sig,
4950     0,
4951     0,
4952     0,
4953     0,
4954     0,
4955     0,
4956     0,
4957     0
4958 );
4959
4960 #ifdef PERL_MICRO
4961 MGVTBL_SET(
4962     PL_vtbl_sigelem,
4963     0,
4964     0,
4965     0,
4966     0,
4967     0,
4968     0,
4969     0,
4970     0
4971 );
4972
4973 #else
4974 MGVTBL_SET(
4975     PL_vtbl_sigelem,
4976     MEMBER_TO_FPTR(Perl_magic_getsig),
4977     MEMBER_TO_FPTR(Perl_magic_setsig),
4978     0,
4979     MEMBER_TO_FPTR(Perl_magic_clearsig),
4980     0,
4981     0,
4982     0,
4983     0
4984 );
4985 #endif
4986
4987 MGVTBL_SET(
4988     PL_vtbl_pack,
4989     0,
4990     0,
4991     MEMBER_TO_FPTR(Perl_magic_sizepack),
4992     MEMBER_TO_FPTR(Perl_magic_wipepack),
4993     0,
4994     0,
4995     0,
4996     0
4997 );
4998
4999 MGVTBL_SET(
5000     PL_vtbl_packelem,
5001     MEMBER_TO_FPTR(Perl_magic_getpack),
5002     MEMBER_TO_FPTR(Perl_magic_setpack),
5003     0,
5004     MEMBER_TO_FPTR(Perl_magic_clearpack),
5005     0,
5006     0,
5007     0,
5008     0
5009 );
5010
5011 MGVTBL_SET(
5012     PL_vtbl_dbline,
5013     0,
5014     MEMBER_TO_FPTR(Perl_magic_setdbline),
5015     0,
5016     0,
5017     0,
5018     0,
5019     0,
5020     0
5021 );
5022
5023 MGVTBL_SET(
5024     PL_vtbl_isa,
5025     0,
5026     MEMBER_TO_FPTR(Perl_magic_setisa),
5027     0,
5028     MEMBER_TO_FPTR(Perl_magic_clearisa),
5029     0,
5030     0,
5031     0,
5032     0
5033 );
5034
5035 MGVTBL_SET(
5036     PL_vtbl_isaelem,
5037     0,
5038     MEMBER_TO_FPTR(Perl_magic_setisa),
5039     0,
5040     0,
5041     0,
5042     0,
5043     0,
5044     0
5045 );
5046
5047 MGVTBL_SET_CONST_MAGIC_GET(
5048     PL_vtbl_arylen,
5049     MEMBER_TO_FPTR(Perl_magic_getarylen),
5050     MEMBER_TO_FPTR(Perl_magic_setarylen),
5051     0,
5052     0,
5053     0,
5054     0,
5055     0,
5056     0
5057 );
5058
5059 MGVTBL_SET(
5060     PL_vtbl_arylen_p,
5061     0,
5062     0,
5063     0,
5064     0,
5065     MEMBER_TO_FPTR(Perl_magic_freearylen_p),
5066     0,
5067     0,
5068     0
5069 );
5070
5071 MGVTBL_SET(
5072     PL_vtbl_mglob,
5073     0,
5074     MEMBER_TO_FPTR(Perl_magic_setmglob),
5075     0,
5076     0,
5077     0,
5078     0,
5079     0,
5080     0
5081 );
5082
5083 MGVTBL_SET(
5084     PL_vtbl_nkeys,
5085     MEMBER_TO_FPTR(Perl_magic_getnkeys),
5086     MEMBER_TO_FPTR(Perl_magic_setnkeys),
5087     0,
5088     0,
5089     0,
5090     0,
5091     0,
5092     0
5093 );
5094
5095 MGVTBL_SET(
5096     PL_vtbl_taint,
5097     MEMBER_TO_FPTR(Perl_magic_gettaint),
5098     MEMBER_TO_FPTR(Perl_magic_settaint),
5099     0,
5100     0,
5101     0,
5102     0,
5103     0,
5104     0
5105 );
5106
5107 MGVTBL_SET(
5108     PL_vtbl_substr,
5109     MEMBER_TO_FPTR(Perl_magic_getsubstr),
5110     MEMBER_TO_FPTR(Perl_magic_setsubstr),
5111     0,
5112     0,
5113     0,
5114     0,
5115     0,
5116     0
5117 );
5118
5119 MGVTBL_SET(
5120     PL_vtbl_vec,
5121     MEMBER_TO_FPTR(Perl_magic_getvec),
5122     MEMBER_TO_FPTR(Perl_magic_setvec),
5123     0,
5124     0,
5125     0,
5126     0,
5127     0,
5128     0
5129 );
5130
5131 MGVTBL_SET(
5132     PL_vtbl_pos,
5133     MEMBER_TO_FPTR(Perl_magic_getpos),
5134     MEMBER_TO_FPTR(Perl_magic_setpos),
5135     0,
5136     0,
5137     0,
5138     0,
5139     0,
5140     0
5141 );
5142
5143 MGVTBL_SET(
5144     PL_vtbl_bm,
5145     0,
5146     MEMBER_TO_FPTR(Perl_magic_setregexp),
5147     0,
5148     0,
5149     0,
5150     0,
5151     0,
5152     0
5153 );
5154
5155 MGVTBL_SET(
5156     PL_vtbl_fm,
5157     0,
5158     MEMBER_TO_FPTR(Perl_magic_setregexp),
5159     0,
5160     0,
5161     0,
5162     0,
5163     0,
5164     0
5165 );
5166
5167 MGVTBL_SET(
5168     PL_vtbl_uvar,
5169     MEMBER_TO_FPTR(Perl_magic_getuvar),
5170     MEMBER_TO_FPTR(Perl_magic_setuvar),
5171     0,
5172     0,
5173     0,
5174     0,
5175     0,
5176     0
5177 );
5178
5179 MGVTBL_SET(
5180     PL_vtbl_defelem,
5181     MEMBER_TO_FPTR(Perl_magic_getdefelem),
5182     MEMBER_TO_FPTR(Perl_magic_setdefelem),
5183     0,
5184     0,
5185     0,
5186     0,
5187     0,
5188     0
5189 );
5190
5191 MGVTBL_SET(
5192     PL_vtbl_regexp,
5193     0,
5194     MEMBER_TO_FPTR(Perl_magic_setregexp),
5195     0,
5196     0,
5197     0,
5198     0,
5199     0,
5200     0
5201 );
5202
5203 MGVTBL_SET(
5204     PL_vtbl_regdata,
5205     0,
5206     0,
5207     MEMBER_TO_FPTR(Perl_magic_regdata_cnt),
5208     0,
5209     0,
5210     0,
5211     0,
5212     0
5213 );
5214
5215 MGVTBL_SET(
5216     PL_vtbl_regdatum,
5217     MEMBER_TO_FPTR(Perl_magic_regdatum_get),
5218     MEMBER_TO_FPTR(Perl_magic_regdatum_set),
5219     0,
5220     0,
5221     0,
5222     0,
5223     0,
5224     0
5225 );
5226
5227 MGVTBL_SET(
5228     PL_vtbl_amagic,
5229     0,
5230     MEMBER_TO_FPTR(Perl_magic_setamagic),
5231     0,
5232     0,
5233     MEMBER_TO_FPTR(Perl_magic_setamagic),
5234     0,
5235     0,
5236     0
5237 );
5238
5239 MGVTBL_SET(
5240     PL_vtbl_amagicelem,
5241     0,
5242     MEMBER_TO_FPTR(Perl_magic_setamagic),
5243     0,
5244     0,
5245     MEMBER_TO_FPTR(Perl_magic_setamagic),
5246     0,
5247     0,
5248     0
5249 );
5250
5251 MGVTBL_SET(
5252     PL_vtbl_backref,
5253     0,
5254     0,
5255     0,
5256     0,
5257     MEMBER_TO_FPTR(Perl_magic_killbackrefs),
5258     0,
5259     0,
5260     0
5261 );
5262
5263 MGVTBL_SET(
5264     PL_vtbl_ovrld,
5265     0,
5266     0,
5267     0,
5268     0,
5269     MEMBER_TO_FPTR(Perl_magic_freeovrld),
5270     0,
5271     0,
5272     0
5273 );
5274
5275 MGVTBL_SET(
5276     PL_vtbl_utf8,
5277     0,
5278     MEMBER_TO_FPTR(Perl_magic_setutf8),
5279     0,
5280     0,
5281     0,
5282     0,
5283     0,
5284     0
5285 );
5286 #ifdef USE_LOCALE_COLLATE
5287 MGVTBL_SET(
5288     PL_vtbl_collxfrm,
5289     0,
5290     MEMBER_TO_FPTR(Perl_magic_setcollxfrm),
5291     0,
5292     0,
5293     0,
5294     0,
5295     0,
5296     0
5297 );
5298 #endif
5299
5300 MGVTBL_SET(
5301     PL_vtbl_hintselem,
5302     0,
5303     MEMBER_TO_FPTR(Perl_magic_sethint),
5304     0,
5305     MEMBER_TO_FPTR(Perl_magic_clearhint),
5306     0,
5307     0,
5308     0,
5309     0
5310 );
5311
5312 #include "overload.h"
5313
5314 END_EXTERN_C
5315
5316 struct am_table {
5317   U32 flags;
5318   U32 was_ok_sub;
5319   long was_ok_am;
5320   long fallback;
5321   CV* table[NofAMmeth];
5322 };
5323 struct am_table_short {
5324   U32 flags;
5325   U32 was_ok_sub;
5326   long was_ok_am;
5327 };
5328 typedef struct am_table AMT;
5329 typedef struct am_table_short AMTS;
5330
5331 #define AMGfallNEVER    1
5332 #define AMGfallNO       2
5333 #define AMGfallYES      3
5334
5335 #define AMTf_AMAGIC             1
5336 #define AMTf_OVERLOADED         2
5337 #define AMT_AMAGIC(amt)         ((amt)->flags & AMTf_AMAGIC)
5338 #define AMT_AMAGIC_on(amt)      ((amt)->flags |= AMTf_AMAGIC)
5339 #define AMT_AMAGIC_off(amt)     ((amt)->flags &= ~AMTf_AMAGIC)
5340 #define AMT_OVERLOADED(amt)     ((amt)->flags & AMTf_OVERLOADED)
5341 #define AMT_OVERLOADED_on(amt)  ((amt)->flags |= AMTf_OVERLOADED)
5342 #define AMT_OVERLOADED_off(amt) ((amt)->flags &= ~AMTf_OVERLOADED)
5343
5344 #define StashHANDLER(stash,meth)        gv_handler((stash),CAT2(meth,_amg))
5345
5346 /*
5347  * some compilers like to redefine cos et alia as faster
5348  * (and less accurate?) versions called F_cos et cetera (Quidquid
5349  * latine dictum sit, altum viditur.)  This trick collides with
5350  * the Perl overloading (amg).  The following #defines fool both.
5351  */
5352
5353 #ifdef _FASTMATH
5354 #   ifdef atan2
5355 #       define F_atan2_amg  atan2_amg
5356 #   endif
5357 #   ifdef cos
5358 #       define F_cos_amg    cos_amg
5359 #   endif
5360 #   ifdef exp
5361 #       define F_exp_amg    exp_amg
5362 #   endif
5363 #   ifdef log
5364 #       define F_log_amg    log_amg
5365 #   endif
5366 #   ifdef pow
5367 #       define F_pow_amg    pow_amg
5368 #   endif
5369 #   ifdef sin
5370 #       define F_sin_amg    sin_amg
5371 #   endif
5372 #   ifdef sqrt
5373 #       define F_sqrt_amg   sqrt_amg
5374 #   endif
5375 #endif /* _FASTMATH */
5376
5377 #define PERLDB_ALL              (PERLDBf_SUB    | PERLDBf_LINE  |       \
5378                                  PERLDBf_NOOPT  | PERLDBf_INTER |       \
5379                                  PERLDBf_SUBLINE| PERLDBf_SINGLE|       \
5380                                  PERLDBf_NAMEEVAL| PERLDBf_NAMEANON |   \
5381                                  PERLDBf_SAVESRC)
5382                                         /* No _NONAME, _GOTO */
5383 #define PERLDBf_SUB             0x01    /* Debug sub enter/exit */
5384 #define PERLDBf_LINE            0x02    /* Keep line # */
5385 #define PERLDBf_NOOPT           0x04    /* Switch off optimizations */
5386 #define PERLDBf_INTER           0x08    /* Preserve more data for
5387                                            later inspections  */
5388 #define PERLDBf_SUBLINE         0x10    /* Keep subr source lines */
5389 #define PERLDBf_SINGLE          0x20    /* Start with single-step on */
5390 #define PERLDBf_NONAME          0x40    /* For _SUB: no name of the subr */
5391 #define PERLDBf_GOTO            0x80    /* Report goto: call DB::goto */
5392 #define PERLDBf_NAMEEVAL        0x100   /* Informative names for evals */
5393 #define PERLDBf_NAMEANON        0x200   /* Informative names for anon subs */
5394 #define PERLDBf_SAVESRC         0x400   /* Save source lines into @{"_<$filename"} */
5395 #define PERLDBf_SAVESRC_NOSUBS  0x800   /* Including evals that generate no subrouties */
5396 #define PERLDBf_SAVESRC_INVALID 0x1000  /* Save source that did not compile */
5397
5398 #define PERLDB_SUB      (PL_perldb && (PL_perldb & PERLDBf_SUB))
5399 #define PERLDB_LINE     (PL_perldb && (PL_perldb & PERLDBf_LINE))
5400 #define PERLDB_NOOPT    (PL_perldb && (PL_perldb & PERLDBf_NOOPT))
5401 #define PERLDB_INTER    (PL_perldb && (PL_perldb & PERLDBf_INTER))
5402 #define PERLDB_SUBLINE  (PL_perldb && (PL_perldb & PERLDBf_SUBLINE))
5403 #define PERLDB_SINGLE   (PL_perldb && (PL_perldb & PERLDBf_SINGLE))
5404 #define PERLDB_SUB_NN   (PL_perldb && (PL_perldb & (PERLDBf_NONAME)))
5405 #define PERLDB_GOTO     (PL_perldb && (PL_perldb & PERLDBf_GOTO))
5406 #define PERLDB_NAMEEVAL (PL_perldb && (PL_perldb & PERLDBf_NAMEEVAL))
5407 #define PERLDB_NAMEANON (PL_perldb && (PL_perldb & PERLDBf_NAMEANON))
5408 #define PERLDB_SAVESRC  (PL_perldb && (PL_perldb & PERLDBf_SAVESRC))
5409 #define PERLDB_SAVESRC_NOSUBS   (PL_perldb && (PL_perldb & PERLDBf_SAVESRC_NOSUBS))
5410 #define PERLDB_SAVESRC_INVALID  (PL_perldb && (PL_perldb & PERLDBf_SAVESRC_INVALID))
5411
5412 #ifdef USE_LOCALE_NUMERIC
5413
5414 #define SET_NUMERIC_STANDARD() \
5415         set_numeric_standard();
5416
5417 #define SET_NUMERIC_LOCAL() \
5418         set_numeric_local();
5419
5420 #define IN_LOCALE_RUNTIME       (CopHINTS_get(PL_curcop) & HINT_LOCALE)
5421 #define IN_LOCALE_COMPILETIME   (PL_hints & HINT_LOCALE)
5422
5423 #define IN_LOCALE \
5424         (IN_PERL_COMPILETIME ? IN_LOCALE_COMPILETIME : IN_LOCALE_RUNTIME)
5425
5426 #define STORE_NUMERIC_LOCAL_SET_STANDARD() \
5427         bool was_local = PL_numeric_local && IN_LOCALE; \
5428         if (was_local) SET_NUMERIC_STANDARD();
5429
5430 #define STORE_NUMERIC_STANDARD_SET_LOCAL() \
5431         bool was_standard = PL_numeric_standard && IN_LOCALE; \
5432         if (was_standard) SET_NUMERIC_LOCAL();
5433
5434 #define RESTORE_NUMERIC_LOCAL() \
5435         if (was_local) SET_NUMERIC_LOCAL();
5436
5437 #define RESTORE_NUMERIC_STANDARD() \
5438         if (was_standard) SET_NUMERIC_STANDARD();
5439
5440 #define Atof                            my_atof
5441
5442 #else /* !USE_LOCALE_NUMERIC */
5443
5444 #define SET_NUMERIC_STANDARD()          /**/
5445 #define SET_NUMERIC_LOCAL()             /**/
5446 #define IS_NUMERIC_RADIX(a, b)          (0)
5447 #define STORE_NUMERIC_LOCAL_SET_STANDARD()      /**/
5448 #define STORE_NUMERIC_STANDARD_SET_LOCAL()      /**/
5449 #define RESTORE_NUMERIC_LOCAL()         /**/
5450 #define RESTORE_NUMERIC_STANDARD()      /**/
5451 #define Atof                            my_atof
5452 #define IN_LOCALE_RUNTIME               0
5453
5454 #endif /* !USE_LOCALE_NUMERIC */
5455
5456 #if !defined(Strtol) && defined(USE_64_BIT_INT) && defined(IV_IS_QUAD) && QUADKIND == QUAD_IS_LONG_LONG
5457 #    ifdef __hpux
5458 #        define strtoll __strtoll       /* secret handshake */
5459 #    endif
5460 #    ifdef WIN64
5461 #        define strtoll _strtoi64       /* secret handshake */
5462 #    endif
5463 #   if !defined(Strtol) && defined(HAS_STRTOLL)
5464 #       define Strtol   strtoll
5465 #   endif
5466 #    if !defined(Strtol) && defined(HAS_STRTOQ)
5467 #       define Strtol   strtoq
5468 #    endif
5469 /* is there atoq() anywhere? */
5470 #endif
5471 #if !defined(Strtol) && defined(HAS_STRTOL)
5472 #   define Strtol       strtol
5473 #endif
5474 #ifndef Atol
5475 /* It would be more fashionable to use Strtol() to define atol()
5476  * (as is done for Atoul(), see below) but for backward compatibility
5477  * we just assume atol(). */
5478 #   if defined(USE_64_BIT_INT) && defined(IV_IS_QUAD) && QUADKIND == QUAD_IS_LONG_LONG && defined(HAS_ATOLL)
5479 #    ifdef WIN64
5480 #       define atoll    _atoi64         /* secret handshake */
5481 #    endif
5482 #       define Atol     atoll
5483 #   else
5484 #       define Atol     atol
5485 #   endif
5486 #endif
5487
5488 #if !defined(Strtoul) && defined(USE_64_BIT_INT) && defined(UV_IS_QUAD) && QUADKIND == QUAD_IS_LONG_LONG
5489 #    ifdef __hpux
5490 #        define strtoull __strtoull     /* secret handshake */
5491 #    endif
5492 #    ifdef WIN64
5493 #        define strtoull _strtoui64     /* secret handshake */
5494 #    endif
5495 #    if !defined(Strtoul) && defined(HAS_STRTOULL)
5496 #       define Strtoul  strtoull
5497 #    endif
5498 #    if !defined(Strtoul) && defined(HAS_STRTOUQ)
5499 #       define Strtoul  strtouq
5500 #    endif
5501 /* is there atouq() anywhere? */
5502 #endif
5503 #if !defined(Strtoul) && defined(HAS_STRTOUL)
5504 #   define Strtoul      strtoul
5505 #endif
5506 #if !defined(Strtoul) && defined(HAS_STRTOL) /* Last resort. */
5507 #   define Strtoul(s, e, b)     strchr((s), '-') ? ULONG_MAX : (unsigned long)strtol((s), (e), (b))
5508 #endif
5509 #ifndef Atoul
5510 #   define Atoul(s)     Strtoul(s, NULL, 10)
5511 #endif
5512
5513
5514 /* if these never got defined, they need defaults */
5515 #ifndef PERL_SET_CONTEXT
5516 #  define PERL_SET_CONTEXT(i)           PERL_SET_INTERP(i)
5517 #endif
5518
5519 #ifndef PERL_GET_CONTEXT
5520 #  define PERL_GET_CONTEXT              PERL_GET_INTERP
5521 #endif
5522
5523 #ifndef PERL_GET_THX
5524 #  define PERL_GET_THX                  ((void*)NULL)
5525 #endif
5526
5527 #ifndef PERL_SET_THX
5528 #  define PERL_SET_THX(t)               NOOP
5529 #endif
5530
5531 #ifndef PERL_SCRIPT_MODE
5532 #define PERL_SCRIPT_MODE "r"
5533 #endif
5534
5535 /*
5536  * Some operating systems are stingy with stack allocation,
5537  * so perl may have to guard against stack overflow.
5538  */
5539 #ifndef PERL_STACK_OVERFLOW_CHECK
5540 #define PERL_STACK_OVERFLOW_CHECK()  NOOP
5541 #endif
5542
5543 /*
5544  * Some nonpreemptive operating systems find it convenient to
5545  * check for asynchronous conditions after each op execution.
5546  * Keep this check simple, or it may slow down execution
5547  * massively.
5548  */
5549
5550 #ifndef PERL_MICRO
5551 #       ifndef PERL_ASYNC_CHECK
5552 #               define PERL_ASYNC_CHECK() if (PL_sig_pending) despatch_signals()
5553 #       endif
5554 #endif
5555
5556 #ifndef PERL_ASYNC_CHECK
5557 #   define PERL_ASYNC_CHECK()  NOOP
5558 #endif
5559
5560 /*
5561  * On some operating systems, a memory allocation may succeed,
5562  * but put the process too close to the system's comfort limit.
5563  * In this case, PERL_ALLOC_CHECK frees the pointer and sets
5564  * it to NULL.
5565  */
5566 #ifndef PERL_ALLOC_CHECK
5567 #define PERL_ALLOC_CHECK(p)  NOOP
5568 #endif
5569
5570 #ifdef HAS_SEM
5571 #   include <sys/ipc.h>
5572 #   include <sys/sem.h>
5573 #   ifndef HAS_UNION_SEMUN      /* Provide the union semun. */
5574     union semun {
5575         int             val;
5576         struct semid_ds *buf;
5577         unsigned short  *array;
5578     };
5579 #   endif
5580 #   ifdef USE_SEMCTL_SEMUN
5581 #       ifdef IRIX32_SEMUN_BROKEN_BY_GCC
5582             union gccbug_semun {
5583                 int             val;
5584                 struct semid_ds *buf;
5585                 unsigned short  *array;
5586                 char            __dummy[5];
5587             };
5588 #           define semun gccbug_semun
5589 #       endif
5590 #       define Semctl(id, num, cmd, semun) semctl(id, num, cmd, semun)
5591 #   else
5592 #       ifdef USE_SEMCTL_SEMID_DS
5593 #           ifdef EXTRA_F_IN_SEMUN_BUF
5594 #               define Semctl(id, num, cmd, semun) semctl(id, num, cmd, semun.buff)
5595 #           else
5596 #               define Semctl(id, num, cmd, semun) semctl(id, num, cmd, semun.buf)
5597 #           endif
5598 #       endif
5599 #   endif
5600 #endif
5601
5602 /*
5603  * Boilerplate macros for initializing and accessing interpreter-local
5604  * data from C.  All statics in extensions should be reworked to use
5605  * this, if you want to make the extension thread-safe.  See
5606  * ext/XS/APItest/APItest.xs for an example of the use of these macros,
5607  * and perlxs.pod for more.
5608  *
5609  * Code that uses these macros is responsible for the following:
5610  * 1. #define MY_CXT_KEY to a unique string, e.g.
5611  *    "DynaLoader::_guts" XS_VERSION
5612  *    XXX in the current implementation, this string is ignored.
5613  * 2. Declare a typedef named my_cxt_t that is a structure that contains
5614  *    all the data that needs to be interpreter-local.
5615  * 3. Use the START_MY_CXT macro after the declaration of my_cxt_t.
5616  * 4. Use the MY_CXT_INIT macro such that it is called exactly once
5617  *    (typically put in the BOOT: section).
5618  * 5. Use the members of the my_cxt_t structure everywhere as
5619  *    MY_CXT.member.
5620  * 6. Use the dMY_CXT macro (a declaration) in all the functions that
5621  *    access MY_CXT.
5622  */
5623
5624 #if defined(PERL_IMPLICIT_CONTEXT)
5625
5626 #ifdef PERL_GLOBAL_STRUCT_PRIVATE
5627
5628 /* This must appear in all extensions that define a my_cxt_t structure,
5629  * right after the definition (i.e. at file scope).  The non-threads
5630  * case below uses it to declare the data as static. */
5631 #define START_MY_CXT
5632 #define MY_CXT_INDEX Perl_my_cxt_index(aTHX_ MY_CXT_KEY)
5633
5634 /* Creates and zeroes the per-interpreter data.
5635  * (We allocate my_cxtp in a Perl SV so that it will be released when
5636  * the interpreter goes away.) */
5637 #define MY_CXT_INIT \
5638         my_cxt_t *my_cxtp = \
5639             (my_cxt_t*)Perl_my_cxt_init(aTHX_ MY_CXT_KEY, sizeof(my_cxt_t))
5640 #define MY_CXT_INIT_INTERP(my_perl) \
5641         my_cxt_t *my_cxtp = \
5642             (my_cxt_t*)Perl_my_cxt_init(my_perl, MY_CXT_KEY, sizeof(my_cxt_t))
5643
5644 /* This declaration should be used within all functions that use the
5645  * interpreter-local data. */
5646 #define dMY_CXT \
5647         my_cxt_t *my_cxtp = (my_cxt_t *)PL_my_cxt_list[MY_CXT_INDEX]
5648 #define dMY_CXT_INTERP(my_perl) \
5649         my_cxt_t *my_cxtp = (my_cxt_t *)(my_perl)->Imy_cxt_list[MY_CXT_INDEX]
5650
5651 /* Clones the per-interpreter data. */
5652 #define MY_CXT_CLONE \
5653         my_cxt_t *my_cxtp = (my_cxt_t*)SvPVX(newSV(sizeof(my_cxt_t)-1));\
5654         Copy(PL_my_cxt_list[MY_CXT_INDEX], my_cxtp, 1, my_cxt_t);\
5655         PL_my_cxt_list[MY_CXT_INDEX] = my_cxtp                          \
5656
5657 #else /* #ifdef PERL_GLOBAL_STRUCT_PRIVATE */
5658
5659 /* This must appear in all extensions that define a my_cxt_t structure,
5660  * right after the definition (i.e. at file scope).  The non-threads
5661  * case below uses it to declare the data as static. */
5662 #define START_MY_CXT static int my_cxt_index = -1;
5663
5664 /* This declaration should be used within all functions that use the
5665  * interpreter-local data. */
5666 #define dMY_CXT \
5667         my_cxt_t *my_cxtp = (my_cxt_t *)PL_my_cxt_list[my_cxt_index]
5668 #define dMY_CXT_INTERP(my_perl) \
5669         my_cxt_t *my_cxtp = (my_cxt_t *)(my_perl)->Imy_cxt_list[my_cxt_index]
5670
5671 /* Creates and zeroes the per-interpreter data.
5672  * (We allocate my_cxtp in a Perl SV so that it will be released when
5673  * the interpreter goes away.) */
5674 #define MY_CXT_INIT \
5675         my_cxt_t *my_cxtp = \
5676             (my_cxt_t*)Perl_my_cxt_init(aTHX_ &my_cxt_index, sizeof(my_cxt_t))
5677 #define MY_CXT_INIT_INTERP(my_perl) \
5678         my_cxt_t *my_cxtp = \
5679             (my_cxt_t*)Perl_my_cxt_init(my_perl, &my_cxt_index, sizeof(my_cxt_t))
5680
5681 /* Clones the per-interpreter data. */
5682 #define MY_CXT_CLONE \
5683         my_cxt_t *my_cxtp = (my_cxt_t*)SvPVX(newSV(sizeof(my_cxt_t)-1));\
5684         Copy(PL_my_cxt_list[my_cxt_index], my_cxtp, 1, my_cxt_t);\
5685         PL_my_cxt_list[my_cxt_index] = my_cxtp                          \
5686
5687 #endif /* #ifdef PERL_GLOBAL_STRUCT_PRIVATE */
5688
5689 /* This macro must be used to access members of the my_cxt_t structure.
5690  * e.g. MYCXT.some_data */
5691 #define MY_CXT          (*my_cxtp)
5692
5693 /* Judicious use of these macros can reduce the number of times dMY_CXT
5694  * is used.  Use is similar to pTHX, aTHX etc. */
5695 #define pMY_CXT         my_cxt_t *my_cxtp
5696 #define pMY_CXT_        pMY_CXT,
5697 #define _pMY_CXT        ,pMY_CXT
5698 #define aMY_CXT         my_cxtp
5699 #define aMY_CXT_        aMY_CXT,
5700 #define _aMY_CXT        ,aMY_CXT
5701
5702 #else /* PERL_IMPLICIT_CONTEXT */
5703
5704 #define START_MY_CXT    static my_cxt_t my_cxt;
5705 #define dMY_CXT_SV      dNOOP
5706 #define dMY_CXT         dNOOP
5707 #define dMY_CXT_INTERP(my_perl) dNOOP
5708 #define MY_CXT_INIT     NOOP
5709 #define MY_CXT_CLONE    NOOP
5710 #define MY_CXT          my_cxt
5711
5712 #define pMY_CXT         void
5713 #define pMY_CXT_
5714 #define _pMY_CXT
5715 #define aMY_CXT
5716 #define aMY_CXT_
5717 #define _aMY_CXT
5718
5719 #endif /* !defined(PERL_IMPLICIT_CONTEXT) */
5720
5721 #ifdef I_FCNTL
5722 #  include <fcntl.h>
5723 #endif
5724
5725 #ifdef __Lynx__
5726 #  include <fcntl.h>
5727 #endif
5728
5729 #ifdef I_SYS_FILE
5730 #  include <sys/file.h>
5731 #endif
5732
5733 #if defined(HAS_FLOCK) && !defined(HAS_FLOCK_PROTO)
5734 int flock(int fd, int op);
5735 #endif
5736
5737 #ifndef O_RDONLY
5738 /* Assume UNIX defaults */
5739 #    define O_RDONLY    0000
5740 #    define O_WRONLY    0001
5741 #    define O_RDWR      0002
5742 #    define O_CREAT     0100
5743 #endif
5744
5745 #ifndef O_BINARY
5746 #  define O_BINARY 0
5747 #endif
5748
5749 #ifndef O_TEXT
5750 #  define O_TEXT 0
5751 #endif
5752
5753 #if O_TEXT != O_BINARY
5754     /* If you have different O_TEXT and O_BINARY and you are a CLRF shop,
5755      * that is, you are somehow DOSish. */
5756 #   if defined(__BEOS__) || defined(__HAIKU__) || defined(__VOS__) || \
5757         defined(__CYGWIN__)
5758     /* BeOS/Haiku has O_TEXT != O_BINARY but O_TEXT and O_BINARY have no effect;
5759      * BeOS/Haiku is always UNIXoid (LF), not DOSish (CRLF). */
5760     /* VOS has O_TEXT != O_BINARY, and they have effect,
5761      * but VOS always uses LF, never CRLF. */
5762     /* If you have O_TEXT different from your O_BINARY but you still are
5763      * not a CRLF shop. */
5764 #       undef PERLIO_USING_CRLF
5765 #   else
5766     /* If you really are DOSish. */
5767 #      define PERLIO_USING_CRLF 1
5768 #   endif
5769 #endif
5770
5771 #ifdef I_LIBUTIL
5772 #   include <libutil.h>         /* setproctitle() in some FreeBSDs */
5773 #endif
5774
5775 #ifndef EXEC_ARGV_CAST
5776 #define EXEC_ARGV_CAST(x) (char **)x
5777 #endif
5778
5779 #define IS_NUMBER_IN_UV               0x01 /* number within UV range (maybe not
5780                                               int).  value returned in pointed-
5781                                               to UV */
5782 #define IS_NUMBER_GREATER_THAN_UV_MAX 0x02 /* pointed to UV undefined */
5783 #define IS_NUMBER_NOT_INT             0x04 /* saw . or E notation */
5784 #define IS_NUMBER_NEG                 0x08 /* leading minus sign */
5785 #define IS_NUMBER_INFINITY            0x10 /* this is big */
5786 #define IS_NUMBER_NAN                 0x20 /* this is not */
5787
5788 #define GROK_NUMERIC_RADIX(sp, send) grok_numeric_radix(sp, send)
5789
5790 /* Input flags: */
5791 #define PERL_SCAN_ALLOW_UNDERSCORES   0x01 /* grok_??? accept _ in numbers */
5792 #define PERL_SCAN_DISALLOW_PREFIX     0x02 /* grok_??? reject 0x in hex etc */
5793 #define PERL_SCAN_SILENT_ILLDIGIT     0x04 /* grok_??? not warn about illegal digits */
5794 /* Output flags: */
5795 #define PERL_SCAN_GREATER_THAN_UV_MAX 0x02 /* should this merge with above? */
5796
5797 /* to let user control profiling */
5798 #ifdef PERL_GPROF_CONTROL
5799 extern void moncontrol(int);
5800 #define PERL_GPROF_MONCONTROL(x) moncontrol(x)
5801 #else
5802 #define PERL_GPROF_MONCONTROL(x)
5803 #endif
5804
5805 #ifdef UNDER_CE
5806 #include "wince.h"
5807 #endif
5808
5809 /* ISO 6429 NEL - C1 control NExt Line */
5810 /* See http://www.unicode.org/unicode/reports/tr13/ */
5811 #ifdef EBCDIC   /* In EBCDIC NEL is just an alias for LF */
5812 #   if '^' == 95        /* CP 1047: MVS OpenEdition - OS/390 - z/OS */
5813 #       define NEXT_LINE_CHAR   0x15
5814 #   else                /* CDRA */
5815 #       define NEXT_LINE_CHAR   0x25
5816 #   endif
5817 #else
5818 #   define NEXT_LINE_CHAR       0x85
5819 #endif
5820
5821 /* The UTF-8 bytes of the Unicode LS and PS, U+2028 and U+2029 */
5822 #define UNICODE_LINE_SEPA_0     0xE2
5823 #define UNICODE_LINE_SEPA_1     0x80
5824 #define UNICODE_LINE_SEPA_2     0xA8
5825 #define UNICODE_PARA_SEPA_0     0xE2
5826 #define UNICODE_PARA_SEPA_1     0x80
5827 #define UNICODE_PARA_SEPA_2     0xA9
5828
5829 #ifndef PIPESOCK_MODE
5830 #  define PIPESOCK_MODE
5831 #endif
5832
5833 #ifndef SOCKET_OPEN_MODE
5834 #  define SOCKET_OPEN_MODE      PIPESOCK_MODE
5835 #endif
5836
5837 #ifndef PIPE_OPEN_MODE
5838 #  define PIPE_OPEN_MODE        PIPESOCK_MODE
5839 #endif
5840
5841 #define PERL_MAGIC_UTF8_CACHESIZE       2
5842
5843 #define PERL_UNICODE_STDIN_FLAG                 0x0001
5844 #define PERL_UNICODE_STDOUT_FLAG                0x0002
5845 #define PERL_UNICODE_STDERR_FLAG                0x0004
5846 #define PERL_UNICODE_IN_FLAG                    0x0008
5847 #define PERL_UNICODE_OUT_FLAG                   0x0010
5848 #define PERL_UNICODE_ARGV_FLAG                  0x0020
5849 #define PERL_UNICODE_LOCALE_FLAG                0x0040
5850 #define PERL_UNICODE_WIDESYSCALLS_FLAG          0x0080 /* for Sarathy */
5851 #define PERL_UNICODE_UTF8CACHEASSERT_FLAG       0x0100
5852
5853 #define PERL_UNICODE_STD_FLAG           \
5854         (PERL_UNICODE_STDIN_FLAG        | \
5855          PERL_UNICODE_STDOUT_FLAG       | \
5856          PERL_UNICODE_STDERR_FLAG)
5857
5858 #define PERL_UNICODE_INOUT_FLAG         \
5859         (PERL_UNICODE_IN_FLAG   | \
5860          PERL_UNICODE_OUT_FLAG)
5861
5862 #define PERL_UNICODE_DEFAULT_FLAGS      \
5863         (PERL_UNICODE_STD_FLAG          | \
5864          PERL_UNICODE_INOUT_FLAG        | \
5865          PERL_UNICODE_LOCALE_FLAG)
5866
5867 #define PERL_UNICODE_ALL_FLAGS                  0x01ff
5868
5869 #define PERL_UNICODE_STDIN                      'I'
5870 #define PERL_UNICODE_STDOUT                     'O'
5871 #define PERL_UNICODE_STDERR                     'E'
5872 #define PERL_UNICODE_STD                        'S'
5873 #define PERL_UNICODE_IN                         'i'
5874 #define PERL_UNICODE_OUT                        'o'
5875 #define PERL_UNICODE_INOUT                      'D'
5876 #define PERL_UNICODE_ARGV                       'A'
5877 #define PERL_UNICODE_LOCALE                     'L'
5878 #define PERL_UNICODE_WIDESYSCALLS               'W'
5879 #define PERL_UNICODE_UTF8CACHEASSERT            'a'
5880
5881 #define PERL_SIGNALS_UNSAFE_FLAG        0x0001
5882
5883 /* From sigaction(2) (FreeBSD man page):
5884  * | Signal routines normally execute with the signal that
5885  * | caused their invocation blocked, but other signals may
5886  * | yet occur.
5887  * Emulation of this behavior (from within Perl) is enabled
5888  * by defining PERL_BLOCK_SIGNALS.
5889  */
5890 #define PERL_BLOCK_SIGNALS
5891
5892 #if defined(HAS_SIGPROCMASK) && defined(PERL_BLOCK_SIGNALS)
5893 #   define PERL_BLOCKSIG_ADD(set,sig) \
5894         sigset_t set; sigemptyset(&(set)); sigaddset(&(set), sig)
5895 #   define PERL_BLOCKSIG_BLOCK(set) \
5896         sigprocmask(SIG_BLOCK, &(set), NULL)
5897 #   define PERL_BLOCKSIG_UNBLOCK(set) \
5898         sigprocmask(SIG_UNBLOCK, &(set), NULL)
5899 #endif /* HAS_SIGPROCMASK && PERL_BLOCK_SIGNALS */
5900
5901 /* How about the old style of sigblock()? */
5902
5903 #ifndef PERL_BLOCKSIG_ADD
5904 #   define PERL_BLOCKSIG_ADD(set, sig)  NOOP
5905 #endif
5906 #ifndef PERL_BLOCKSIG_BLOCK
5907 #   define PERL_BLOCKSIG_BLOCK(set)     NOOP
5908 #endif
5909 #ifndef PERL_BLOCKSIG_UNBLOCK
5910 #   define PERL_BLOCKSIG_UNBLOCK(set)   NOOP
5911 #endif
5912
5913 /* Use instead of abs() since abs() forces its argument to be an int,
5914  * but also beware since this evaluates its argument twice, so no x++. */
5915 #define PERL_ABS(x) ((x) < 0 ? -(x) : (x))
5916
5917 #if defined(__DECC) && defined(__osf__)
5918 #pragma message disable (mainparm) /* Perl uses the envp in main(). */
5919 #endif
5920
5921 #define do_open(g, n, l, a, rm, rp, sf) \
5922         do_openn(g, n, l, a, rm, rp, sf, (SV **) NULL, 0)
5923 #ifdef PERL_DEFAULT_DO_EXEC3_IMPLEMENTATION
5924 #  define do_exec(cmd)                  do_exec3(cmd,0,0)
5925 #endif
5926 #ifdef OS2
5927 #  define do_aexec                      Perl_do_aexec
5928 #else
5929 #  define do_aexec(really, mark,sp)     do_aexec5(really, mark, sp, 0, 0)
5930 #endif
5931
5932 #if defined(OEMVS)
5933 #define NO_ENV_ARRAY_IN_MAIN
5934 #endif
5935
5936 /* These are used by Perl_pv_escape() and Perl_pv_pretty() 
5937  * are here so that they are available throughout the core 
5938  * NOTE that even though some are for _escape and some for _pretty
5939  * there must not be any clashes as the flags from _pretty are
5940  * passed straight through to _escape.
5941  */
5942
5943 #define PERL_PV_ESCAPE_QUOTE        0x0001
5944 #define PERL_PV_PRETTY_QUOTE        PERL_PV_ESCAPE_QUOTE
5945
5946 #define PERL_PV_PRETTY_ELLIPSES     0x0002
5947 #define PERL_PV_PRETTY_LTGT         0x0004
5948
5949 #define PERL_PV_ESCAPE_FIRSTCHAR    0x0008
5950
5951 #define PERL_PV_ESCAPE_UNI          0x0100     
5952 #define PERL_PV_ESCAPE_UNI_DETECT   0x0200
5953
5954 #define PERL_PV_ESCAPE_ALL          0x1000
5955 #define PERL_PV_ESCAPE_NOBACKSLASH  0x2000
5956 #define PERL_PV_ESCAPE_NOCLEAR      0x4000
5957 #define PERL_PV_ESCAPE_RE           0x8000
5958
5959 #define PERL_PV_PRETTY_NOCLEAR      PERL_PV_ESCAPE_NOCLEAR
5960
5961 /* used by pv_display in dump.c*/
5962 #define PERL_PV_PRETTY_DUMP  PERL_PV_PRETTY_ELLIPSES|PERL_PV_PRETTY_QUOTE
5963 #define PERL_PV_PRETTY_REGPROP PERL_PV_PRETTY_ELLIPSES|PERL_PV_PRETTY_LTGT|PERL_PV_ESCAPE_RE
5964
5965 /*
5966
5967    (KEEP THIS LAST IN perl.h!)
5968
5969    Mention
5970
5971    NV_PRESERVES_UV
5972
5973    HAS_MKSTEMP
5974    HAS_MKSTEMPS
5975    HAS_MKDTEMP
5976
5977    HAS_GETCWD
5978
5979    HAS_MMAP
5980    HAS_MPROTECT
5981    HAS_MSYNC
5982    HAS_MADVISE
5983    HAS_MUNMAP
5984    I_SYSMMAN
5985    Mmap_t
5986
5987    NVef
5988    NVff
5989    NVgf
5990
5991    HAS_UALARM
5992    HAS_USLEEP
5993
5994    HAS_SETITIMER
5995    HAS_GETITIMER
5996
5997    HAS_SENDMSG
5998    HAS_RECVMSG
5999    HAS_READV
6000    HAS_WRITEV
6001    I_SYSUIO
6002    HAS_STRUCT_MSGHDR
6003    HAS_STRUCT_CMSGHDR
6004
6005    HAS_NL_LANGINFO
6006
6007    HAS_DIRFD
6008
6009    so that Configure picks them up.
6010
6011    (KEEP THIS LAST IN perl.h!)
6012
6013 */
6014
6015 #endif /* Include guard */
6016
6017 #define CLEAR_ERRSV() STMT_START { sv_setpvn(ERRSV,"",0); if (SvMAGICAL(ERRSV)) { mg_free(ERRSV); } SvPOK_only(ERRSV); } STMT_END
6018
6019 /*
6020  * Local variables:
6021  * c-indentation-style: bsd
6022  * c-basic-offset: 4
6023  * indent-tabs-mode: t
6024  * End:
6025  *
6026  * ex: set ts=8 sts=4 sw=4 noet:
6027  */