c344105725f43cf775bc2cbf2261a27bfe8d8fe8
[p5sagit/p5-mst-13.2.git] / perl.h
1 /*    perl.h
2  *
3  *    Copyright (c) 1987-1997, Larry Wall
4  *
5  *    You may distribute under the terms of either the GNU General Public
6  *    License or the Artistic License, as specified in the README file.
7  *
8  */
9 #ifndef H_PERL
10 #define H_PERL 1
11 #define OVERLOAD
12
13 #ifdef PERL_FOR_X2P
14 /*
15  * This file is being used for x2p stuff. 
16  * Above symbol is defined via -D in 'x2p/Makefile.SH'
17  * Decouple x2p stuff from some of perls more extreme eccentricities. 
18  */
19 #undef EMBED
20 #undef NO_EMBED
21 #define NO_EMBED
22 #undef MULTIPLICITY
23 #undef USE_STDIO
24 #define USE_STDIO
25 #endif /* PERL_FOR_X2P */
26
27 #define VOIDUSED 1
28 #include "config.h"
29
30 #include "embed.h"
31
32 #ifdef OP_IN_REGISTER
33 #  ifdef __GNUC__
34 #    define stringify_immed(s) #s
35 #    define stringify(s) stringify_immed(s)
36 register struct op *op asm(stringify(OP_IN_REGISTER));
37 #  endif
38 #endif
39
40 /*
41  * STMT_START { statements; } STMT_END;
42  * can be used as a single statement, as in
43  * if (x) STMT_START { ... } STMT_END; else ...
44  *
45  * Trying to select a version that gives no warnings...
46  */
47 #if !(defined(STMT_START) && defined(STMT_END))
48 # if defined(__GNUC__) && !defined(__STRICT_ANSI__) && !defined(__cplusplus)
49 #   define STMT_START   (void)( /* gcc supports ``({ STATEMENTS; })'' */
50 #   define STMT_END     )
51 # else
52    /* Now which other defined()s do we need here ??? */
53 #  if (VOIDFLAGS) && (defined(sun) || defined(__sun__))
54 #   define STMT_START   if (1)
55 #   define STMT_END     else (void)0
56 #  else
57 #   define STMT_START   do
58 #   define STMT_END     while (0)
59 #  endif
60 # endif
61 #endif
62
63 #define NOOP (void)0
64
65 #define WITH_THR(s) do { dTHR; s; } while (0)
66
67 #ifdef USE_THREADS
68 #  ifdef FAKE_THREADS
69 #    include "fakethr.h"
70 #  else
71 #    ifdef WIN32
72 #      include "win32/win32thread.h"
73 #    else
74 #      include <pthread.h>
75 typedef pthread_mutex_t perl_mutex;
76 typedef pthread_cond_t perl_cond;
77 typedef pthread_key_t perl_key;
78 #    endif /* WIN32 */
79 #  endif /* FAKE_THREADS */
80 #endif /* USE_THREADS */
81
82 /*
83  * SOFT_CAST can be used for args to prototyped functions to retain some
84  * type checking; it only casts if the compiler does not know prototypes.
85  */
86 #if defined(CAN_PROTOTYPE) && defined(DEBUGGING_COMPILE)
87 #define SOFT_CAST(type) 
88 #else
89 #define SOFT_CAST(type) (type)
90 #endif
91
92 #ifndef BYTEORDER
93 #   define BYTEORDER 0x1234
94 #endif
95
96 /* Overall memory policy? */
97 #ifndef CONSERVATIVE
98 #   define LIBERAL 1
99 #endif
100
101 /*
102  * The following contortions are brought to you on behalf of all the
103  * standards, semi-standards, de facto standards, not-so-de-facto standards
104  * of the world, as well as all the other botches anyone ever thought of.
105  * The basic theory is that if we work hard enough here, the rest of the
106  * code can be a lot prettier.  Well, so much for theory.  Sorry, Henry...
107  */
108
109 /* define this once if either system, instead of cluttering up the src */
110 #if defined(MSDOS) || defined(atarist) || defined(WIN32)
111 #define DOSISH 1
112 #endif
113
114 #if defined(__STDC__) || defined(vax11c) || defined(_AIX) || defined(__stdc__) || defined(__cplusplus)
115 # define STANDARD_C 1
116 #endif
117
118 #if defined(__cplusplus) || defined(WIN32)
119 # define DONT_DECLARE_STD 1
120 #endif
121
122 #if defined(HASVOLATILE) || defined(STANDARD_C)
123 #   ifdef __cplusplus
124 #       define VOL              // to temporarily suppress warnings
125 #   else
126 #       define VOL volatile
127 #   endif
128 #else
129 #   define VOL
130 #endif
131
132 #define TAINT           (tainted = TRUE)
133 #define TAINT_NOT       (tainted = FALSE)
134 #define TAINT_IF(c)     if (c) { tainted = TRUE; }
135 #define TAINT_ENV()     if (tainting) { taint_env(); }
136 #define TAINT_PROPER(s) if (tainting) { taint_proper(no_security, s); }
137
138 /* XXX All process group stuff is handled in pp_sys.c.  Should these 
139    defines move there?  If so, I could simplify this a lot. --AD  9/96.
140 */
141 /* Process group stuff changed from traditional BSD to POSIX.
142    perlfunc.pod documents the traditional BSD-style syntax, so we'll
143    try to preserve that, if possible.
144 */
145 #ifdef HAS_SETPGID
146 #  define BSD_SETPGRP(pid, pgrp)        setpgid((pid), (pgrp))
147 #else
148 #  if defined(HAS_SETPGRP) && defined(USE_BSD_SETPGRP)
149 #    define BSD_SETPGRP(pid, pgrp)      setpgrp((pid), (pgrp))
150 #  else
151 #    ifdef HAS_SETPGRP2  /* DG/UX */
152 #      define BSD_SETPGRP(pid, pgrp)    setpgrp2((pid), (pgrp))
153 #    endif
154 #  endif
155 #endif
156 #if defined(BSD_SETPGRP) && !defined(HAS_SETPGRP)
157 #  define HAS_SETPGRP  /* Well, effectively it does . . . */
158 #endif
159
160 /* getpgid isn't POSIX, but at least Solaris and Linux have it, and it makes
161     our life easier :-) so we'll try it.
162 */
163 #ifdef HAS_GETPGID
164 #  define BSD_GETPGRP(pid)              getpgid((pid))
165 #else
166 #  if defined(HAS_GETPGRP) && defined(USE_BSD_GETPGRP)
167 #    define BSD_GETPGRP(pid)            getpgrp((pid))
168 #  else
169 #    ifdef HAS_GETPGRP2  /* DG/UX */
170 #      define BSD_GETPGRP(pid)          getpgrp2((pid))
171 #    endif
172 #  endif
173 #endif
174 #if defined(BSD_GETPGRP) && !defined(HAS_GETPGRP)
175 #  define HAS_GETPGRP  /* Well, effectively it does . . . */
176 #endif
177
178 /* These are not exact synonyms, since setpgrp() and getpgrp() may 
179    have different behaviors, but perl.h used to define USE_BSDPGRP
180    (prior to 5.003_05) so some extension might depend on it.
181 */
182 #if defined(USE_BSD_SETPGRP) || defined(USE_BSD_GETPGRP)
183 #  ifndef USE_BSDPGRP
184 #    define USE_BSDPGRP
185 #  endif
186 #endif
187
188 #ifndef _TYPES_         /* If types.h defines this it's easy. */
189 #   ifndef major                /* Does everyone's types.h define this? */
190 #       include <sys/types.h>
191 #   endif
192 #endif
193
194 #ifdef __cplusplus
195 #  ifndef I_STDARG
196 #    define I_STDARG 1
197 #  endif
198 #endif
199
200 #ifdef I_STDARG
201 #  include <stdarg.h>
202 #else
203 #  ifdef I_VARARGS
204 #    include <varargs.h>
205 #  endif
206 #endif
207
208 #include "perlio.h"
209
210 #ifdef USE_NEXT_CTYPE
211
212 #if NX_CURRENT_COMPILER_RELEASE >= 400
213 #include <objc/NXCType.h>
214 #else /*  NX_CURRENT_COMPILER_RELEASE < 400 */
215 #include <appkit/NXCType.h>
216 #endif /*  NX_CURRENT_COMPILER_RELEASE >= 400 */
217
218 #else /* !USE_NEXT_CTYPE */
219 #include <ctype.h>
220 #endif /* USE_NEXT_CTYPE */
221
222 #ifdef METHOD   /* Defined by OSF/1 v3.0 by ctype.h */
223 #undef METHOD
224 #endif
225
226 #ifdef I_LOCALE
227 #   include <locale.h>
228 #endif
229
230 #if !defined(NO_LOCALE) && defined(HAS_SETLOCALE)
231 #   define USE_LOCALE
232 #   if !defined(NO_LOCALE_COLLATE) && defined(LC_COLLATE) \
233        && defined(HAS_STRXFRM)
234 #       define USE_LOCALE_COLLATE
235 #   endif
236 #   if !defined(NO_LOCALE_CTYPE) && defined(LC_CTYPE)
237 #       define USE_LOCALE_CTYPE
238 #   endif
239 #   if !defined(NO_LOCALE_NUMERIC) && defined(LC_NUMERIC)
240 #       define USE_LOCALE_NUMERIC
241 #   endif
242 #endif /* !NO_LOCALE && HAS_SETLOCALE */
243
244 #include <setjmp.h>
245
246 #ifdef I_SYS_PARAM
247 #   ifdef PARAM_NEEDS_TYPES
248 #       include <sys/types.h>
249 #   endif
250 #   include <sys/param.h>
251 #endif
252
253
254 /* Use all the "standard" definitions? */
255 #if defined(STANDARD_C) && defined(I_STDLIB)
256 #   include <stdlib.h>
257 #endif
258
259 /* This comes after <stdlib.h> so we don't try to change the standard
260  * library prototypes; we'll use our own in proto.h instead. */
261
262 #ifdef MYMALLOC
263
264 #   ifdef HIDEMYMALLOC
265 #       define malloc  Mymalloc
266 #       define calloc  Mycalloc
267 #       define realloc Myremalloc
268 #       define free    Myfree
269 #   endif
270 #   ifdef EMBEDMYMALLOC
271 #       define malloc  Perl_malloc
272 #       define calloc  Perl_calloc
273 #       define realloc Perl_realloc
274 #       define free    Perl_free
275 #   endif
276
277 #   undef safemalloc
278 #   undef safecalloc
279 #   undef saferealloc
280 #   undef safefree
281 #   define safemalloc  malloc
282 #   define safecalloc  calloc
283 #   define saferealloc realloc
284 #   define safefree    free
285
286 #endif /* MYMALLOC */
287
288 #define MEM_SIZE Size_t
289
290 #if defined(STANDARD_C) && defined(I_STDDEF)
291 #   include <stddef.h>
292 #   define STRUCT_OFFSET(s,m)  offsetof(s,m)
293 #else
294 #   define STRUCT_OFFSET(s,m)  (Size_t)(&(((s *)0)->m))
295 #endif
296
297 #if defined(I_STRING) || defined(__cplusplus)
298 #   include <string.h>
299 #else
300 #   include <strings.h>
301 #endif
302
303 #if !defined(HAS_STRCHR) && defined(HAS_INDEX) && !defined(strchr)
304 #define strchr index
305 #define strrchr rindex
306 #endif
307
308 #ifdef I_MEMORY
309 #  include <memory.h>
310 #endif
311
312 #ifdef HAS_MEMCPY
313 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
314 #    ifndef memcpy
315         extern char * memcpy _((char*, char*, int));
316 #    endif
317 #  endif
318 #else
319 #   ifndef memcpy
320 #       ifdef HAS_BCOPY
321 #           define memcpy(d,s,l) bcopy(s,d,l)
322 #       else
323 #           define memcpy(d,s,l) my_bcopy(s,d,l)
324 #       endif
325 #   endif
326 #endif /* HAS_MEMCPY */
327
328 #ifdef HAS_MEMSET
329 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
330 #    ifndef memset
331         extern char *memset _((char*, int, int));
332 #    endif
333 #  endif
334 #else
335 #  define memset(d,c,l) my_memset(d,c,l)
336 #endif /* HAS_MEMSET */
337
338 #if !defined(HAS_MEMMOVE) && !defined(memmove)
339 #   if defined(HAS_BCOPY) && defined(HAS_SAFE_BCOPY)
340 #       define memmove(d,s,l) bcopy(s,d,l)
341 #   else
342 #       if defined(HAS_MEMCPY) && defined(HAS_SAFE_MEMCPY)
343 #           define memmove(d,s,l) memcpy(d,s,l)
344 #       else
345 #           define memmove(d,s,l) my_bcopy(s,d,l)
346 #       endif
347 #   endif
348 #endif
349
350 #if defined(mips) && defined(ultrix) && !defined(__STDC__)
351 #   undef HAS_MEMCMP
352 #endif
353
354 #if defined(HAS_MEMCMP) && defined(HAS_SANE_MEMCMP)
355 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
356 #    ifndef memcmp
357         extern int memcmp _((char*, char*, int));
358 #    endif
359 #  endif
360 #  ifdef BUGGY_MSC
361   #  pragma function(memcmp)
362 #  endif
363 #else
364 #   ifndef memcmp
365 #       define memcmp   my_memcmp
366 #   endif
367 #endif /* HAS_MEMCMP && HAS_SANE_MEMCMP */
368
369 #ifndef memzero
370 #   ifdef HAS_MEMSET
371 #       define memzero(d,l) memset(d,0,l)
372 #   else
373 #       ifdef HAS_BZERO
374 #           define memzero(d,l) bzero(d,l)
375 #       else
376 #           define memzero(d,l) my_bzero(d,l)
377 #       endif
378 #   endif
379 #endif
380
381 #ifndef HAS_BCMP
382 #   ifndef bcmp
383 #       define bcmp(s1,s2,l) memcmp(s1,s2,l)
384 #   endif
385 #endif /* !HAS_BCMP */
386
387 #ifdef I_NETINET_IN
388 #   include <netinet/in.h>
389 #endif
390
391 #if defined(SF_APPEND) && defined(USE_SFIO) && defined(I_SFIO)
392 /* <sfio.h> defines SF_APPEND and <sys/stat.h> might define SF_APPEND
393  * (the neo-BSD seem to do this).  */
394 #   undef SF_APPEND
395 #endif
396
397 #ifdef I_SYS_STAT
398 #   include <sys/stat.h>
399 #endif
400
401 /* The stat macros for Amdahl UTS, Unisoft System V/88 (and derivatives
402    like UTekV) are broken, sometimes giving false positives.  Undefine
403    them here and let the code below set them to proper values.
404
405    The ghs macro stands for GreenHills Software C-1.8.5 which
406    is the C compiler for sysV88 and the various derivatives.
407    This header file bug is corrected in gcc-2.5.8 and later versions.
408    --Kaveh Ghazi (ghazi@noc.rutgers.edu) 10/3/94.  */
409
410 #if defined(uts) || (defined(m88k) && defined(ghs))
411 #   undef S_ISDIR
412 #   undef S_ISCHR
413 #   undef S_ISBLK
414 #   undef S_ISREG
415 #   undef S_ISFIFO
416 #   undef S_ISLNK
417 #endif
418
419 #ifdef I_TIME
420 #   include <time.h>
421 #endif
422
423 #ifdef I_SYS_TIME
424 #   ifdef I_SYS_TIME_KERNEL
425 #       define KERNEL
426 #   endif
427 #   include <sys/time.h>
428 #   ifdef I_SYS_TIME_KERNEL
429 #       undef KERNEL
430 #   endif
431 #endif
432
433 #if defined(HAS_TIMES) && defined(I_SYS_TIMES)
434 #    include <sys/times.h>
435 #endif
436
437 #if defined(HAS_STRERROR) && (!defined(HAS_MKDIR) || !defined(HAS_RMDIR))
438 #   undef HAS_STRERROR
439 #endif
440
441 #ifndef HAS_MKFIFO
442 #  ifndef mkfifo
443 #    define mkfifo(path, mode) (mknod((path), (mode) | S_IFIFO, 0))
444 #  endif
445 #endif /* !HAS_MKFIFO */
446
447 #include <errno.h>
448 #ifdef HAS_SOCKET
449 #   ifdef I_NET_ERRNO
450 #     include <net/errno.h>
451 #   endif
452 #endif
453
454 #ifdef VMS
455 #   define SETERRNO(errcode,vmserrcode) \
456         STMT_START {                    \
457             set_errno(errcode);         \
458             set_vaxc_errno(vmserrcode); \
459         } STMT_END
460 #else
461 #   define SETERRNO(errcode,vmserrcode) errno = (errcode)
462 #endif
463
464 #ifdef USE_THREADS
465 #  define ERRSV (thr->errsv)
466 #  define ERRHV (thr->errhv)
467 #else
468 #  define ERRSV GvSV(errgv)
469 #  define ERRHV GvHV(errgv)
470 #endif /* USE_THREADS */
471
472 #ifndef errno
473         extern int errno;     /* ANSI allows errno to be an lvalue expr */
474 #endif
475
476 #ifdef HAS_STRERROR
477 #       ifdef VMS
478         char *strerror _((int,...));
479 #       else
480 #ifndef DONT_DECLARE_STD
481         char *strerror _((int));
482 #endif
483 #       endif
484 #       ifndef Strerror
485 #           define Strerror strerror
486 #       endif
487 #else
488 #    ifdef HAS_SYS_ERRLIST
489         extern int sys_nerr;
490         extern char *sys_errlist[];
491 #       ifndef Strerror
492 #           define Strerror(e) \
493                 ((e) < 0 || (e) >= sys_nerr ? "(unknown)" : sys_errlist[e])
494 #       endif
495 #   endif
496 #endif
497
498 #ifdef I_SYS_IOCTL
499 #   ifndef _IOCTL_
500 #       include <sys/ioctl.h>
501 #   endif
502 #endif
503
504 #if defined(mc300) || defined(mc500) || defined(mc700) || defined(mc6000)
505 #   ifdef HAS_SOCKETPAIR
506 #       undef HAS_SOCKETPAIR
507 #   endif
508 #   ifdef I_NDBM
509 #       undef I_NDBM
510 #   endif
511 #endif
512
513 #if INTSIZE == 2
514 #   define htoni htons
515 #   define ntohi ntohs
516 #else
517 #   define htoni htonl
518 #   define ntohi ntohl
519 #endif
520
521 /* Configure already sets Direntry_t */
522 #if defined(I_DIRENT)
523 #   include <dirent.h>
524 #   if defined(NeXT) && defined(I_SYS_DIR) /* NeXT needs dirent + sys/dir.h */
525 #       include <sys/dir.h>
526 #   endif
527 #else
528 #   ifdef I_SYS_NDIR
529 #       include <sys/ndir.h>
530 #   else
531 #       ifdef I_SYS_DIR
532 #           ifdef hp9000s500
533 #               include <ndir.h>        /* may be wrong in the future */
534 #           else
535 #               include <sys/dir.h>
536 #           endif
537 #       endif
538 #   endif
539 #endif
540
541 #ifdef FPUTS_BOTCH
542 /* work around botch in SunOS 4.0.1 and 4.0.2 */
543 #   ifndef fputs
544 #       define fputs(sv,fp) fprintf(fp,"%s",sv)
545 #   endif
546 #endif
547
548 /*
549  * The following gobbledygook brought to you on behalf of __STDC__.
550  * (I could just use #ifndef __STDC__, but this is more bulletproof
551  * in the face of half-implementations.)
552  */
553
554 #ifndef S_IFMT
555 #   ifdef _S_IFMT
556 #       define S_IFMT _S_IFMT
557 #   else
558 #       define S_IFMT 0170000
559 #   endif
560 #endif
561
562 #ifndef S_ISDIR
563 #   define S_ISDIR(m) ((m & S_IFMT) == S_IFDIR)
564 #endif
565
566 #ifndef S_ISCHR
567 #   define S_ISCHR(m) ((m & S_IFMT) == S_IFCHR)
568 #endif
569
570 #ifndef S_ISBLK
571 #   ifdef S_IFBLK
572 #       define S_ISBLK(m) ((m & S_IFMT) == S_IFBLK)
573 #   else
574 #       define S_ISBLK(m) (0)
575 #   endif
576 #endif
577
578 #ifndef S_ISREG
579 #   define S_ISREG(m) ((m & S_IFMT) == S_IFREG)
580 #endif
581
582 #ifndef S_ISFIFO
583 #   ifdef S_IFIFO
584 #       define S_ISFIFO(m) ((m & S_IFMT) == S_IFIFO)
585 #   else
586 #       define S_ISFIFO(m) (0)
587 #   endif
588 #endif
589
590 #ifndef S_ISLNK
591 #   ifdef _S_ISLNK
592 #       define S_ISLNK(m) _S_ISLNK(m)
593 #   else
594 #       ifdef _S_IFLNK
595 #           define S_ISLNK(m) ((m & S_IFMT) == _S_IFLNK)
596 #       else
597 #           ifdef S_IFLNK
598 #               define S_ISLNK(m) ((m & S_IFMT) == S_IFLNK)
599 #           else
600 #               define S_ISLNK(m) (0)
601 #           endif
602 #       endif
603 #   endif
604 #endif
605
606 #ifndef S_ISSOCK
607 #   ifdef _S_ISSOCK
608 #       define S_ISSOCK(m) _S_ISSOCK(m)
609 #   else
610 #       ifdef _S_IFSOCK
611 #           define S_ISSOCK(m) ((m & S_IFMT) == _S_IFSOCK)
612 #       else
613 #           ifdef S_IFSOCK
614 #               define S_ISSOCK(m) ((m & S_IFMT) == S_IFSOCK)
615 #           else
616 #               define S_ISSOCK(m) (0)
617 #           endif
618 #       endif
619 #   endif
620 #endif
621
622 #ifndef S_IRUSR
623 #   ifdef S_IREAD
624 #       define S_IRUSR S_IREAD
625 #       define S_IWUSR S_IWRITE
626 #       define S_IXUSR S_IEXEC
627 #   else
628 #       define S_IRUSR 0400
629 #       define S_IWUSR 0200
630 #       define S_IXUSR 0100
631 #   endif
632 #   define S_IRGRP (S_IRUSR>>3)
633 #   define S_IWGRP (S_IWUSR>>3)
634 #   define S_IXGRP (S_IXUSR>>3)
635 #   define S_IROTH (S_IRUSR>>6)
636 #   define S_IWOTH (S_IWUSR>>6)
637 #   define S_IXOTH (S_IXUSR>>6)
638 #endif
639
640 #ifndef S_ISUID
641 #   define S_ISUID 04000
642 #endif
643
644 #ifndef S_ISGID
645 #   define S_ISGID 02000
646 #endif
647
648 #ifdef ff_next
649 #   undef ff_next
650 #endif
651
652 #if defined(cray) || defined(gould) || defined(i860) || defined(pyr)
653 #   define SLOPPYDIVIDE
654 #endif
655
656 #ifdef UV
657 #undef UV
658 #endif
659
660 /*  XXX QUAD stuff is not currently supported on most systems.
661     Specifically, perl internals don't support long long.  Among
662     the many problems is that some compilers support long long,
663     but the underlying library functions (such as sprintf) don't.
664     Some things do work (such as quad pack/unpack on convex);
665     also some systems use long long for the fpos_t typedef.  That
666     seems to work too.
667
668     The IV type is supposed to be long enough to hold any integral
669     value or a pointer.
670     --Andy Dougherty    August 1996
671 */
672
673 #ifdef cray
674 #   define Quad_t int
675 #else
676 #   ifdef convex
677 #       define Quad_t long long
678 #   else
679 #       if BYTEORDER > 0xFFFF
680 #           define Quad_t long
681 #       endif
682 #   endif
683 #endif
684
685 #ifdef Quad_t
686 #   define HAS_QUAD
687     typedef Quad_t IV;
688     typedef unsigned Quad_t UV;
689 #   define IV_MAX PERL_QUAD_MAX
690 #   define IV_MIN PERL_QUAD_MIN
691 #   define UV_MAX PERL_UQUAD_MAX
692 #   define UV_MIN PERL_UQUAD_MIN
693 #else
694     typedef long IV;
695     typedef unsigned long UV;
696 #   define IV_MAX PERL_LONG_MAX
697 #   define IV_MIN PERL_LONG_MIN
698 #   define UV_MAX PERL_ULONG_MAX
699 #   define UV_MIN PERL_ULONG_MIN
700 #endif
701
702 /* Previously these definitions used hardcoded figures. 
703  * It is hoped these formula are more portable, although
704  * no data one way or another is presently known to me.
705  * The "PERL_" names are used because these calculated constants
706  * do not meet the ANSI requirements for LONG_MAX, etc., which
707  * need to be constants acceptable to #if - kja
708  *    define PERL_LONG_MAX        2147483647L
709  *    define PERL_LONG_MIN        (-LONG_MAX - 1)
710  *    define PERL ULONG_MAX       4294967295L
711  */
712
713 #ifdef I_LIMITS  /* Needed for cast_xxx() functions below. */
714 #  include <limits.h>
715 #else
716 #ifdef I_VALUES
717 #  include <values.h>
718 #endif
719 #endif
720
721 /*
722  * Try to figure out max and min values for the integral types.  THE CORRECT
723  * SOLUTION TO THIS MESS: ADAPT enquire.c FROM GCC INTO CONFIGURE.  The
724  * following hacks are used if neither limits.h or values.h provide them:
725  * U<TYPE>_MAX: for types >= int: ~(unsigned TYPE)0
726  *              for types <  int:  (unsigned TYPE)~(unsigned)0
727  *      The argument to ~ must be unsigned so that later signed->unsigned
728  *      conversion can't modify the value's bit pattern (e.g. -0 -> +0),
729  *      and it must not be smaller than int because ~ does integral promotion.
730  * <type>_MAX: (<type>) (U<type>_MAX >> 1)
731  * <type>_MIN: -<type>_MAX - <is_twos_complement_architecture: (3 & -1) == 3>.
732  *      The latter is a hack which happens to work on some machines but
733  *      does *not* catch any random system, or things like integer types
734  *      with NaN if that is possible.
735  *
736  * All of the types are explicitly cast to prevent accidental loss of
737  * numeric range, and in the hope that they will be less likely to confuse
738  * over-eager optimizers.
739  *
740  */
741
742 #define PERL_UCHAR_MIN ((unsigned char)0)
743
744 #ifdef UCHAR_MAX
745 #  define PERL_UCHAR_MAX ((unsigned char)UCHAR_MAX)
746 #else
747 #  ifdef MAXUCHAR
748 #    define PERL_UCHAR_MAX ((unsigned char)MAXUCHAR)
749 #  else
750 #    define PERL_UCHAR_MAX       ((unsigned char)~(unsigned)0)
751 #  endif
752 #endif
753  
754 /*
755  * CHAR_MIN and CHAR_MAX are not included here, as the (char) type may be
756  * ambiguous. It may be equivalent to (signed char) or (unsigned char)
757  * depending on local options. Until Configure detects this (or at least
758  * detects whether the "signed" keyword is available) the CHAR ranges
759  * will not be included. UCHAR functions normally.
760  *                                                           - kja
761  */
762
763 #define PERL_USHORT_MIN ((unsigned short)0)
764
765 #ifdef USHORT_MAX
766 #  define PERL_USHORT_MAX ((unsigned short)USHORT_MAX)
767 #else
768 #  ifdef MAXUSHORT
769 #    define PERL_USHORT_MAX ((unsigned short)MAXUSHORT)
770 #  else
771 #    define PERL_USHORT_MAX       ((unsigned short)~(unsigned)0)
772 #  endif
773 #endif
774
775 #ifdef SHORT_MAX
776 #  define PERL_SHORT_MAX ((short)SHORT_MAX)
777 #else
778 #  ifdef MAXSHORT    /* Often used in <values.h> */
779 #    define PERL_SHORT_MAX ((short)MAXSHORT)
780 #  else
781 #    define PERL_SHORT_MAX      ((short) (PERL_USHORT_MAX >> 1))
782 #  endif
783 #endif
784
785 #ifdef SHORT_MIN
786 #  define PERL_SHORT_MIN ((short)SHORT_MIN)
787 #else
788 #  ifdef MINSHORT
789 #    define PERL_SHORT_MIN ((short)MINSHORT)
790 #  else
791 #    define PERL_SHORT_MIN        (-PERL_SHORT_MAX - ((3 & -1) == 3))
792 #  endif
793 #endif
794
795 #ifdef UINT_MAX
796 #  define PERL_UINT_MAX ((unsigned int)UINT_MAX)
797 #else
798 #  ifdef MAXUINT
799 #    define PERL_UINT_MAX ((unsigned int)MAXUINT)
800 #  else
801 #    define PERL_UINT_MAX       (~(unsigned int)0)
802 #  endif
803 #endif
804
805 #define PERL_UINT_MIN ((unsigned int)0)
806
807 #ifdef INT_MAX
808 #  define PERL_INT_MAX ((int)INT_MAX)
809 #else
810 #  ifdef MAXINT    /* Often used in <values.h> */
811 #    define PERL_INT_MAX ((int)MAXINT)
812 #  else
813 #    define PERL_INT_MAX        ((int)(PERL_UINT_MAX >> 1))
814 #  endif
815 #endif
816
817 #ifdef INT_MIN
818 #  define PERL_INT_MIN ((int)INT_MIN)
819 #else
820 #  ifdef MININT
821 #    define PERL_INT_MIN ((int)MININT)
822 #  else
823 #    define PERL_INT_MIN        (-PERL_INT_MAX - ((3 & -1) == 3))
824 #  endif
825 #endif
826
827 #ifdef ULONG_MAX
828 #  define PERL_ULONG_MAX ((unsigned long)ULONG_MAX)
829 #else
830 #  ifdef MAXULONG
831 #    define PERL_ULONG_MAX ((unsigned long)MAXULONG)
832 #  else
833 #    define PERL_ULONG_MAX       (~(unsigned long)0)
834 #  endif
835 #endif
836
837 #define PERL_ULONG_MIN ((unsigned long)0L)
838
839 #ifdef LONG_MAX
840 #  define PERL_LONG_MAX ((long)LONG_MAX)
841 #else
842 #  ifdef MAXLONG    /* Often used in <values.h> */
843 #    define PERL_LONG_MAX ((long)MAXLONG)
844 #  else
845 #    define PERL_LONG_MAX        ((long) (PERL_ULONG_MAX >> 1))
846 #  endif
847 #endif
848
849 #ifdef LONG_MIN
850 #  define PERL_LONG_MIN ((long)LONG_MIN)
851 #else
852 #  ifdef MINLONG
853 #    define PERL_LONG_MIN ((long)MINLONG)
854 #  else
855 #    define PERL_LONG_MIN        (-PERL_LONG_MAX - ((3 & -1) == 3))
856 #  endif
857 #endif
858
859 #ifdef HAS_QUAD
860
861 #  ifdef UQUAD_MAX
862 #    define PERL_UQUAD_MAX ((UV)UQUAD_MAX)
863 #  else
864 #    define PERL_UQUAD_MAX      (~(UV)0)
865 #  endif
866
867 #  define PERL_UQUAD_MIN ((UV)0)
868
869 #  ifdef QUAD_MAX
870 #    define PERL_QUAD_MAX ((IV)QUAD_MAX)
871 #  else
872 #    define PERL_QUAD_MAX       ((IV) (PERL_UQUAD_MAX >> 1))
873 #  endif
874
875 #  ifdef QUAD_MIN
876 #    define PERL_QUAD_MIN ((IV)QUAD_MIN)
877 #  else
878 #    define PERL_QUAD_MIN       (-PERL_QUAD_MAX - ((3 & -1) == 3))
879 #  endif
880
881 #endif
882
883 /* Digital UNIX defines a typedef CONTEXT when pthreads is in use */ 
884 #if defined(__osf__)
885 #  define CONTEXT PERL_CONTEXT
886 #endif
887
888 typedef MEM_SIZE STRLEN;
889
890 typedef struct op OP;
891 typedef struct cop COP;
892 typedef struct unop UNOP;
893 typedef struct binop BINOP;
894 typedef struct listop LISTOP;
895 typedef struct logop LOGOP;
896 typedef struct condop CONDOP;
897 typedef struct pmop PMOP;
898 typedef struct svop SVOP;
899 typedef struct gvop GVOP;
900 typedef struct pvop PVOP;
901 typedef struct loop LOOP;
902
903 typedef struct Outrec Outrec;
904 typedef struct interpreter PerlInterpreter;
905 #ifndef __BORLANDC__
906 typedef struct ff FF;           /* XXX not defined anywhere, should go? */
907 #endif
908 typedef struct sv SV;
909 typedef struct av AV;
910 typedef struct hv HV;
911 typedef struct cv CV;
912 typedef struct regexp REGEXP;
913 typedef struct gp GP;
914 typedef struct gv GV;
915 typedef struct io IO;
916 typedef struct context CONTEXT;
917 typedef struct block BLOCK;
918
919 typedef struct magic MAGIC;
920 typedef struct xrv XRV;
921 typedef struct xpv XPV;
922 typedef struct xpviv XPVIV;
923 typedef struct xpvuv XPVUV;
924 typedef struct xpvnv XPVNV;
925 typedef struct xpvmg XPVMG;
926 typedef struct xpvlv XPVLV;
927 typedef struct xpvav XPVAV;
928 typedef struct xpvhv XPVHV;
929 typedef struct xpvgv XPVGV;
930 typedef struct xpvcv XPVCV;
931 typedef struct xpvbm XPVBM;
932 typedef struct xpvfm XPVFM;
933 typedef struct xpvio XPVIO;
934 typedef struct mgvtbl MGVTBL;
935 typedef union any ANY;
936
937 #include "handy.h"
938
939 typedef I32 (*filter_t) _((int, SV *, int));
940 #define FILTER_READ(idx, sv, len)  filter_read(idx, sv, len)
941 #define FILTER_DATA(idx)           (AvARRAY(rsfp_filters)[idx])
942 #define FILTER_ISREADER(idx)       (idx >= AvFILL(rsfp_filters))
943
944 #ifdef DOSISH
945 # if defined(OS2)
946 #   include "os2ish.h"
947 # else
948 #   include "dosish.h"
949 # endif
950 #else
951 # if defined(VMS)
952 #   include "vmsish.h"
953 # else
954 #   if defined(PLAN9)
955 #     include "./plan9/plan9ish.h"
956 #   else
957 #     include "unixish.h"
958 #   endif
959 # endif
960 #endif
961   
962 #ifdef VMS
963 #   define STATUS_NATIVE        statusvalue_vms
964 #   define STATUS_NATIVE_EXPORT \
965         ((I32)statusvalue_vms == -1 ? 44 : statusvalue_vms)
966 #   define STATUS_NATIVE_SET(n)                                         \
967         STMT_START {                                                    \
968             statusvalue_vms = (n);                                      \
969             if ((I32)statusvalue_vms == -1)                             \
970                 statusvalue = -1;                                       \
971             else if (statusvalue_vms & STS$M_SUCCESS)                   \
972                 statusvalue = 0;                                        \
973             else if ((statusvalue_vms & STS$M_SEVERITY) == 0)           \
974                 statusvalue = 1 << 8;                                   \
975             else                                                        \
976                 statusvalue = (statusvalue_vms & STS$M_SEVERITY) << 8;  \
977         } STMT_END
978 #   define STATUS_POSIX statusvalue
979 #   ifdef VMSISH_STATUS
980 #       define STATUS_CURRENT   (VMSISH_STATUS ? STATUS_NATIVE : STATUS_POSIX)
981 #   else
982 #       define STATUS_CURRENT   STATUS_POSIX
983 #   endif
984 #   define STATUS_POSIX_SET(n)                          \
985         STMT_START {                                    \
986             statusvalue = (n);                          \
987             if (statusvalue != -1) {                    \
988                 statusvalue &= 0xFFFF;                  \
989                 statusvalue_vms = statusvalue ? 44 : 1; \
990             }                                           \
991             else statusvalue_vms = -1;                  \
992         } STMT_END
993 #   define STATUS_ALL_SUCCESS   (statusvalue = 0, statusvalue_vms = 1)
994 #   define STATUS_ALL_FAILURE   (statusvalue = 1, statusvalue_vms = 44)
995 #else
996 #   define STATUS_NATIVE        STATUS_POSIX
997 #   define STATUS_NATIVE_EXPORT STATUS_POSIX
998 #   define STATUS_NATIVE_SET    STATUS_POSIX_SET
999 #   define STATUS_POSIX         statusvalue
1000 #   define STATUS_POSIX_SET(n)          \
1001         STMT_START {                    \
1002             statusvalue = (n);          \
1003             if (statusvalue != -1)      \
1004                 statusvalue &= 0xFFFF;  \
1005         } STMT_END
1006 #   define STATUS_CURRENT STATUS_POSIX
1007 #   define STATUS_ALL_SUCCESS   (statusvalue = 0)
1008 #   define STATUS_ALL_FAILURE   (statusvalue = 1)
1009 #endif
1010
1011 /* Some unistd.h's give a prototype for pause() even though
1012    HAS_PAUSE ends up undefined.  This causes the #define
1013    below to be rejected by the compmiler.  Sigh.
1014 */
1015 #ifdef HAS_PAUSE
1016 #define Pause   pause
1017 #else
1018 #define Pause() sleep((32767<<16)+32767)
1019 #endif
1020
1021 #ifndef IOCPARM_LEN
1022 #   ifdef IOCPARM_MASK
1023         /* on BSDish systes we're safe */
1024 #       define IOCPARM_LEN(x)  (((x) >> 16) & IOCPARM_MASK)
1025 #   else
1026         /* otherwise guess at what's safe */
1027 #       define IOCPARM_LEN(x)   256
1028 #   endif
1029 #endif
1030
1031 union any {
1032     void*       any_ptr;
1033     I32         any_i32;
1034     IV          any_iv;
1035     long        any_long;
1036     void        (*any_dptr) _((void*));
1037 };
1038
1039 #ifdef USE_THREADS
1040 #define ARGSproto struct thread *
1041 #else
1042 #define ARGSproto void
1043 #endif /* USE_THREADS */
1044
1045 /* Work around some cygwin32 problems with importing global symbols */
1046 #if defined(CYGWIN32) && defined(DLLIMPORT) 
1047 #   include "cw32imp.h"
1048 #endif
1049
1050 #include "regexp.h"
1051 #include "sv.h"
1052 #include "util.h"
1053 #include "form.h"
1054 #include "gv.h"
1055 #include "cv.h"
1056 #include "opcode.h"
1057 #include "op.h"
1058 #include "cop.h"
1059 #include "av.h"
1060 #include "hv.h"
1061 #include "mg.h"
1062 #include "scope.h"
1063
1064 /* work around some libPW problems */
1065 #ifdef DOINIT
1066 EXT char Error[1];
1067 #endif
1068
1069 #if defined(iAPX286) || defined(M_I286) || defined(I80286)
1070 #   define I286
1071 #endif
1072
1073 #if defined(htonl) && !defined(HAS_HTONL)
1074 #define HAS_HTONL
1075 #endif
1076 #if defined(htons) && !defined(HAS_HTONS)
1077 #define HAS_HTONS
1078 #endif
1079 #if defined(ntohl) && !defined(HAS_NTOHL)
1080 #define HAS_NTOHL
1081 #endif
1082 #if defined(ntohs) && !defined(HAS_NTOHS)
1083 #define HAS_NTOHS
1084 #endif
1085 #ifndef HAS_HTONL
1086 #if (BYTEORDER & 0xffff) != 0x4321
1087 #define HAS_HTONS
1088 #define HAS_HTONL
1089 #define HAS_NTOHS
1090 #define HAS_NTOHL
1091 #define MYSWAP
1092 #define htons my_swap
1093 #define htonl my_htonl
1094 #define ntohs my_swap
1095 #define ntohl my_ntohl
1096 #endif
1097 #else
1098 #if (BYTEORDER & 0xffff) == 0x4321
1099 #undef HAS_HTONS
1100 #undef HAS_HTONL
1101 #undef HAS_NTOHS
1102 #undef HAS_NTOHL
1103 #endif
1104 #endif
1105
1106 /*
1107  * Little-endian byte order functions - 'v' for 'VAX', or 'reVerse'.
1108  * -DWS
1109  */
1110 #if BYTEORDER != 0x1234
1111 # define HAS_VTOHL
1112 # define HAS_VTOHS
1113 # define HAS_HTOVL
1114 # define HAS_HTOVS
1115 # if BYTEORDER == 0x4321
1116 #  define vtohl(x)      ((((x)&0xFF)<<24)       \
1117                         +(((x)>>24)&0xFF)       \
1118                         +(((x)&0x0000FF00)<<8)  \
1119                         +(((x)&0x00FF0000)>>8)  )
1120 #  define vtohs(x)      ((((x)&0xFF)<<8) + (((x)>>8)&0xFF))
1121 #  define htovl(x)      vtohl(x)
1122 #  define htovs(x)      vtohs(x)
1123 # endif
1124         /* otherwise default to functions in util.c */
1125 #endif
1126
1127 #ifdef CASTNEGFLOAT
1128 #define U_S(what) ((U16)(what))
1129 #define U_I(what) ((unsigned int)(what))
1130 #define U_L(what) ((U32)(what))
1131 #else
1132 #  ifdef __cplusplus
1133     extern "C" {
1134 #  endif
1135 U32 cast_ulong _((double));
1136 #  ifdef __cplusplus
1137     }
1138 #  endif
1139 #define U_S(what) ((U16)cast_ulong((double)(what)))
1140 #define U_I(what) ((unsigned int)cast_ulong((double)(what)))
1141 #define U_L(what) (cast_ulong((double)(what)))
1142 #endif
1143
1144 #ifdef CASTI32
1145 #define I_32(what) ((I32)(what))
1146 #define I_V(what) ((IV)(what))
1147 #define U_V(what) ((UV)(what))
1148 #else
1149 #  ifdef __cplusplus
1150     extern "C" {
1151 #  endif
1152 I32 cast_i32 _((double));
1153 IV cast_iv _((double));
1154 UV cast_uv _((double));
1155 #  ifdef __cplusplus
1156     }
1157 #  endif
1158 #define I_32(what) (cast_i32((double)(what)))
1159 #define I_V(what) (cast_iv((double)(what)))
1160 #define U_V(what) (cast_uv((double)(what)))
1161 #endif
1162
1163 struct Outrec {
1164     I32         o_lines;
1165     char        *o_str;
1166     U32         o_len;
1167 };
1168
1169 #ifndef MAXSYSFD
1170 #   define MAXSYSFD 2
1171 #endif
1172
1173 #ifndef TMPPATH
1174 #  define TMPPATH "/tmp/perl-eXXXXXX"
1175 #endif
1176
1177 #ifndef __cplusplus
1178 Uid_t getuid _((void));
1179 Uid_t geteuid _((void));
1180 Gid_t getgid _((void));
1181 Gid_t getegid _((void));
1182 #endif
1183
1184 #ifdef DEBUGGING
1185 #ifndef Perl_debug_log
1186 #define Perl_debug_log  PerlIO_stderr()
1187 #endif
1188 #define YYDEBUG 1
1189 #define DEB(a)                          a
1190 #define DEBUG(a)   if (debug)           a
1191 #define DEBUG_p(a) if (debug & 1)       a
1192 #define DEBUG_s(a) if (debug & 2)       a
1193 #define DEBUG_l(a) if (debug & 4)       a
1194 #define DEBUG_t(a) if (debug & 8)       a
1195 #define DEBUG_o(a) if (debug & 16)      a
1196 #define DEBUG_c(a) if (debug & 32)      a
1197 #define DEBUG_P(a) if (debug & 64)      a
1198 #define DEBUG_m(a) if (curinterp && debug & 128)        a
1199 #define DEBUG_f(a) if (debug & 256)     a
1200 #define DEBUG_r(a) if (debug & 512)     a
1201 #define DEBUG_x(a) if (debug & 1024)    a
1202 #define DEBUG_u(a) if (debug & 2048)    a
1203 #define DEBUG_L(a) if (debug & 4096)    a
1204 #define DEBUG_H(a) if (debug & 8192)    a
1205 #define DEBUG_X(a) if (debug & 16384)   a
1206 #define DEBUG_D(a) if (debug & 32768)   a
1207 #else
1208 #define DEB(a)
1209 #define DEBUG(a)
1210 #define DEBUG_p(a)
1211 #define DEBUG_s(a)
1212 #define DEBUG_l(a)
1213 #define DEBUG_t(a)
1214 #define DEBUG_o(a)
1215 #define DEBUG_c(a)
1216 #define DEBUG_P(a)
1217 #define DEBUG_m(a)
1218 #define DEBUG_f(a)
1219 #define DEBUG_r(a)
1220 #define DEBUG_x(a)
1221 #define DEBUG_u(a)
1222 #define DEBUG_L(a)
1223 #define DEBUG_H(a)
1224 #define DEBUG_X(a)
1225 #define DEBUG_D(a)
1226 #endif
1227 #define YYMAXDEPTH 300
1228
1229 #ifndef assert  /* <assert.h> might have been included somehow */
1230 #define assert(what)    DEB( {                                          \
1231         if (!(what)) {                                                  \
1232             croak("Assertion failed: file \"%s\", line %d",             \
1233                 __FILE__, __LINE__);                                    \
1234             exit(1);                                                    \
1235         }})
1236 #endif
1237
1238 struct ufuncs {
1239     I32 (*uf_val)_((IV, SV*));
1240     I32 (*uf_set)_((IV, SV*));
1241     IV uf_index;
1242 };
1243
1244 /* Fix these up for __STDC__ */
1245 #ifndef DONT_DECLARE_STD
1246 char *mktemp _((char*));
1247 double atof _((const char*));
1248 #endif
1249
1250 #ifndef STANDARD_C
1251 /* All of these are in stdlib.h or time.h for ANSI C */
1252 Time_t time();
1253 struct tm *gmtime(), *localtime();
1254 char *strchr(), *strrchr();
1255 char *strcpy(), *strcat();
1256 #endif /* ! STANDARD_C */
1257
1258
1259 #ifdef I_MATH
1260 #    include <math.h>
1261 #else
1262 #   ifdef __cplusplus
1263         extern "C" {
1264 #   endif
1265             double exp _((double));
1266             double log _((double));
1267             double log10 _((double));
1268             double sqrt _((double));
1269             double frexp _((double,int*));
1270             double ldexp _((double,int));
1271             double modf _((double,double*));
1272             double sin _((double));
1273             double cos _((double));
1274             double atan2 _((double,double));
1275             double pow _((double,double));
1276 #   ifdef __cplusplus
1277         };
1278 #   endif
1279 #endif
1280
1281 #ifndef __cplusplus
1282 #ifdef __NeXT__ /* or whatever catches all NeXTs */
1283 char *crypt ();       /* Maybe more hosts will need the unprototyped version */
1284 #else
1285 char *crypt _((const char*, const char*));
1286 #endif
1287 #ifndef DONT_DECLARE_STD
1288 #ifndef getenv
1289 char *getenv _((const char*));
1290 #endif
1291 Off_t lseek _((int,Off_t,int));
1292 #endif
1293 char *getlogin _((void));
1294 #endif
1295
1296 #ifdef UNLINK_ALL_VERSIONS /* Currently only makes sense for VMS */
1297 #define UNLINK unlnk
1298 I32 unlnk _((char*));
1299 #else
1300 #define UNLINK unlink
1301 #endif
1302
1303 #ifndef HAS_SETREUID
1304 #  ifdef HAS_SETRESUID
1305 #    define setreuid(r,e) setresuid(r,e,(Uid_t)-1)
1306 #    define HAS_SETREUID
1307 #  endif
1308 #endif
1309 #ifndef HAS_SETREGID
1310 #  ifdef HAS_SETRESGID
1311 #    define setregid(r,e) setresgid(r,e,(Gid_t)-1)
1312 #    define HAS_SETREGID
1313 #  endif
1314 #endif
1315
1316 typedef Signal_t (*Sighandler_t) _((int));
1317
1318 #ifdef HAS_SIGACTION
1319 typedef struct sigaction Sigsave_t;
1320 #else
1321 typedef Sighandler_t Sigsave_t;
1322 #endif
1323
1324 #define SCAN_DEF 0
1325 #define SCAN_TR 1
1326 #define SCAN_REPL 2
1327
1328 #ifdef DEBUGGING
1329 # ifndef register
1330 #  define register
1331 # endif
1332 # define PAD_SV(po) pad_sv(po)
1333 # define RUNOPS_DEFAULT runops_debug
1334 #else
1335 # define PAD_SV(po) curpad[po]
1336 # define RUNOPS_DEFAULT runops_standard
1337 #endif
1338
1339 /*
1340  * These need prototyping here because <proto.h> isn't
1341  * included until after runops is initialised.
1342  */
1343
1344 int runops_standard _((void));
1345 #ifdef DEBUGGING
1346 int runops_debug _((void));
1347 #endif
1348
1349 #define PER_THREAD_MAGICALS "123456789&`'+/.,\\\";^-%=|~:\001\005!@"
1350
1351 /****************/
1352 /* Truly global */
1353 /****************/
1354
1355 /* global state */
1356 EXT PerlInterpreter *   curinterp;      /* currently running interpreter */
1357 #ifdef USE_THREADS
1358 EXT perl_key            thr_key;        /* For per-thread struct thread ptr */
1359 EXT perl_mutex          sv_mutex;       /* Mutex for allocating SVs in sv.c */
1360 EXT perl_mutex          malloc_mutex;   /* Mutex for malloc */
1361 EXT perl_mutex          eval_mutex;     /* Mutex for doeval */
1362 EXT perl_cond           eval_cond;      /* Condition variable for doeval */
1363 EXT struct thread *     eval_owner;     /* Owner thread for doeval */
1364 EXT int                 nthreads;       /* Number of threads currently */
1365 EXT perl_mutex          threads_mutex;  /* Mutex for nthreads and thread list */
1366 EXT perl_cond           nthreads_cond;  /* Condition variable for nthreads */
1367 EXT char *              per_thread_magicals INIT(PER_THREAD_MAGICALS);
1368 #ifdef FAKE_THREADS
1369 EXT struct thread *     thr;            /* Currently executing (fake) thread */
1370 #endif
1371 #endif /* USE_THREADS */
1372
1373 /* VMS doesn't use environ array and NeXT has problems with crt0.o globals */
1374 #if !defined(VMS) && !(defined(NeXT) && defined(__DYNAMIC__))
1375 #ifndef DONT_DECLARE_STD
1376 extern char **  environ;        /* environment variables supplied via exec */
1377 #endif
1378 #else
1379 #  if defined(NeXT) && defined(__DYNAMIC__)
1380
1381 #  include <mach-o/dyld.h>
1382 EXT char *** environ_pointer;
1383 #  define environ (*environ_pointer)
1384 #  endif
1385 #endif /* environ processing */
1386
1387 EXT int         uid;            /* current real user id */
1388 EXT int         euid;           /* current effective user id */
1389 EXT int         gid;            /* current real group id */
1390 EXT int         egid;           /* current effective group id */
1391 EXT bool        nomemok;        /* let malloc context handle nomem */
1392 EXT U32         an;             /* malloc sequence number */
1393 EXT U32         cop_seqmax;     /* statement sequence number */
1394 EXT U16         op_seqmax;      /* op sequence number */
1395 EXT U32         evalseq;        /* eval sequence number */
1396 EXT U32         sub_generation; /* inc to force methods to be looked up again */
1397 EXT char **     origenviron;
1398 EXT U32         origalen;
1399 EXT HV *        pidstatus;      /* pid-to-status mappings for waitpid */
1400 EXT U32 *       profiledata;
1401 EXT int         maxo INIT(MAXO);/* Number of ops */
1402 EXT char *      osname;         /* operating system */
1403 EXT char *      sh_path INIT(SH_PATH); /* full path of shell */
1404 EXT Sighandler_t        sighandlerp;
1405
1406 EXT XPV*        xiv_arenaroot;  /* list of allocated xiv areas */
1407 EXT IV **       xiv_root;       /* free xiv list--shared by interpreters */
1408 EXT double *    xnv_root;       /* free xnv list--shared by interpreters */
1409 EXT XRV *       xrv_root;       /* free xrv list--shared by interpreters */
1410 EXT XPV *       xpv_root;       /* free xpv list--shared by interpreters */
1411 EXT HE *        he_root;        /* free he list--shared by interpreters */
1412 EXT char *      nice_chunk;     /* a nice chunk of memory to reuse */
1413 EXT U32         nice_chunk_size;/* how nice the chunk of memory is */
1414
1415 /* Stack for currently executing thread--context switch must handle this.     */
1416 EXT SV **       stack_base;     /* stack->array_ary */
1417 EXT SV **       stack_sp;       /* stack pointer now */
1418 EXT SV **       stack_max;      /* stack->array_ary + stack->array_max */
1419
1420 /* likewise for these */
1421
1422 #ifdef OP_IN_REGISTER
1423 EXT OP *        opsave;         /* save current op register across longjmps */
1424 #else
1425 EXT OP *        op;             /* current op--when not in a global register */
1426 #endif
1427 EXT int         (*runops) _((void)) INIT(RUNOPS_DEFAULT);
1428 EXT I32 *       scopestack;     /* blocks we've entered */
1429 EXT I32         scopestack_ix;
1430 EXT I32         scopestack_max;
1431
1432 EXT ANY*        savestack;      /* to save non-local values on */
1433 EXT I32         savestack_ix;
1434 EXT I32         savestack_max;
1435
1436 EXT OP **       retstack;       /* returns we've pushed */
1437 EXT I32         retstack_ix;
1438 EXT I32         retstack_max;
1439
1440 EXT I32 *       markstack;      /* stackmarks we're remembering */
1441 EXT I32 *       markstack_ptr;  /* stackmarks we're remembering */
1442 EXT I32 *       markstack_max;  /* stackmarks we're remembering */
1443
1444 EXT SV **       curpad;
1445
1446 /* temp space */
1447 EXT SV *        Sv;
1448 EXT XPV *       Xpv;
1449 EXT char        tokenbuf[256];
1450 EXT struct stat statbuf;
1451 #ifdef HAS_TIMES
1452 EXT struct tms  timesbuf;
1453 #endif
1454 EXT STRLEN na;          /* for use in SvPV when length is Not Applicable */
1455
1456 /* for tmp use in stupid debuggers */
1457 EXT int *       di;
1458 EXT short *     ds;
1459 EXT char *      dc;
1460
1461 /* handy constants */
1462 EXTCONST char * Yes INIT("1");
1463 EXTCONST char * No INIT("");
1464 EXTCONST char * hexdigit INIT("0123456789abcdef0123456789ABCDEFx");
1465 EXTCONST char * patleave INIT("\\.^$@dDwWsSbB+*?|()-nrtfeaxc0123456789[{]}");
1466 EXTCONST char * vert INIT("|");
1467
1468 EXTCONST char warn_uninit[]
1469   INIT("Use of uninitialized value");
1470 EXTCONST char warn_nosemi[]
1471   INIT("Semicolon seems to be missing");
1472 EXTCONST char warn_reserved[]
1473   INIT("Unquoted string \"%s\" may clash with future reserved word");
1474 EXTCONST char warn_nl[]
1475   INIT("Unsuccessful %s on filename containing newline");
1476 EXTCONST char no_wrongref[]
1477   INIT("Can't use %s ref as %s ref");
1478 EXTCONST char no_symref[]
1479   INIT("Can't use string (\"%.32s\") as %s ref while \"strict refs\" in use");
1480 EXTCONST char no_usym[]
1481   INIT("Can't use an undefined value as %s reference");
1482 EXTCONST char no_aelem[]
1483   INIT("Modification of non-creatable array value attempted, subscript %d");
1484 EXTCONST char no_helem[]
1485   INIT("Modification of non-creatable hash value attempted, subscript \"%s\"");
1486 EXTCONST char no_modify[]
1487   INIT("Modification of a read-only value attempted");
1488 EXTCONST char no_mem[]
1489   INIT("Out of memory!\n");
1490 EXTCONST char no_security[]
1491   INIT("Insecure dependency in %s%s");
1492 EXTCONST char no_sock_func[]
1493   INIT("Unsupported socket function \"%s\" called");
1494 EXTCONST char no_dir_func[]
1495   INIT("Unsupported directory function \"%s\" called");
1496 EXTCONST char no_func[]
1497   INIT("The %s function is unimplemented");
1498 EXTCONST char no_myglob[]
1499   INIT("\"my\" variable %s can't be in a package");
1500
1501 EXT SV          sv_undef;
1502 EXT SV          sv_no;
1503 EXT SV          sv_yes;
1504 #ifdef CSH
1505     EXT char *  cshname INIT(CSH);
1506     EXT I32     cshlen;
1507 #endif
1508
1509 #ifdef DOINIT
1510 EXT char *sig_name[] = { SIG_NAME };
1511 EXT int   sig_num[]  = { SIG_NUM };
1512 EXT SV  * psig_ptr[sizeof(sig_num)/sizeof(*sig_num)];
1513 EXT SV  * psig_name[sizeof(sig_num)/sizeof(*sig_num)];
1514 #else
1515 EXT char *sig_name[];
1516 EXT int   sig_num[];
1517 EXT SV  * psig_ptr[];
1518 EXT SV  * psig_name[];
1519 #endif
1520
1521 /* fast case folding tables */
1522
1523 #ifdef DOINIT
1524 EXTCONST  unsigned char fold[] = {
1525         0,      1,      2,      3,      4,      5,      6,      7,
1526         8,      9,      10,     11,     12,     13,     14,     15,
1527         16,     17,     18,     19,     20,     21,     22,     23,
1528         24,     25,     26,     27,     28,     29,     30,     31,
1529         32,     33,     34,     35,     36,     37,     38,     39,
1530         40,     41,     42,     43,     44,     45,     46,     47,
1531         48,     49,     50,     51,     52,     53,     54,     55,
1532         56,     57,     58,     59,     60,     61,     62,     63,
1533         64,     'a',    'b',    'c',    'd',    'e',    'f',    'g',
1534         'h',    'i',    'j',    'k',    'l',    'm',    'n',    'o',
1535         'p',    'q',    'r',    's',    't',    'u',    'v',    'w',
1536         'x',    'y',    'z',    91,     92,     93,     94,     95,
1537         96,     'A',    'B',    'C',    'D',    'E',    'F',    'G',
1538         'H',    'I',    'J',    'K',    'L',    'M',    'N',    'O',
1539         'P',    'Q',    'R',    'S',    'T',    'U',    'V',    'W',
1540         'X',    'Y',    'Z',    123,    124,    125,    126,    127,
1541         128,    129,    130,    131,    132,    133,    134,    135,
1542         136,    137,    138,    139,    140,    141,    142,    143,
1543         144,    145,    146,    147,    148,    149,    150,    151,
1544         152,    153,    154,    155,    156,    157,    158,    159,
1545         160,    161,    162,    163,    164,    165,    166,    167,
1546         168,    169,    170,    171,    172,    173,    174,    175,
1547         176,    177,    178,    179,    180,    181,    182,    183,
1548         184,    185,    186,    187,    188,    189,    190,    191,
1549         192,    193,    194,    195,    196,    197,    198,    199,
1550         200,    201,    202,    203,    204,    205,    206,    207,
1551         208,    209,    210,    211,    212,    213,    214,    215,
1552         216,    217,    218,    219,    220,    221,    222,    223,    
1553         224,    225,    226,    227,    228,    229,    230,    231,
1554         232,    233,    234,    235,    236,    237,    238,    239,
1555         240,    241,    242,    243,    244,    245,    246,    247,
1556         248,    249,    250,    251,    252,    253,    254,    255
1557 };
1558 #else
1559 EXTCONST unsigned char fold[];
1560 #endif
1561
1562 #ifdef DOINIT
1563 EXT unsigned char fold_locale[] = {
1564         0,      1,      2,      3,      4,      5,      6,      7,
1565         8,      9,      10,     11,     12,     13,     14,     15,
1566         16,     17,     18,     19,     20,     21,     22,     23,
1567         24,     25,     26,     27,     28,     29,     30,     31,
1568         32,     33,     34,     35,     36,     37,     38,     39,
1569         40,     41,     42,     43,     44,     45,     46,     47,
1570         48,     49,     50,     51,     52,     53,     54,     55,
1571         56,     57,     58,     59,     60,     61,     62,     63,
1572         64,     'a',    'b',    'c',    'd',    'e',    'f',    'g',
1573         'h',    'i',    'j',    'k',    'l',    'm',    'n',    'o',
1574         'p',    'q',    'r',    's',    't',    'u',    'v',    'w',
1575         'x',    'y',    'z',    91,     92,     93,     94,     95,
1576         96,     'A',    'B',    'C',    'D',    'E',    'F',    'G',
1577         'H',    'I',    'J',    'K',    'L',    'M',    'N',    'O',
1578         'P',    'Q',    'R',    'S',    'T',    'U',    'V',    'W',
1579         'X',    'Y',    'Z',    123,    124,    125,    126,    127,
1580         128,    129,    130,    131,    132,    133,    134,    135,
1581         136,    137,    138,    139,    140,    141,    142,    143,
1582         144,    145,    146,    147,    148,    149,    150,    151,
1583         152,    153,    154,    155,    156,    157,    158,    159,
1584         160,    161,    162,    163,    164,    165,    166,    167,
1585         168,    169,    170,    171,    172,    173,    174,    175,
1586         176,    177,    178,    179,    180,    181,    182,    183,
1587         184,    185,    186,    187,    188,    189,    190,    191,
1588         192,    193,    194,    195,    196,    197,    198,    199,
1589         200,    201,    202,    203,    204,    205,    206,    207,
1590         208,    209,    210,    211,    212,    213,    214,    215,
1591         216,    217,    218,    219,    220,    221,    222,    223,    
1592         224,    225,    226,    227,    228,    229,    230,    231,
1593         232,    233,    234,    235,    236,    237,    238,    239,
1594         240,    241,    242,    243,    244,    245,    246,    247,
1595         248,    249,    250,    251,    252,    253,    254,    255
1596 };
1597 #else
1598 EXT unsigned char fold_locale[];
1599 #endif
1600
1601 #ifdef DOINIT
1602 EXTCONST unsigned char freq[] = {       /* letter frequencies for mixed English/C */
1603         1,      2,      84,     151,    154,    155,    156,    157,
1604         165,    246,    250,    3,      158,    7,      18,     29,
1605         40,     51,     62,     73,     85,     96,     107,    118,
1606         129,    140,    147,    148,    149,    150,    152,    153,
1607         255,    182,    224,    205,    174,    176,    180,    217,
1608         233,    232,    236,    187,    235,    228,    234,    226,
1609         222,    219,    211,    195,    188,    193,    185,    184,
1610         191,    183,    201,    229,    181,    220,    194,    162,
1611         163,    208,    186,    202,    200,    218,    198,    179,
1612         178,    214,    166,    170,    207,    199,    209,    206,
1613         204,    160,    212,    216,    215,    192,    175,    173,
1614         243,    172,    161,    190,    203,    189,    164,    230,
1615         167,    248,    227,    244,    242,    255,    241,    231,
1616         240,    253,    169,    210,    245,    237,    249,    247,
1617         239,    168,    252,    251,    254,    238,    223,    221,
1618         213,    225,    177,    197,    171,    196,    159,    4,
1619         5,      6,      8,      9,      10,     11,     12,     13,
1620         14,     15,     16,     17,     19,     20,     21,     22,
1621         23,     24,     25,     26,     27,     28,     30,     31,
1622         32,     33,     34,     35,     36,     37,     38,     39,
1623         41,     42,     43,     44,     45,     46,     47,     48,
1624         49,     50,     52,     53,     54,     55,     56,     57,
1625         58,     59,     60,     61,     63,     64,     65,     66,
1626         67,     68,     69,     70,     71,     72,     74,     75,
1627         76,     77,     78,     79,     80,     81,     82,     83,
1628         86,     87,     88,     89,     90,     91,     92,     93,
1629         94,     95,     97,     98,     99,     100,    101,    102,
1630         103,    104,    105,    106,    108,    109,    110,    111,
1631         112,    113,    114,    115,    116,    117,    119,    120,
1632         121,    122,    123,    124,    125,    126,    127,    128,
1633         130,    131,    132,    133,    134,    135,    136,    137,
1634         138,    139,    141,    142,    143,    144,    145,    146
1635 };
1636 #else
1637 EXTCONST unsigned char freq[];
1638 #endif
1639
1640 #ifdef DEBUGGING
1641 #ifdef DOINIT
1642 EXTCONST char* block_type[] = {
1643         "NULL",
1644         "SUB",
1645         "EVAL",
1646         "LOOP",
1647         "SUBST",
1648         "BLOCK",
1649 };
1650 #else
1651 EXTCONST char* block_type[];
1652 #endif
1653 #endif
1654
1655 /*****************************************************************************/
1656 /* This lexer/parser stuff is currently global since yacc is hard to reenter */
1657 /*****************************************************************************/
1658 /* XXX This needs to be revisited, since BEGIN makes yacc re-enter... */
1659
1660 #include "perly.h"
1661
1662 #define LEX_NOTPARSING          11      /* borrowed from toke.c */
1663
1664 typedef enum {
1665     XOPERATOR,
1666     XTERM,
1667     XREF,
1668     XSTATE,
1669     XBLOCK,
1670     XTERMBLOCK
1671 } expectation;
1672
1673 EXT U32         lex_state;      /* next token is determined */
1674 EXT U32         lex_defer;      /* state after determined token */
1675 EXT expectation lex_expect;     /* expect after determined token */
1676 EXT I32         lex_brackets;   /* bracket count */
1677 EXT I32         lex_formbrack;  /* bracket count at outer format level */
1678 EXT I32         lex_fakebrack;  /* outer bracket is mere delimiter */
1679 EXT I32         lex_casemods;   /* casemod count */
1680 EXT I32         lex_dojoin;     /* doing an array interpolation */
1681 EXT I32         lex_starts;     /* how many interps done on level */
1682 EXT SV *        lex_stuff;      /* runtime pattern from m// or s/// */
1683 EXT SV *        lex_repl;       /* runtime replacement from s/// */
1684 EXT OP *        lex_op;         /* extra info to pass back on op */
1685 EXT OP *        lex_inpat;      /* in pattern $) and $| are special */
1686 EXT I32         lex_inwhat;     /* what kind of quoting are we in */
1687 EXT char *      lex_brackstack; /* what kind of brackets to pop */
1688 EXT char *      lex_casestack;  /* what kind of case mods in effect */
1689
1690 /* What we know when we're in LEX_KNOWNEXT state. */
1691 EXT YYSTYPE     nextval[5];     /* value of next token, if any */
1692 EXT I32         nexttype[5];    /* type of next token */
1693 EXT I32         nexttoke;
1694
1695 EXT PerlIO * VOL        rsfp INIT(Nullfp);
1696 EXT SV *        linestr;
1697 EXT char *      bufptr;
1698 EXT char *      oldbufptr;
1699 EXT char *      oldoldbufptr;
1700 EXT char *      bufend;
1701 EXT expectation expect INIT(XSTATE);    /* how to interpret ambiguous tokens */
1702 EXT AV *        rsfp_filters;
1703
1704 EXT I32         multi_start;    /* 1st line of multi-line string */
1705 EXT I32         multi_end;      /* last line of multi-line string */
1706 EXT I32         multi_open;     /* delimiter of said string */
1707 EXT I32         multi_close;    /* delimiter of said string */
1708
1709 EXT GV *        scrgv;
1710 EXT I32         error_count;    /* how many errors so far, max 10 */
1711 EXT I32         subline;        /* line this subroutine began on */
1712 EXT SV *        subname;        /* name of current subroutine */
1713
1714 EXT CV *        compcv;         /* currently compiling subroutine */
1715 EXT AV *        comppad;        /* storage for lexically scoped temporaries */
1716 EXT AV *        comppad_name;   /* variable names for "my" variables */
1717 EXT I32         comppad_name_fill;/* last "introduced" variable offset */
1718 EXT I32         comppad_name_floor;/* start of vars in innermost block */
1719 EXT I32         min_intro_pending;/* start of vars to introduce */
1720 EXT I32         max_intro_pending;/* end of vars to introduce */
1721 EXT I32         padix;          /* max used index in current "register" pad */
1722 EXT I32         padix_floor;    /* how low may inner block reset padix */
1723 EXT I32         pad_reset_pending; /* reset pad on next attempted alloc */
1724 EXT COP         compiling;
1725
1726 EXT I32         thisexpr;       /* name id for nothing_in_common() */
1727 EXT char *      last_uni;       /* position of last named-unary operator */
1728 EXT char *      last_lop;       /* position of last list operator */
1729 EXT OPCODE      last_lop_op;    /* last list operator */
1730 EXT bool        in_my;          /* we're compiling a "my" declaration */
1731 EXT HV *        in_my_stash;    /* declared class of this "my" declaration */
1732 #ifdef FCRYPT
1733 EXT I32         cryptseen;      /* has fast crypt() been initialized? */
1734 #endif
1735
1736 EXT U32         hints;          /* various compilation flags */
1737
1738                                 /* Note: the lowest 8 bits are reserved for
1739                                    stuffing into op->op_private */
1740 #define HINT_INTEGER            0x00000001
1741 #define HINT_STRICT_REFS        0x00000002
1742
1743 #define HINT_BLOCK_SCOPE        0x00000100
1744 #define HINT_STRICT_SUBS        0x00000200
1745 #define HINT_STRICT_VARS        0x00000400
1746 #define HINT_LOCALE             0x00000800
1747
1748 /**************************************************************************/
1749 /* This regexp stuff is global since it always happens within 1 expr eval */
1750 /**************************************************************************/
1751
1752 EXT char *      regprecomp;     /* uncompiled string. */
1753 EXT char *      regparse;       /* Input-scan pointer. */
1754 EXT char *      regxend;        /* End of input for compile */
1755 EXT I32         regnpar;        /* () count. */
1756 EXT char *      regcode;        /* Code-emit pointer; &regdummy = don't. */
1757 EXT I32         regsize;        /* Code size. */
1758 EXT I32         regnaughty;     /* How bad is this pattern? */
1759 EXT I32         regsawback;     /* Did we see \1, ...? */
1760
1761 EXT char *      reginput;       /* String-input pointer. */
1762 EXT char *      regbol;         /* Beginning of input, for ^ check. */
1763 EXT char *      regeol;         /* End of input, for $ check. */
1764 EXT char **     regstartp;      /* Pointer to startp array. */
1765 EXT char **     regendp;        /* Ditto for endp. */
1766 EXT U32 *       reglastparen;   /* Similarly for lastparen. */
1767 EXT char *      regtill;        /* How far we are required to go. */
1768 EXT U16         regflags;       /* are we folding, multilining? */
1769 EXT char        regprev;        /* char before regbol, \n if none */
1770
1771 EXT bool        do_undump;      /* -u or dump seen? */
1772 EXT VOL U32     debug;
1773
1774 /***********************************************/
1775 /* Global only to current interpreter instance */
1776 /***********************************************/
1777
1778 #ifdef MULTIPLICITY
1779 #define IEXT
1780 #define IINIT(x)
1781 struct interpreter {
1782 #else
1783 #define IEXT EXT
1784 #define IINIT(x) INIT(x)
1785 #endif
1786
1787 /* pseudo environmental stuff */
1788 IEXT int        Iorigargc;
1789 IEXT char **    Iorigargv;
1790 IEXT GV *       Ienvgv;
1791 IEXT GV *       Isiggv;
1792 IEXT GV *       Iincgv;
1793 IEXT char *     Iorigfilename;
1794 IEXT SV *       Idiehook;
1795 IEXT SV *       Iwarnhook;
1796 IEXT SV *       Iparsehook;
1797
1798 /* Various states of an input record separator SV (rs, nrs) */
1799 #define RsSNARF(sv)   (! SvOK(sv))
1800 #define RsSIMPLE(sv)  (SvOK(sv) && SvCUR(sv))
1801 #define RsPARA(sv)    (SvOK(sv) && ! SvCUR(sv))
1802
1803 /* switches */
1804 IEXT char *     Icddir;
1805 IEXT bool       Iminus_c;
1806 IEXT char       Ipatchlevel[10];
1807 IEXT char **    Ilocalpatches;
1808 IEXT SV *       Inrs;
1809 IEXT char *     Isplitstr IINIT(" ");
1810 IEXT bool       Ipreprocess;
1811 IEXT bool       Iminus_n;
1812 IEXT bool       Iminus_p;
1813 IEXT bool       Iminus_l;
1814 IEXT bool       Iminus_a;
1815 IEXT bool       Iminus_F;
1816 IEXT bool       Idoswitches;
1817 IEXT bool       Idowarn;
1818 IEXT bool       Idoextract;
1819 IEXT bool       Isawampersand;  /* must save all match strings */
1820 IEXT bool       Isawstudy;      /* do fbm_instr on all strings */
1821 IEXT bool       Isawvec;
1822 IEXT bool       Iunsafe;
1823 IEXT char *     Iinplace;
1824 IEXT char *     Ie_tmpname;
1825 IEXT PerlIO *   Ie_fp;
1826 IEXT U32        Iperldb;
1827         /* This value may be raised by extensions for testing purposes */
1828 IEXT int        Iperl_destruct_level IINIT(0);  /* 0=none, 1=full, 2=full with checks */
1829
1830 /* magical thingies */
1831 IEXT Time_t     Ibasetime;              /* $^T */
1832 IEXT SV *       Iformfeed;              /* $^L */
1833 IEXT char *     Ichopset IINIT(" \n-"); /* $: */
1834 IEXT SV *       Irs;                    /* $/ */
1835 IEXT char *     Iofs;                   /* $, */
1836 IEXT STRLEN     Iofslen;
1837 IEXT char *     Iors;                   /* $\ */
1838 IEXT STRLEN     Iorslen;
1839 IEXT char *     Iofmt;                  /* $# */
1840 IEXT I32        Imaxsysfd IINIT(MAXSYSFD); /* top fd to pass to subprocesses */
1841 IEXT int        Imultiline;             /* $*--do strings hold >1 line? */
1842 IEXT I32        Istatusvalue;           /* $? */
1843 #ifdef VMS
1844 IEXT U32        Istatusvalue_vms;
1845 #endif
1846
1847 IEXT struct stat Istatcache;            /* _ */
1848 IEXT GV *       Istatgv;
1849 IEXT SV *       Istatname IINIT(Nullsv);
1850
1851 /* shortcuts to various I/O objects */
1852 IEXT GV *       Istdingv;
1853 IEXT GV *       Ilast_in_gv;
1854 IEXT GV *       Idefgv;
1855 IEXT GV *       Iargvgv;
1856 IEXT GV *       Idefoutgv;
1857 IEXT GV *       Iargvoutgv;
1858
1859 /* shortcuts to regexp stuff */
1860 IEXT GV *       Ileftgv;
1861 IEXT GV *       Iampergv;
1862 IEXT GV *       Irightgv;
1863 IEXT PMOP *     Icurpm;         /* what to do \ interps from */
1864 IEXT I32 *      Iscreamfirst;
1865 IEXT I32 *      Iscreamnext;
1866 IEXT I32        Imaxscream IINIT(-1);
1867 IEXT SV *       Ilastscream;
1868
1869 /* shortcuts to misc objects */
1870 IEXT GV *       Ierrgv;
1871
1872 /* shortcuts to debugging objects */
1873 IEXT GV *       IDBgv;
1874 IEXT GV *       IDBline;
1875 IEXT GV *       IDBsub;
1876 IEXT SV *       IDBsingle;
1877 IEXT SV *       IDBtrace;
1878 IEXT SV *       IDBsignal;
1879 IEXT AV *       Ilineary;       /* lines of script for debugger */
1880 IEXT AV *       Idbargs;        /* args to call listed by caller function */
1881
1882 /* symbol tables */
1883 IEXT HV *       Idefstash;      /* main symbol table */
1884 IEXT HV *       Icurstash;      /* symbol table for current package */
1885 IEXT HV *       Idebstash;      /* symbol table for perldb package */
1886 IEXT SV *       Icurstname;     /* name of current package */
1887 IEXT AV *       Ibeginav;       /* names of BEGIN subroutines */
1888 IEXT AV *       Iendav;         /* names of END subroutines */
1889 IEXT AV *       Iinitav;        /* names of INIT subroutines */
1890 IEXT HV *       Istrtab;        /* shared string table */
1891
1892 /* memory management */
1893 IEXT SV **      Itmps_stack;
1894 IEXT I32        Itmps_ix IINIT(-1);
1895 IEXT I32        Itmps_floor IINIT(-1);
1896 IEXT I32        Itmps_max;
1897 IEXT I32        Isv_count;      /* how many SV* are currently allocated */
1898 IEXT I32        Isv_objcount;   /* how many objects are currently allocated */
1899 IEXT SV*        Isv_root;       /* storage for SVs belonging to interp */
1900 IEXT SV*        Isv_arenaroot;  /* list of areas for garbage collection */
1901
1902 /* funky return mechanisms */
1903 IEXT I32        Ilastspbase;
1904 IEXT I32        Ilastsize;
1905 IEXT int        Iforkprocess;   /* so do_open |- can return proc# */
1906
1907 /* subprocess state */
1908 IEXT AV *       Ifdpid;         /* keep fd-to-pid mappings for my_popen */
1909
1910 /* internal state */
1911 IEXT VOL int    Iin_eval;       /* trap "fatal" errors? */
1912 IEXT OP *       Irestartop;     /* Are we propagating an error from croak? */
1913 IEXT int        Idelaymagic;    /* ($<,$>) = ... */
1914 IEXT bool       Idirty;         /* In the middle of tearing things down? */
1915 IEXT U8         Ilocalizing;    /* are we processing a local() list? */
1916 IEXT bool       Itainted;       /* using variables controlled by $< */
1917 IEXT bool       Itainting;      /* doing taint checks */
1918 IEXT char *     Iop_mask IINIT(NULL);   /* masked operations for safe evals */
1919
1920 /* trace state */
1921 IEXT I32        Idlevel;
1922 IEXT I32        Idlmax IINIT(128);
1923 IEXT char *     Idebname;
1924 IEXT char *     Idebdelim;
1925
1926 /* current interpreter roots */
1927 IEXT CV *       Imain_cv;
1928 IEXT OP *       Imain_root;
1929 IEXT OP *       Imain_start;
1930 IEXT OP *       Ieval_root;
1931 IEXT OP *       Ieval_start;
1932
1933 /* runtime control stuff */
1934 IEXT COP * VOL  Icurcop IINIT(&compiling);
1935 IEXT COP *      Icurcopdb IINIT(NULL);
1936 IEXT line_t     Icopline IINIT(NOLINE);
1937 IEXT CONTEXT *  Icxstack;
1938 IEXT I32        Icxstack_ix IINIT(-1);
1939 IEXT I32        Icxstack_max IINIT(128);
1940 IEXT JMPENV     Istart_env;     /* empty startup sigjmp() environment */
1941 IEXT JMPENV *   Itop_env;       /* ptr. to current sigjmp() environment */
1942 IEXT I32        Irunlevel;
1943
1944 /* stack stuff */
1945 IEXT AV *       Icurstack;              /* THE STACK */
1946 IEXT AV *       Imainstack;     /* the stack when nothing funny is happening */
1947
1948 /* format accumulators */
1949 IEXT SV *       Iformtarget;
1950 IEXT SV *       Ibodytarget;
1951 IEXT SV *       Itoptarget;
1952
1953 /* statics moved here for shared library purposes */
1954 IEXT SV         Istrchop;       /* return value from chop */
1955 IEXT int        Ifilemode;      /* so nextargv() can preserve mode */
1956 IEXT int        Ilastfd;        /* what to preserve mode on */
1957 IEXT char *     Ioldname;       /* what to preserve mode on */
1958 IEXT char **    IArgv;          /* stuff to free from do_aexec, vfork safe */
1959 IEXT char *     ICmd;           /* stuff to free from do_aexec, vfork safe */
1960 IEXT OP *       Isortcop;       /* user defined sort routine */
1961 IEXT HV *       Isortstash;     /* which is in some package or other */
1962 IEXT GV *       Ifirstgv;       /* $a */
1963 IEXT GV *       Isecondgv;      /* $b */
1964 IEXT AV *       Isortstack;     /* temp stack during pp_sort() */
1965 IEXT AV *       Isignalstack;   /* temp stack during sighandler() */
1966 IEXT SV *       Imystrk;        /* temp key string for do_each() */
1967 IEXT I32        Idumplvl;       /* indentation level on syntax tree dump */
1968 IEXT PMOP *     Ioldlastpm;     /* for saving regexp context during debugger */
1969 IEXT I32        Igensym;        /* next symbol for getsym() to define */
1970 IEXT bool       Ipreambled;
1971 IEXT AV *       Ipreambleav;
1972 IEXT int        Ilaststatval IINIT(-1);
1973 IEXT I32        Ilaststype IINIT(OP_STAT);
1974 IEXT SV *       Imess_sv;
1975
1976 #ifdef USE_THREADS
1977 /* threads stuff */
1978 IEXT SV *       Ithrsv;         /* holds struct thread for main thread */
1979 #endif /* USE_THREADS */
1980
1981 #undef IEXT
1982 #undef IINIT
1983
1984 #ifdef MULTIPLICITY
1985 };
1986 #else
1987 struct interpreter {
1988     char broiled;
1989 };
1990 #endif
1991
1992 #include "thread.h"
1993 #include "pp.h"
1994
1995 #ifdef __cplusplus
1996 extern "C" {
1997 #endif
1998
1999 #include "proto.h"
2000
2001 #ifdef EMBED
2002 #define Perl_sv_setptrobj(rv,ptr,name) Perl_sv_setref_iv(rv,name,(IV)ptr)
2003 #define Perl_sv_setptrref(rv,ptr) Perl_sv_setref_iv(rv,Nullch,(IV)ptr)
2004 #else
2005 #define sv_setptrobj(rv,ptr,name) sv_setref_iv(rv,name,(IV)ptr)
2006 #define sv_setptrref(rv,ptr) sv_setref_iv(rv,Nullch,(IV)ptr)
2007 #endif
2008
2009 #ifdef __cplusplus
2010 };
2011 #endif
2012
2013 /* The following must follow proto.h */
2014
2015 #ifdef DOINIT
2016
2017 EXT MGVTBL vtbl_sv =    {magic_get,
2018                                 magic_set,
2019                                         magic_len,
2020                                                 0,      0};
2021 EXT MGVTBL vtbl_env =   {0,     magic_set_all_env,
2022                                 0,      magic_clear_all_env,
2023                                                         0};
2024 EXT MGVTBL vtbl_envelem =       {0,     magic_setenv,
2025                                         0,      magic_clearenv,
2026                                                         0};
2027 EXT MGVTBL vtbl_sig =   {0,     0,               0, 0, 0};
2028 EXT MGVTBL vtbl_sigelem =       {magic_getsig,
2029                                         magic_setsig,
2030                                         0,      magic_clearsig,
2031                                                         0};
2032 EXT MGVTBL vtbl_pack =  {0,     0,      0,      magic_wipepack,
2033                                                         0};
2034 EXT MGVTBL vtbl_packelem =      {magic_getpack,
2035                                 magic_setpack,
2036                                         0,      magic_clearpack,
2037                                                         0};
2038 EXT MGVTBL vtbl_dbline =        {0,     magic_setdbline,
2039                                         0,      0,      0};
2040 EXT MGVTBL vtbl_isa =   {0,     magic_setisa,
2041                                         0,      magic_setisa,
2042                                                         0};
2043 EXT MGVTBL vtbl_isaelem =       {0,     magic_setisa,
2044                                         0,      0,      0};
2045 EXT MGVTBL vtbl_arylen =        {magic_getarylen,
2046                                 magic_setarylen,
2047                                         0,      0,      0};
2048 EXT MGVTBL vtbl_glob =  {magic_getglob,
2049                                 magic_setglob,
2050                                         0,      0,      0};
2051 EXT MGVTBL vtbl_mglob = {0,     magic_setmglob,
2052                                         0,      0,      0};
2053 EXT MGVTBL vtbl_nkeys = {0,     magic_setnkeys,
2054                                         0,      0,      0};
2055 EXT MGVTBL vtbl_taint = {magic_gettaint,magic_settaint,
2056                                         0,      0,      0};
2057 EXT MGVTBL vtbl_substr =        {0,     magic_setsubstr,
2058                                         0,      0,      0};
2059 EXT MGVTBL vtbl_vec =   {0,     magic_setvec,
2060                                         0,      0,      0};
2061 EXT MGVTBL vtbl_pos =   {magic_getpos,
2062                                 magic_setpos,
2063                                         0,      0,      0};
2064 EXT MGVTBL vtbl_bm =    {0,     magic_setbm,
2065                                         0,      0,      0};
2066 EXT MGVTBL vtbl_fm =    {0,     magic_setfm,
2067                                         0,      0,      0};
2068 EXT MGVTBL vtbl_uvar =  {magic_getuvar,
2069                                 magic_setuvar,
2070                                         0,      0,      0};
2071 #ifdef USE_THREADS
2072 EXT MGVTBL vtbl_mutex = {0,     0,      0,      0,      magic_mutexfree};
2073 #endif /* USE_THREADS */
2074 EXT MGVTBL vtbl_defelem = {magic_getdefelem,magic_setdefelem,
2075                                         0,      0,      magic_freedefelem};
2076
2077 #ifdef USE_LOCALE_COLLATE
2078 EXT MGVTBL vtbl_collxfrm = {0,
2079                                 magic_setcollxfrm,
2080                                         0,      0,      0};
2081 #endif
2082
2083 #ifdef OVERLOAD
2084 EXT MGVTBL vtbl_amagic =       {0,     magic_setamagic,
2085                                         0,      0,      magic_setamagic};
2086 EXT MGVTBL vtbl_amagicelem =   {0,     magic_setamagic,
2087                                         0,      0,      magic_setamagic};
2088 #endif /* OVERLOAD */
2089
2090 #else /* !DOINIT */
2091
2092 EXT MGVTBL vtbl_sv;
2093 EXT MGVTBL vtbl_env;
2094 EXT MGVTBL vtbl_envelem;
2095 EXT MGVTBL vtbl_sig;
2096 EXT MGVTBL vtbl_sigelem;
2097 EXT MGVTBL vtbl_pack;
2098 EXT MGVTBL vtbl_packelem;
2099 EXT MGVTBL vtbl_dbline;
2100 EXT MGVTBL vtbl_isa;
2101 EXT MGVTBL vtbl_isaelem;
2102 EXT MGVTBL vtbl_arylen;
2103 EXT MGVTBL vtbl_glob;
2104 EXT MGVTBL vtbl_mglob;
2105 EXT MGVTBL vtbl_nkeys;
2106 EXT MGVTBL vtbl_taint;
2107 EXT MGVTBL vtbl_substr;
2108 EXT MGVTBL vtbl_vec;
2109 EXT MGVTBL vtbl_pos;
2110 EXT MGVTBL vtbl_bm;
2111 EXT MGVTBL vtbl_fm;
2112 EXT MGVTBL vtbl_uvar;
2113
2114 #ifdef USE_THREADS
2115 EXT MGVTBL vtbl_mutex;
2116 #endif /* USE_THREADS */
2117
2118 EXT MGVTBL vtbl_defelem;
2119
2120 #ifdef USE_LOCALE_COLLATE
2121 EXT MGVTBL vtbl_collxfrm;
2122 #endif
2123
2124 #ifdef OVERLOAD
2125 EXT MGVTBL vtbl_amagic;
2126 EXT MGVTBL vtbl_amagicelem;
2127 #endif /* OVERLOAD */
2128
2129 #endif /* !DOINIT */
2130
2131 #ifdef OVERLOAD
2132
2133 EXT long amagic_generation;
2134
2135 #define NofAMmeth 58
2136 #ifdef DOINIT
2137 EXTCONST char * AMG_names[NofAMmeth] = {
2138   "fallback",   "abs",                  /* "fallback" should be the first. */
2139   "bool",       "nomethod",
2140   "\"\"",       "0+",
2141   "+",          "+=",
2142   "-",          "-=",
2143   "*",          "*=",
2144   "/",          "/=",
2145   "%",          "%=",
2146   "**",         "**=",
2147   "<<",         "<<=",
2148   ">>",         ">>=",
2149   "&",          "&=",
2150   "|",          "|=",
2151   "^",          "^=",
2152   "<",          "<=",
2153   ">",          ">=",
2154   "==",         "!=",
2155   "<=>",        "cmp",
2156   "lt",         "le",
2157   "gt",         "ge",
2158   "eq",         "ne",
2159   "!",          "~",
2160   "++",         "--",
2161   "atan2",      "cos",
2162   "sin",        "exp",
2163   "log",        "sqrt",
2164   "x",          "x=",
2165   ".",          ".=",
2166   "=",          "neg"
2167 };
2168 #else
2169 EXTCONST char * AMG_names[NofAMmeth];
2170 #endif /* def INITAMAGIC */
2171
2172 struct am_table {
2173   long was_ok_sub;
2174   long was_ok_am;
2175   U32 flags;
2176   CV* table[NofAMmeth];
2177   long fallback;
2178 };
2179 struct am_table_short {
2180   long was_ok_sub;
2181   long was_ok_am;
2182   U32 flags;
2183 };
2184 typedef struct am_table AMT;
2185 typedef struct am_table_short AMTS;
2186
2187 #define AMGfallNEVER    1
2188 #define AMGfallNO       2
2189 #define AMGfallYES      3
2190
2191 #define AMTf_AMAGIC             1
2192 #define AMT_AMAGIC(amt)         ((amt)->flags & AMTf_AMAGIC)
2193 #define AMT_AMAGIC_on(amt)      ((amt)->flags |= AMTf_AMAGIC)
2194 #define AMT_AMAGIC_off(amt)     ((amt)->flags &= ~AMTf_AMAGIC)
2195
2196 enum {
2197   fallback_amg, abs_amg,
2198   bool__amg,    nomethod_amg,
2199   string_amg,   numer_amg,
2200   add_amg,      add_ass_amg,
2201   subtr_amg,    subtr_ass_amg,
2202   mult_amg,     mult_ass_amg,
2203   div_amg,      div_ass_amg,
2204   mod_amg,      mod_ass_amg,
2205   pow_amg,      pow_ass_amg,
2206   lshift_amg,   lshift_ass_amg,
2207   rshift_amg,   rshift_ass_amg,
2208   band_amg,     band_ass_amg,
2209   bor_amg,      bor_ass_amg,
2210   bxor_amg,     bxor_ass_amg,
2211   lt_amg,       le_amg,
2212   gt_amg,       ge_amg,
2213   eq_amg,       ne_amg,
2214   ncmp_amg,     scmp_amg,
2215   slt_amg,      sle_amg,
2216   sgt_amg,      sge_amg,
2217   seq_amg,      sne_amg,
2218   not_amg,      compl_amg,
2219   inc_amg,      dec_amg,
2220   atan2_amg,    cos_amg,
2221   sin_amg,      exp_amg,
2222   log_amg,      sqrt_amg,
2223   repeat_amg,   repeat_ass_amg,
2224   concat_amg,   concat_ass_amg,
2225   copy_amg,     neg_amg
2226 };
2227
2228 /*
2229  * some compilers like to redefine cos et alia as faster
2230  * (and less accurate?) versions called F_cos et cetera (Quidquid
2231  * latine dictum sit, altum viditur.)  This trick collides with
2232  * the Perl overloading (amg).  The following #defines fool both.
2233  */
2234
2235 #ifdef _FASTMATH
2236 #   ifdef atan2
2237 #       define F_atan2_amg  atan2_amg
2238 #   endif
2239 #   ifdef cos
2240 #       define F_cos_amg    cos_amg
2241 #   endif
2242 #   ifdef exp
2243 #       define F_exp_amg    exp_amg
2244 #   endif
2245 #   ifdef log
2246 #       define F_log_amg    log_amg
2247 #   endif
2248 #   ifdef pow
2249 #       define F_pow_amg    pow_amg
2250 #   endif
2251 #   ifdef sin
2252 #       define F_sin_amg    sin_amg
2253 #   endif
2254 #   ifdef sqrt
2255 #       define F_sqrt_amg   sqrt_amg
2256 #   endif
2257 #endif /* _FASTMATH */
2258
2259 #endif /* OVERLOAD */
2260
2261 #define PERLDB_ALL      0xff
2262 #define PERLDBf_SUB     0x01            /* Debug sub enter/exit. */
2263 #define PERLDBf_LINE    0x02            /* Keep line #. */
2264 #define PERLDBf_NOOPT   0x04            /* Switch off optimizations. */
2265 #define PERLDBf_INTER   0x08            /* Preserve more data for
2266                                            later inspections.  */
2267 #define PERLDBf_SUBLINE 0x10            /* Keep subr source lines. */
2268 #define PERLDBf_SINGLE  0x20            /* Start with single-step on. */
2269
2270 #define PERLDB_SUB      (perldb && (perldb & PERLDBf_SUB))
2271 #define PERLDB_LINE     (perldb && (perldb & PERLDBf_LINE))
2272 #define PERLDB_NOOPT    (perldb && (perldb & PERLDBf_NOOPT))
2273 #define PERLDB_INTER    (perldb && (perldb & PERLDBf_INTER))
2274 #define PERLDB_SUBLINE  (perldb && (perldb & PERLDBf_SUBLINE))
2275 #define PERLDB_SINGLE   (perldb && (perldb & PERLDBf_SINGLE))
2276
2277 #ifdef USE_LOCALE_COLLATE
2278 EXT U32         collation_ix;           /* Collation generation index */
2279 EXT char *      collation_name;         /* Name of current collation */
2280 EXT bool        collation_standard INIT(TRUE); /* Assume simple collation */
2281 EXT Size_t      collxfrm_base;          /* Basic overhead in *xfrm() */
2282 EXT Size_t      collxfrm_mult INIT(2);  /* Expansion factor in *xfrm() */
2283 #endif /* USE_LOCALE_COLLATE */
2284
2285 #ifdef USE_LOCALE_NUMERIC
2286
2287 EXT char *      numeric_name;           /* Name of current numeric locale */
2288 EXT bool        numeric_standard INIT(TRUE); /* Assume simple numerics */
2289 EXT bool        numeric_local INIT(TRUE);    /* Assume local numerics */
2290
2291 #define SET_NUMERIC_STANDARD() \
2292     STMT_START {                                \
2293         if (! numeric_standard)                 \
2294             perl_set_numeric_standard();        \
2295     } STMT_END
2296
2297 #define SET_NUMERIC_LOCAL() \
2298     STMT_START {                                \
2299         if (! numeric_local)                    \
2300             perl_set_numeric_local();           \
2301     } STMT_END
2302
2303 #else /* !USE_LOCALE_NUMERIC */
2304
2305 #define SET_NUMERIC_STANDARD()  /**/
2306 #define SET_NUMERIC_LOCAL()     /**/
2307
2308 #endif /* !USE_LOCALE_NUMERIC */
2309
2310 #if !defined(PERLIO_IS_STDIO) && defined(HAS_ATTRIBUTE)
2311 /* 
2312  * Now we have __attribute__ out of the way 
2313  * Remap printf 
2314  */
2315 #define printf PerlIO_stdoutf
2316 #endif
2317
2318 /*
2319  * nice_chunk and nice_chunk size need to be set
2320  * and queried under the protection of sv_mutex
2321  */
2322 #define offer_nice_chunk(chunk, chunk_size) do {        \
2323         MUTEX_LOCK(&sv_mutex);                          \
2324         if (!nice_chunk) {                              \
2325             nice_chunk = (char*)(chunk);                \
2326             nice_chunk_size = (chunk_size);             \
2327         }                                               \
2328         MUTEX_UNLOCK(&sv_mutex);                        \
2329     } while (0)
2330
2331 #endif /* Include guard */
2332