ffc1704924add804e0a80ce20f9cad9a28753357
[p5sagit/p5-mst-13.2.git] / perl.h
1 /*    perl.h
2  *
3  *    Copyright (c) 1987-1994, 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 #include "embed.h"
14
15 #define VOIDUSED 1
16 #include "config.h"
17
18 #ifndef BYTEORDER
19 #   define BYTEORDER 0x1234
20 #endif
21
22 /* Overall memory policy? */
23 #ifndef CONSERVATIVE
24 #   define LIBERAL 1
25 #endif
26
27 /*
28  * The following contortions are brought to you on behalf of all the
29  * standards, semi-standards, de facto standards, not-so-de-facto standards
30  * of the world, as well as all the other botches anyone ever thought of.
31  * The basic theory is that if we work hard enough here, the rest of the
32  * code can be a lot prettier.  Well, so much for theory.  Sorry, Henry...
33  */
34
35 #ifdef MYMALLOC
36 #   ifdef HIDEMYMALLOC
37 #       define malloc Mymalloc
38 #       define realloc Myremalloc
39 #       define free Myfree
40 #   endif
41 #   define safemalloc malloc
42 #   define saferealloc realloc
43 #   define safefree free
44 #endif
45
46 /* work around some libPW problems */
47 #ifdef DOINIT
48 EXT char Error[1];
49 #endif
50
51 /* define this once if either system, instead of cluttering up the src */
52 #if defined(MSDOS) || defined(atarist)
53 #define DOSISH 1
54 #endif
55
56 #if defined(__STDC__) || defined(vax11c) || defined(_AIX) || defined(__stdc__) || defined(__cplusplus)
57 # define STANDARD_C 1
58 #endif
59
60 #if defined(HASVOLATILE) || defined(STANDARD_C)
61 #   ifdef __cplusplus
62 #       define VOL              // to temporarily suppress warnings
63 #   else
64 #       define VOL volatile
65 #   endif
66 #else
67 #   define VOL
68 #endif
69
70 #define TAINT_IF(c)     (tainted |= (c))
71 #define TAINT_NOT       (tainted = 0)
72 #define TAINT_PROPER(s) if (tainting) taint_proper(no_security, s)
73 #define TAINT_ENV()     if (tainting) taint_env()
74
75 #ifndef HAS_VFORK
76 #   define vfork fork
77 #endif
78
79 #ifdef HAS_GETPGRP2
80 #   ifndef HAS_GETPGRP
81 #       define HAS_GETPGRP
82 #   endif
83 #endif
84
85 #ifdef HAS_SETPGRP2
86 #   ifndef HAS_SETPGRP
87 #       define HAS_SETPGRP
88 #   endif
89 #endif
90
91 #include <stdio.h>
92 #ifdef USE_NEXT_CTYPE 
93 #include <appkit/NXCType.h>
94 #else
95 #include <ctype.h>
96 #endif
97
98 #ifdef METHOD   /* Defined by OSF/1 v3.0 by ctype.h */
99 #undef METHOD
100 #endif
101
102 #include <setjmp.h>
103
104 #ifdef I_SYS_PARAM
105 #   ifdef PARAM_NEEDS_TYPES
106 #       include <sys/types.h>
107 #   endif
108 #   include <sys/param.h>
109 #endif
110
111
112 /* Use all the "standard" definitions? */
113 #if defined(STANDARD_C) && defined(I_STDLIB)
114 #   include <stdlib.h>
115 #endif /* STANDARD_C */
116
117 #define MEM_SIZE Size_t
118
119 #if defined(I_STRING) || defined(__cplusplus)
120 #   include <string.h>
121 #else
122 #   include <strings.h>
123 #endif
124
125 #if !defined(HAS_STRCHR) && defined(HAS_INDEX) && !defined(strchr)
126 #define strchr index
127 #define strrchr rindex
128 #endif
129
130 #if defined(mips) && defined(ultrix) && !defined(__STDC__)
131 #   undef HAS_MEMCMP
132 #endif
133
134 #ifdef HAS_MEMCPY
135 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
136 #    ifndef memcpy
137         extern char * memcpy _((char*, char*, int));
138 #    endif
139 #  endif
140 #else
141 #   ifndef memcpy
142 #       ifdef HAS_BCOPY
143 #           define memcpy(d,s,l) bcopy(s,d,l)
144 #       else
145 #           define memcpy(d,s,l) my_bcopy(s,d,l)
146 #       endif
147 #   endif
148 #endif /* HAS_MEMCPY */
149
150 #ifdef HAS_MEMSET
151 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
152 #    ifndef memset
153         extern char *memset _((char*, int, int));
154 #    endif
155 #  endif
156 #  define memzero(d,l) memset(d,0,l)
157 #else
158 #   ifndef memzero
159 #       ifdef HAS_BZERO
160 #           define memzero(d,l) bzero(d,l)
161 #       else
162 #           define memzero(d,l) my_bzero(d,l)
163 #       endif
164 #   endif
165 #endif /* HAS_MEMSET */
166
167 #ifdef HAS_MEMCMP
168 #  if !defined(STANDARD_C) && !defined(I_STRING) && !defined(I_MEMORY)
169 #    ifndef memcmp
170         extern int memcmp _((char*, char*, int));
171 #    endif
172 #  endif
173 #else
174 #   ifndef memcmp
175 #       define memcmp   my_memcmp
176 #   endif
177 #endif /* HAS_MEMCMP */
178
179 /* we prefer bcmp slightly for comparisons that don't care about ordering */
180 #ifndef HAS_BCMP
181 #   ifndef bcmp
182 #       define bcmp(s1,s2,l) memcmp(s1,s2,l)
183 #   endif
184 #endif /* HAS_BCMP */
185
186 #if !defined(HAS_MEMMOVE) && !defined(memmove)
187 #   if defined(HAS_BCOPY) && defined(HAS_SAFE_BCOPY)
188 #       define memmove(d,s,l) bcopy(s,d,l)
189 #   else
190 #       if defined(HAS_MEMCPY) && defined(HAS_SAFE_MEMCPY)
191 #           define memmove(d,s,l) memcpy(d,s,l)
192 #       else
193 #           define memmove(d,s,l) my_bcopy(s,d,l)
194 #       endif
195 #   endif
196 #endif
197
198 #ifndef _TYPES_         /* If types.h defines this it's easy. */
199 #   ifndef major                /* Does everyone's types.h define this? */
200 #       include <sys/types.h>
201 #   endif
202 #endif
203
204 #ifdef I_NETINET_IN
205 #   include <netinet/in.h>
206 #endif
207
208 #include <sys/stat.h>
209
210 /* The stat macros for Amdahl UTS, Unisoft System V/88 (and derivatives
211    like UTekV) are broken, sometimes giving false positives.  Undefine
212    them here and let the code below set them to proper values.
213
214    The ghs macro stands for GreenHills Software C-1.8.5 which
215    is the C compiler for sysV88 and the various derivatives.
216    This header file bug is corrected in gcc-2.5.8 and later versions.
217    --Kaveh Ghazi (ghazi@noc.rutgers.edu) 10/3/94.  */
218
219 #if defined(uts) || (defined(m88k) && defined(ghs))
220 #   undef S_ISDIR
221 #   undef S_ISCHR
222 #   undef S_ISBLK
223 #   undef S_ISREG
224 #   undef S_ISFIFO
225 #   undef S_ISLNK
226 #endif
227
228 #ifdef I_TIME
229 #   include <time.h>
230 #endif
231
232 #ifdef I_SYS_TIME
233 #   ifdef I_SYS_TIME_KERNEL
234 #       define KERNEL
235 #   endif
236 #   include <sys/time.h>
237 #   ifdef I_SYS_TIME_KERNEL
238 #       undef KERNEL
239 #   endif
240 #endif
241
242 #ifndef MSDOS
243 #  if defined(HAS_TIMES) && defined(I_SYS_TIMES)
244 #    include <sys/times.h>
245 #  endif
246 #endif
247
248 #if defined(HAS_STRERROR) && (!defined(HAS_MKDIR) || !defined(HAS_RMDIR))
249 #   undef HAS_STRERROR
250 #endif
251
252 #ifndef HAS_MKFIFO
253 #  ifndef mkfifo
254 #    define mkfifo(path, mode) (mknod((path), (mode) | S_IFIFO, 0))
255 #  endif
256 #endif /* !HAS_MKFIFO */
257
258 #include <errno.h>
259 #ifdef HAS_SOCKET
260 #   ifdef I_NET_ERRNO
261 #     include <net/errno.h>
262 #   endif
263 #endif
264
265 #ifndef MSDOS
266 #   ifndef errno
267         extern int errno;     /* ANSI allows errno to be an lvalue expr */
268 #   endif
269 #endif
270
271 #ifdef HAS_STRERROR
272 #       ifdef VMS
273         char *strerror _((int,...));
274 #       else
275         char *strerror _((int));
276 #       endif
277 #       ifndef Strerror
278 #           define Strerror strerror
279 #       endif
280 #else
281 #    ifdef HAS_SYS_ERRLIST
282         extern int sys_nerr;
283         extern char *sys_errlist[];
284 #       ifndef Strerror
285 #           define Strerror(e) \
286                 ((e) < 0 || (e) >= sys_nerr ? "(unknown)" : sys_errlist[e])
287 #       endif
288 #   endif
289 #endif
290
291 #ifdef I_SYS_IOCTL
292 #   ifndef _IOCTL_
293 #       include <sys/ioctl.h>
294 #   endif
295 #endif
296
297 #if defined(mc300) || defined(mc500) || defined(mc700) || defined(mc6000)
298 #   ifdef HAS_SOCKETPAIR
299 #       undef HAS_SOCKETPAIR
300 #   endif
301 #   ifdef I_NDBM
302 #       undef I_NDBM
303 #   endif
304 #endif
305
306 #if INTSIZE == 2
307 #   define htoni htons
308 #   define ntohi ntohs
309 #else
310 #   define htoni htonl
311 #   define ntohi ntohl
312 #endif
313
314 /* Configure already sets Direntry_t */
315 #if defined(I_DIRENT)
316 #   include <dirent.h>
317 #   if defined(NeXT) && defined(I_SYS_DIR) /* NeXT needs dirent + sys/dir.h */
318 #       include <sys/dir.h>
319 #   endif
320 #else
321 #   ifdef I_SYS_NDIR
322 #       include <sys/ndir.h>
323 #   else
324 #       ifdef I_SYS_DIR
325 #           ifdef hp9000s500
326 #               include <ndir.h>        /* may be wrong in the future */
327 #           else
328 #               include <sys/dir.h>
329 #           endif
330 #       endif
331 #   endif
332 #endif 
333
334 #ifdef FPUTS_BOTCH
335 /* work around botch in SunOS 4.0.1 and 4.0.2 */
336 #   ifndef fputs
337 #       define fputs(sv,fp) fprintf(fp,"%s",sv)
338 #   endif
339 #endif
340
341 /*
342  * The following gobbledygook brought to you on behalf of __STDC__.
343  * (I could just use #ifndef __STDC__, but this is more bulletproof
344  * in the face of half-implementations.)
345  */
346
347 #ifndef S_IFMT
348 #   ifdef _S_IFMT
349 #       define S_IFMT _S_IFMT
350 #   else
351 #       define S_IFMT 0170000
352 #   endif
353 #endif
354
355 #ifndef S_ISDIR
356 #   define S_ISDIR(m) ((m & S_IFMT) == S_IFDIR)
357 #endif
358
359 #ifndef S_ISCHR
360 #   define S_ISCHR(m) ((m & S_IFMT) == S_IFCHR)
361 #endif
362
363 #ifndef S_ISBLK
364 #   ifdef S_IFBLK
365 #       define S_ISBLK(m) ((m & S_IFMT) == S_IFBLK)
366 #   else
367 #       define S_ISBLK(m) (0)
368 #   endif
369 #endif
370
371 #ifndef S_ISREG
372 #   define S_ISREG(m) ((m & S_IFMT) == S_IFREG)
373 #endif
374
375 #ifndef S_ISFIFO
376 #   ifdef S_IFIFO
377 #       define S_ISFIFO(m) ((m & S_IFMT) == S_IFIFO)
378 #   else
379 #       define S_ISFIFO(m) (0)
380 #   endif
381 #endif
382
383 #ifndef S_ISLNK
384 #   ifdef _S_ISLNK
385 #       define S_ISLNK(m) _S_ISLNK(m)
386 #   else
387 #       ifdef _S_IFLNK
388 #           define S_ISLNK(m) ((m & S_IFMT) == _S_IFLNK)
389 #       else
390 #           ifdef S_IFLNK
391 #               define S_ISLNK(m) ((m & S_IFMT) == S_IFLNK)
392 #           else
393 #               define S_ISLNK(m) (0)
394 #           endif
395 #       endif
396 #   endif
397 #endif
398
399 #ifndef S_ISSOCK
400 #   ifdef _S_ISSOCK
401 #       define S_ISSOCK(m) _S_ISSOCK(m)
402 #   else
403 #       ifdef _S_IFSOCK
404 #           define S_ISSOCK(m) ((m & S_IFMT) == _S_IFSOCK)
405 #       else
406 #           ifdef S_IFSOCK
407 #               define S_ISSOCK(m) ((m & S_IFMT) == S_IFSOCK)
408 #           else
409 #               define S_ISSOCK(m) (0)
410 #           endif
411 #       endif
412 #   endif
413 #endif
414
415 #ifndef S_IRUSR
416 #   ifdef S_IREAD
417 #       define S_IRUSR S_IREAD
418 #       define S_IWUSR S_IWRITE
419 #       define S_IXUSR S_IEXEC
420 #   else
421 #       define S_IRUSR 0400
422 #       define S_IWUSR 0200
423 #       define S_IXUSR 0100
424 #   endif
425 #   define S_IRGRP (S_IRUSR>>3)
426 #   define S_IWGRP (S_IWUSR>>3)
427 #   define S_IXGRP (S_IXUSR>>3)
428 #   define S_IROTH (S_IRUSR>>6)
429 #   define S_IWOTH (S_IWUSR>>6)
430 #   define S_IXOTH (S_IXUSR>>6)
431 #endif
432
433 #ifndef S_ISUID
434 #   define S_ISUID 04000
435 #endif
436
437 #ifndef S_ISGID
438 #   define S_ISGID 02000
439 #endif
440
441 #ifdef ff_next
442 #   undef ff_next
443 #endif
444
445 #if defined(cray) || defined(gould) || defined(i860) || defined(pyr)
446 #   define SLOPPYDIVIDE
447 #endif
448
449 #if defined(cray) || defined(convex) || defined (uts) || BYTEORDER > 0xffff
450 #   define HAS_QUAD
451 #endif
452
453 #ifdef HAS_QUAD
454 #   ifdef cray
455 #       define Quad_t int
456 #   else
457 #       if defined(convex) || defined (uts)
458 #           define Quad_t long long
459 #       else
460 #           define Quad_t long
461 #       endif
462 #   endif
463 #endif
464
465 #ifdef VOIDSIG
466 #   define VOIDRET void
467 #else
468 #   define VOIDRET int
469 #endif
470
471 #ifdef DOSISH
472 #   include "dosish.h"
473 #else
474 # if defined(VMS)
475 #   include "vmsish.h"
476 # else
477 #   include "unixish.h"
478 # endif
479 #endif
480
481 #ifndef HAS_PAUSE
482 #define pause() sleep((32767<<16)+32767)
483 #endif
484
485 #ifndef IOCPARM_LEN
486 #   ifdef IOCPARM_MASK
487         /* on BSDish systes we're safe */
488 #       define IOCPARM_LEN(x)  (((x) >> 16) & IOCPARM_MASK)
489 #   else
490         /* otherwise guess at what's safe */
491 #       define IOCPARM_LEN(x)   256
492 #   endif
493 #endif
494
495 typedef MEM_SIZE STRLEN;
496
497 typedef struct op OP;
498 typedef struct cop COP;
499 typedef struct unop UNOP;
500 typedef struct binop BINOP;
501 typedef struct listop LISTOP;
502 typedef struct logop LOGOP;
503 typedef struct condop CONDOP;
504 typedef struct pmop PMOP;
505 typedef struct svop SVOP;
506 typedef struct gvop GVOP;
507 typedef struct pvop PVOP;
508 typedef struct cvop CVOP;
509 typedef struct loop LOOP;
510
511 typedef struct Outrec Outrec;
512 typedef struct lstring Lstring;
513 typedef struct interpreter PerlInterpreter;
514 typedef struct ff FF;
515 typedef struct sv SV;
516 typedef struct av AV;
517 typedef struct hv HV;
518 typedef struct cv CV;
519 typedef struct regexp REGEXP;
520 typedef struct gp GP;
521 typedef struct sv GV;
522 typedef struct io IO;
523 typedef struct context CONTEXT;
524 typedef struct block BLOCK;
525
526 typedef struct magic MAGIC;
527 typedef struct xrv XRV;
528 typedef struct xpv XPV;
529 typedef struct xpviv XPVIV;
530 typedef struct xpvnv XPVNV;
531 typedef struct xpvmg XPVMG;
532 typedef struct xpvlv XPVLV;
533 typedef struct xpvav XPVAV;
534 typedef struct xpvhv XPVHV;
535 typedef struct xpvgv XPVGV;
536 typedef struct xpvcv XPVCV;
537 typedef struct xpvbm XPVBM;
538 typedef struct xpvfm XPVFM;
539 typedef struct xpvio XPVIO;
540 typedef struct mgvtbl MGVTBL;
541 typedef union any ANY;
542
543 typedef FILE * (*cryptswitch_t) _((FILE *rfp));
544
545 #include "handy.h"
546
547 #ifdef HAS_QUAD
548 typedef Quad_t IV;
549 #else
550 typedef long IV;
551 #endif
552
553 union any {
554     void*       any_ptr;
555     I32         any_i32;
556     IV          any_iv;
557     long        any_long;
558     void        (*any_dptr) _((void*));
559 };
560
561 #include "regexp.h"
562 #include "sv.h"
563 #include "util.h"
564 #include "form.h"
565 #include "gv.h"
566 #include "cv.h"
567 #include "opcode.h"
568 #include "op.h"
569 #include "cop.h"
570 #include "av.h"
571 #include "hv.h"
572 #include "mg.h"
573 #include "scope.h"
574
575 #if defined(iAPX286) || defined(M_I286) || defined(I80286)
576 #   define I286
577 #endif
578
579 #if defined(htonl) && !defined(HAS_HTONL)
580 #define HAS_HTONL
581 #endif
582 #if defined(htons) && !defined(HAS_HTONS)
583 #define HAS_HTONS
584 #endif
585 #if defined(ntohl) && !defined(HAS_NTOHL)
586 #define HAS_NTOHL
587 #endif
588 #if defined(ntohs) && !defined(HAS_NTOHS)
589 #define HAS_NTOHS
590 #endif
591 #ifndef HAS_HTONL
592 #if (BYTEORDER & 0xffff) != 0x4321
593 #define HAS_HTONS
594 #define HAS_HTONL
595 #define HAS_NTOHS
596 #define HAS_NTOHL
597 #define MYSWAP
598 #define htons my_swap
599 #define htonl my_htonl
600 #define ntohs my_swap
601 #define ntohl my_ntohl
602 #endif
603 #else
604 #if (BYTEORDER & 0xffff) == 0x4321
605 #undef HAS_HTONS
606 #undef HAS_HTONL
607 #undef HAS_NTOHS
608 #undef HAS_NTOHL
609 #endif
610 #endif
611
612 /*
613  * Little-endian byte order functions - 'v' for 'VAX', or 'reVerse'.
614  * -DWS
615  */
616 #if BYTEORDER != 0x1234
617 # define HAS_VTOHL
618 # define HAS_VTOHS
619 # define HAS_HTOVL
620 # define HAS_HTOVS
621 # if BYTEORDER == 0x4321
622 #  define vtohl(x)      ((((x)&0xFF)<<24)       \
623                         +(((x)>>24)&0xFF)       \
624                         +(((x)&0x0000FF00)<<8)  \
625                         +(((x)&0x00FF0000)>>8)  )
626 #  define vtohs(x)      ((((x)&0xFF)<<8) + (((x)>>8)&0xFF))
627 #  define htovl(x)      vtohl(x)
628 #  define htovs(x)      vtohs(x)
629 # endif
630         /* otherwise default to functions in util.c */
631 #endif
632
633 #ifdef CASTNEGFLOAT
634 #define U_S(what) ((U16)(what))
635 #define U_I(what) ((unsigned int)(what))
636 #define U_L(what) ((U32)(what))
637 #else
638 U32 cast_ulong _((double));
639 #define U_S(what) ((U16)cast_ulong(what))
640 #define U_I(what) ((unsigned int)cast_ulong(what))
641 #define U_L(what) (cast_ulong(what))
642 #endif
643
644 #ifdef CASTI32
645 #define I_32(what) ((I32)(what))
646 #define I_V(what) ((IV)(what))
647 #else
648 I32 cast_i32 _((double));
649 #define I_32(what) (cast_i32(what))
650 IV cast_iv _((double));
651 #define I_V(what) (cast_iv(what))
652 #endif
653
654 struct Outrec {
655     I32         o_lines;
656     char        *o_str;
657     U32         o_len;
658 };
659
660 #ifndef MAXSYSFD
661 #   define MAXSYSFD 2
662 #endif
663
664 #ifdef DOSISH
665 #define TMPPATH "plXXXXXX"
666 #else
667 #ifdef VMS
668 #define TMPPATH "/sys$scratch/perl-eXXXXXX"
669 #else
670 #define TMPPATH "/tmp/perl-eXXXXXX"
671 #endif
672 #endif
673
674 #ifndef __cplusplus
675 Uid_t getuid _((void));
676 Uid_t geteuid _((void));
677 Gid_t getgid _((void));
678 Gid_t getegid _((void));
679 #endif
680
681 #ifdef DEBUGGING
682 #define YYDEBUG 1
683 #define DEB(a)                          a
684 #define DEBUG(a)   if (debug)           a
685 #define DEBUG_p(a) if (debug & 1)       a
686 #define DEBUG_s(a) if (debug & 2)       a
687 #define DEBUG_l(a) if (debug & 4)       a
688 #define DEBUG_t(a) if (debug & 8)       a
689 #define DEBUG_o(a) if (debug & 16)      a
690 #define DEBUG_c(a) if (debug & 32)      a
691 #define DEBUG_P(a) if (debug & 64)      a
692 #define DEBUG_m(a) if (debug & 128)     a
693 #define DEBUG_f(a) if (debug & 256)     a
694 #define DEBUG_r(a) if (debug & 512)     a
695 #define DEBUG_x(a) if (debug & 1024)    a
696 #define DEBUG_u(a) if (debug & 2048)    a
697 #define DEBUG_L(a) if (debug & 4096)    a
698 #define DEBUG_H(a) if (debug & 8192)    a
699 #define DEBUG_X(a) if (debug & 16384)   a
700 #define DEBUG_D(a) if (debug & 32768)   a
701 #else
702 #define DEB(a)
703 #define DEBUG(a)
704 #define DEBUG_p(a)
705 #define DEBUG_s(a)
706 #define DEBUG_l(a)
707 #define DEBUG_t(a)
708 #define DEBUG_o(a)
709 #define DEBUG_c(a)
710 #define DEBUG_P(a)
711 #define DEBUG_m(a)
712 #define DEBUG_f(a)
713 #define DEBUG_r(a)
714 #define DEBUG_x(a)
715 #define DEBUG_u(a)
716 #define DEBUG_L(a)
717 #define DEBUG_H(a)
718 #define DEBUG_X(a)
719 #define DEBUG_D(a)
720 #endif
721 #define YYMAXDEPTH 300
722
723 #define assert(what)    DEB( {                                          \
724         if (!(what)) {                                                  \
725             croak("Assertion failed: file \"%s\", line %d",             \
726                 __FILE__, __LINE__);                                    \
727             exit(1);                                                    \
728         }})
729
730 struct ufuncs {
731     I32 (*uf_val)_((IV, SV*));
732     I32 (*uf_set)_((IV, SV*));
733     IV uf_index;
734 };
735
736 /* Fix these up for __STDC__ */
737 #ifndef __cplusplus
738 char *mktemp _((char*));
739 double atof _((const char*));
740 #endif
741
742 #ifndef STANDARD_C
743 /* All of these are in stdlib.h or time.h for ANSI C */
744 Time_t time();
745 struct tm *gmtime(), *localtime();
746 char *strchr(), *strrchr();
747 char *strcpy(), *strcat();
748 #endif /* ! STANDARD_C */
749
750
751 #ifdef I_MATH
752 #    include <math.h>
753 #else
754 #   ifdef __cplusplus
755         extern "C" {
756 #   endif
757             double exp _((double));
758             double fmod _((double,double));
759             double log _((double));
760             double sqrt _((double));
761             double modf _((double,double*));
762             double sin _((double));
763             double cos _((double));
764             double atan2 _((double,double));
765             double pow _((double,double));
766 #   ifdef __cplusplus
767         };
768 #   endif
769 #endif
770
771 #ifndef HAS_FMOD
772 #   ifdef HAS_DREM
773 #       define fmod(x,y) drem((x),(y))
774 #   else
775 #       define USE_MY_FMOD
776 #       define fmod(x,y) my_fmod(x,y)
777 #   endif
778 #endif
779
780 #ifndef __cplusplus
781 char *crypt _((const char*, const char*));
782 char *getenv _((const char*));
783 Off_t lseek _((int,Off_t,int));
784 char *getlogin _((void));
785 #endif
786
787 #ifdef EUNICE
788 #define UNLINK unlnk
789 I32 unlnk _((char*));
790 #else
791 #define UNLINK unlink
792 #endif
793
794 #ifndef HAS_SETREUID
795 #  ifdef HAS_SETRESUID
796 #    define setreuid(r,e) setresuid(r,e,(Uid_t)-1)
797 #    define HAS_SETREUID
798 #  endif
799 #endif
800 #ifndef HAS_SETREGID
801 #  ifdef HAS_SETRESGID
802 #    define setregid(r,e) setresgid(r,e,(Gid_t)-1)
803 #    define HAS_SETREGID
804 #  endif
805 #endif
806
807 #define SCAN_DEF 0
808 #define SCAN_TR 1
809 #define SCAN_REPL 2
810
811 #ifdef DEBUGGING
812 # ifndef register 
813 #  define register
814 # endif
815 # define PAD_SV(po) pad_sv(po)
816 #else
817 # define PAD_SV(po) curpad[po]
818 #endif
819
820 /****************/
821 /* Truly global */
822 /****************/
823
824 /* global state */
825 EXT PerlInterpreter *   curinterp;      /* currently running interpreter */
826 #ifndef VMS  /* VMS doesn't use environ array */
827 extern char **  environ;        /* environment variables supplied via exec */
828 #endif
829 EXT int         uid;            /* current real user id */
830 EXT int         euid;           /* current effective user id */
831 EXT int         gid;            /* current real group id */
832 EXT int         egid;           /* current effective group id */
833 EXT bool        nomemok;        /* let malloc context handle nomem */
834 EXT U32         an;             /* malloc sequence number */
835 EXT U32         cop_seqmax;     /* statement sequence number */
836 EXT U32         op_seqmax;      /* op sequence number */
837 EXT U32         evalseq;        /* eval sequence number */
838 EXT U32         sub_generation; /* inc to force methods to be looked up again */
839 EXT char **     origenviron;
840 EXT U32         origalen;
841 EXT U32 *       profiledata;
842
843 EXT XPV*        xiv_arenaroot;  /* list of allocated xiv areas */
844 EXT IV **       xiv_root;       /* free xiv list--shared by interpreters */
845 EXT double *    xnv_root;       /* free xnv list--shared by interpreters */
846 EXT XRV *       xrv_root;       /* free xrv list--shared by interpreters */
847 EXT XPV *       xpv_root;       /* free xpv list--shared by interpreters */
848
849 /* Stack for currently executing thread--context switch must handle this.     */
850 EXT SV **       stack_base;     /* stack->array_ary */
851 EXT SV **       stack_sp;       /* stack pointer now */
852 EXT SV **       stack_max;      /* stack->array_ary + stack->array_max */
853
854 /* likewise for these */
855
856 EXT OP *        op;             /* current op--oughta be in a global register */
857
858 EXT I32 *       scopestack;     /* blocks we've entered */
859 EXT I32         scopestack_ix;
860 EXT I32         scopestack_max;
861
862 EXT ANY*        savestack;      /* to save non-local values on */
863 EXT I32         savestack_ix;
864 EXT I32         savestack_max;
865
866 EXT OP **       retstack;       /* returns we've pushed */
867 EXT I32         retstack_ix;
868 EXT I32         retstack_max;
869
870 EXT I32 *       markstack;      /* stackmarks we're remembering */
871 EXT I32 *       markstack_ptr;  /* stackmarks we're remembering */
872 EXT I32 *       markstack_max;  /* stackmarks we're remembering */
873
874 EXT SV **       curpad;
875
876 /* temp space */
877 EXT SV *        Sv;
878 EXT XPV *       Xpv;
879 EXT char        buf[1024];
880 EXT char        tokenbuf[256];
881 EXT struct stat statbuf;
882 #ifdef HAS_TIMES
883 EXT struct tms  timesbuf;
884 #endif
885 EXT STRLEN na;          /* for use in SvPV when length is Not Applicable */
886
887 /* for tmp use in stupid debuggers */
888 EXT int *       di;
889 EXT short *     ds;
890 EXT char *      dc;
891
892 /* handy constants */
893 EXT char *      Yes INIT("1");
894 EXT char *      No INIT("");
895 EXT char *      hexdigit INIT("0123456789abcdef0123456789ABCDEFx");
896 EXT char *      patleave INIT("\\.^$@dDwWsSbB+*?|()-nrtfeaxc0123456789[{]}");
897 EXT char *      vert INIT("|");
898
899 EXT char        warn_uninit[]
900   INIT("Use of uninitialized value");
901 EXT char        warn_nosemi[]
902   INIT("Semicolon seems to be missing");
903 EXT char        warn_reserved[]
904   INIT("Unquoted string \"%s\" may clash with future reserved word");
905 EXT char        warn_nl[]
906   INIT("Unsuccessful %s on filename containing newline");
907 EXT char        no_wrongref[]
908   INIT("Can't use %s ref as %s ref");
909 EXT char        no_symref[]
910   INIT("Can't use a string as %s ref while \"strict refs\" in use");
911 EXT char        no_usym[]
912   INIT("Can't use an undefined value as %s reference");
913 EXT char        no_aelem[]
914   INIT("Modification of non-creatable array value attempted, subscript %d");
915 EXT char        no_helem[]
916   INIT("Modification of non-creatable hash value attempted, subscript \"%s\"");
917 EXT char        no_modify[]
918   INIT("Modification of a read-only value attempted");
919 EXT char        no_mem[]
920   INIT("Out of memory!\n");
921 EXT char        no_security[]
922   INIT("Insecure dependency in %s%s");
923 EXT char        no_sock_func[]
924   INIT("Unsupported socket function \"%s\" called");
925 EXT char        no_dir_func[]
926   INIT("Unsupported directory function \"%s\" called");
927 EXT char        no_func[]
928   INIT("The %s function is unimplemented");
929
930 EXT SV          sv_undef;
931 EXT SV          sv_no;
932 EXT SV          sv_yes;
933 #ifdef CSH
934     EXT char *  cshname INIT(CSH);
935     EXT I32     cshlen;
936 #endif
937
938 #ifdef DOINIT
939 EXT char *sig_name[] = {
940     SIG_NAME,0
941 };
942 #else
943 EXT char *sig_name[];
944 #endif
945
946 #ifdef DOINIT
947 EXT unsigned char fold[] = {    /* fast case folding table */
948         0,      1,      2,      3,      4,      5,      6,      7,
949         8,      9,      10,     11,     12,     13,     14,     15,
950         16,     17,     18,     19,     20,     21,     22,     23,
951         24,     25,     26,     27,     28,     29,     30,     31,
952         32,     33,     34,     35,     36,     37,     38,     39,
953         40,     41,     42,     43,     44,     45,     46,     47,
954         48,     49,     50,     51,     52,     53,     54,     55,
955         56,     57,     58,     59,     60,     61,     62,     63,
956         64,     'a',    'b',    'c',    'd',    'e',    'f',    'g',
957         'h',    'i',    'j',    'k',    'l',    'm',    'n',    'o',
958         'p',    'q',    'r',    's',    't',    'u',    'v',    'w',
959         'x',    'y',    'z',    91,     92,     93,     94,     95,
960         96,     'A',    'B',    'C',    'D',    'E',    'F',    'G',
961         'H',    'I',    'J',    'K',    'L',    'M',    'N',    'O',
962         'P',    'Q',    'R',    'S',    'T',    'U',    'V',    'W',
963         'X',    'Y',    'Z',    123,    124,    125,    126,    127,
964         128,    129,    130,    131,    132,    133,    134,    135,
965         136,    137,    138,    139,    140,    141,    142,    143,
966         144,    145,    146,    147,    148,    149,    150,    151,
967         152,    153,    154,    155,    156,    157,    158,    159,
968         160,    161,    162,    163,    164,    165,    166,    167,
969         168,    169,    170,    171,    172,    173,    174,    175,
970         176,    177,    178,    179,    180,    181,    182,    183,
971         184,    185,    186,    187,    188,    189,    190,    191,
972         192,    193,    194,    195,    196,    197,    198,    199,
973         200,    201,    202,    203,    204,    205,    206,    207,
974         208,    209,    210,    211,    212,    213,    214,    215,
975         216,    217,    218,    219,    220,    221,    222,    223,    
976         224,    225,    226,    227,    228,    229,    230,    231,
977         232,    233,    234,    235,    236,    237,    238,    239,
978         240,    241,    242,    243,    244,    245,    246,    247,
979         248,    249,    250,    251,    252,    253,    254,    255
980 };
981 #else
982 EXT unsigned char fold[];
983 #endif
984
985 #ifdef DOINIT
986 EXT unsigned char freq[] = {    /* letter frequencies for mixed English/C */
987         1,      2,      84,     151,    154,    155,    156,    157,
988         165,    246,    250,    3,      158,    7,      18,     29,
989         40,     51,     62,     73,     85,     96,     107,    118,
990         129,    140,    147,    148,    149,    150,    152,    153,
991         255,    182,    224,    205,    174,    176,    180,    217,
992         233,    232,    236,    187,    235,    228,    234,    226,
993         222,    219,    211,    195,    188,    193,    185,    184,
994         191,    183,    201,    229,    181,    220,    194,    162,
995         163,    208,    186,    202,    200,    218,    198,    179,
996         178,    214,    166,    170,    207,    199,    209,    206,
997         204,    160,    212,    216,    215,    192,    175,    173,
998         243,    172,    161,    190,    203,    189,    164,    230,
999         167,    248,    227,    244,    242,    255,    241,    231,
1000         240,    253,    169,    210,    245,    237,    249,    247,
1001         239,    168,    252,    251,    254,    238,    223,    221,
1002         213,    225,    177,    197,    171,    196,    159,    4,
1003         5,      6,      8,      9,      10,     11,     12,     13,
1004         14,     15,     16,     17,     19,     20,     21,     22,
1005         23,     24,     25,     26,     27,     28,     30,     31,
1006         32,     33,     34,     35,     36,     37,     38,     39,
1007         41,     42,     43,     44,     45,     46,     47,     48,
1008         49,     50,     52,     53,     54,     55,     56,     57,
1009         58,     59,     60,     61,     63,     64,     65,     66,
1010         67,     68,     69,     70,     71,     72,     74,     75,
1011         76,     77,     78,     79,     80,     81,     82,     83,
1012         86,     87,     88,     89,     90,     91,     92,     93,
1013         94,     95,     97,     98,     99,     100,    101,    102,
1014         103,    104,    105,    106,    108,    109,    110,    111,
1015         112,    113,    114,    115,    116,    117,    119,    120,
1016         121,    122,    123,    124,    125,    126,    127,    128,
1017         130,    131,    132,    133,    134,    135,    136,    137,
1018         138,    139,    141,    142,    143,    144,    145,    146
1019 };
1020 #else
1021 EXT unsigned char freq[];
1022 #endif
1023
1024 #ifdef DEBUGGING
1025 #ifdef DOINIT
1026 EXT char* block_type[] = {
1027         "NULL",
1028         "SUB",
1029         "EVAL",
1030         "LOOP",
1031         "SUBST",
1032         "BLOCK",
1033 };
1034 #else
1035 EXT char* block_type[];
1036 #endif
1037 #endif
1038
1039 /*****************************************************************************/
1040 /* This lexer/parser stuff is currently global since yacc is hard to reenter */
1041 /*****************************************************************************/
1042 /* XXX This needs to be revisited, since BEGIN makes yacc re-enter... */
1043
1044 #include "perly.h"
1045
1046 typedef enum {
1047     XOPERATOR,
1048     XTERM,
1049     XREF,
1050     XSTATE,
1051     XBLOCK,
1052     XTERMBLOCK
1053 } expectation;
1054
1055 EXT U32         lex_state;      /* next token is determined */
1056 EXT U32         lex_defer;      /* state after determined token */
1057 EXT expectation lex_expect;     /* expect after determined token */
1058 EXT I32         lex_brackets;   /* bracket count */
1059 EXT I32         lex_formbrack;  /* bracket count at outer format level */
1060 EXT I32         lex_fakebrack;  /* outer bracket is mere delimiter */
1061 EXT I32         lex_casemods;   /* casemod count */
1062 EXT I32         lex_dojoin;     /* doing an array interpolation */
1063 EXT I32         lex_starts;     /* how many interps done on level */
1064 EXT SV *        lex_stuff;      /* runtime pattern from m// or s/// */
1065 EXT SV *        lex_repl;       /* runtime replacement from s/// */
1066 EXT OP *        lex_op;         /* extra info to pass back on op */
1067 EXT OP *        lex_inpat;      /* in pattern $) and $| are special */
1068 EXT I32         lex_inwhat;     /* what kind of quoting are we in */
1069 EXT char *      lex_brackstack; /* what kind of brackets to pop */
1070 EXT char *      lex_casestack;  /* what kind of case mods in effect */
1071
1072 /* What we know when we're in LEX_KNOWNEXT state. */
1073 EXT YYSTYPE     nextval[5];     /* value of next token, if any */
1074 EXT I32         nexttype[5];    /* type of next token */
1075 EXT I32         nexttoke;
1076
1077 EXT FILE * VOL  rsfp INIT(Nullfp);
1078 EXT SV *        linestr;
1079 EXT char *      bufptr;
1080 EXT char *      oldbufptr;
1081 EXT char *      oldoldbufptr;
1082 EXT char *      bufend;
1083 EXT expectation expect INIT(XSTATE);    /* how to interpret ambiguous tokens */
1084 EXT char *      autoboot_preamble INIT(Nullch);
1085
1086 EXT I32         multi_start;    /* 1st line of multi-line string */
1087 EXT I32         multi_end;      /* last line of multi-line string */
1088 EXT I32         multi_open;     /* delimiter of said string */
1089 EXT I32         multi_close;    /* delimiter of said string */
1090
1091 EXT GV *        scrgv;
1092 EXT I32         error_count;    /* how many errors so far, max 10 */
1093 EXT I32         subline;        /* line this subroutine began on */
1094 EXT SV *        subname;        /* name of current subroutine */
1095
1096 EXT AV *        comppad;        /* storage for lexically scoped temporaries */
1097 EXT AV *        comppad_name;   /* variable names for "my" variables */
1098 EXT I32         comppad_name_fill;/* last "introduced" variable offset */
1099 EXT I32         min_intro_pending;/* start of vars to introduce */
1100 EXT I32         max_intro_pending;/* end of vars to introduce */
1101 EXT I32         padix;          /* max used index in current "register" pad */
1102 EXT I32         padix_floor;    /* how low may inner block reset padix */
1103 EXT bool        pad_reset_pending; /* reset pad on next attempted alloc */
1104 EXT COP         compiling;
1105
1106 EXT I32         thisexpr;       /* name id for nothing_in_common() */
1107 EXT char *      last_uni;       /* position of last named-unary operator */
1108 EXT char *      last_lop;       /* position of last list operator */
1109 EXT OPCODE      last_lop_op;    /* last list operator */
1110 EXT bool        in_my;          /* we're compiling a "my" declaration */
1111 #ifdef FCRYPT
1112 EXT I32         cryptseen;      /* has fast crypt() been initialized? */
1113 #endif
1114
1115 EXT U32         hints;          /* various compilation flags */
1116
1117                                 /* Note: the lowest 8 bits are reserved for
1118                                    stuffing into op->op_private */
1119 #define HINT_INTEGER            0x00000001
1120 #define HINT_STRICT_REFS        0x00000002
1121
1122 #define HINT_BLOCK_SCOPE        0x00000100
1123 #define HINT_STRICT_SUBS        0x00000200
1124 #define HINT_STRICT_VARS        0x00000400
1125
1126 /**************************************************************************/
1127 /* This regexp stuff is global since it always happens within 1 expr eval */
1128 /**************************************************************************/
1129
1130 EXT char *      regprecomp;     /* uncompiled string. */
1131 EXT char *      regparse;       /* Input-scan pointer. */
1132 EXT char *      regxend;        /* End of input for compile */
1133 EXT I32         regnpar;        /* () count. */
1134 EXT char *      regcode;        /* Code-emit pointer; &regdummy = don't. */
1135 EXT I32         regsize;        /* Code size. */
1136 EXT I32         regnaughty;     /* How bad is this pattern? */
1137 EXT I32         regsawback;     /* Did we see \1, ...? */
1138
1139 EXT char *      reginput;       /* String-input pointer. */
1140 EXT char *      regbol;         /* Beginning of input, for ^ check. */
1141 EXT char *      regeol;         /* End of input, for $ check. */
1142 EXT char **     regstartp;      /* Pointer to startp array. */
1143 EXT char **     regendp;        /* Ditto for endp. */
1144 EXT U32 *       reglastparen;   /* Similarly for lastparen. */
1145 EXT char *      regtill;        /* How far we are required to go. */
1146 EXT U16         regflags;       /* are we folding, multilining? */
1147 EXT char        regprev;        /* char before regbol, \n if none */
1148
1149 /***********************************************/
1150 /* Global only to current interpreter instance */
1151 /***********************************************/
1152
1153 #ifdef MULTIPLICITY
1154 #define IEXT
1155 #define IINIT(x)
1156 struct interpreter {
1157 #else
1158 #define IEXT EXT
1159 #define IINIT(x) INIT(x)
1160 #endif
1161
1162 /* pseudo environmental stuff */
1163 IEXT int        Iorigargc;
1164 IEXT char **    Iorigargv;
1165 IEXT GV *       Ienvgv;
1166 IEXT GV *       Isiggv;
1167 IEXT GV *       Iincgv;
1168 IEXT char *     Iorigfilename;
1169
1170 /* switches */
1171 IEXT char *     Icddir;
1172 IEXT bool       Iminus_c;
1173 IEXT char       Ipatchlevel[6];
1174 IEXT char *     Inrs IINIT("\n");
1175 IEXT U32        Inrschar IINIT('\n');   /* final char of rs, or 0777 if none */
1176 IEXT I32        Inrslen IINIT(1);
1177 IEXT char *     Isplitstr IINIT(" ");
1178 IEXT bool       Ipreprocess;
1179 IEXT bool       Iminus_n;
1180 IEXT bool       Iminus_p;
1181 IEXT bool       Iminus_l;
1182 IEXT bool       Iminus_a;
1183 IEXT bool       Iminus_F;
1184 IEXT bool       Idoswitches;
1185 IEXT bool       Idowarn;
1186 IEXT bool       Idoextract;
1187 IEXT bool       Isawampersand;  /* must save all match strings */
1188 IEXT bool       Isawstudy;      /* do fbm_instr on all strings */
1189 IEXT bool       Isawi;          /* study must assume case insensitive */
1190 IEXT bool       Isawvec;
1191 IEXT bool       Iunsafe;
1192 IEXT bool       Ido_undump;             /* -u or dump seen? */
1193 IEXT char *     Iinplace;
1194 IEXT char *     Ie_tmpname;
1195 IEXT FILE *     Ie_fp;
1196 IEXT VOL U32    Idebug;
1197 IEXT U32        Iperldb;
1198
1199 /* magical thingies */
1200 IEXT Time_t     Ibasetime;              /* $^T */
1201 IEXT SV *       Iformfeed;              /* $^L */
1202 IEXT char *     Ichopset IINIT(" \n-"); /* $: */
1203 IEXT char *     Irs IINIT("\n");        /* $/ */
1204 IEXT U32        Irschar IINIT('\n');    /* final char of rs, or 0777 if none */
1205 IEXT STRLEN     Irslen IINIT(1);
1206 IEXT bool       Irspara;
1207 IEXT char *     Iofs;                   /* $, */
1208 IEXT STRLEN     Iofslen;
1209 IEXT char *     Iors;                   /* $\ */
1210 IEXT STRLEN     Iorslen;
1211 IEXT char *     Iofmt;                  /* $# */
1212 IEXT I32        Imaxsysfd IINIT(MAXSYSFD); /* top fd to pass to subprocesses */
1213 IEXT int        Imultiline;       /* $*--do strings hold >1 line? */
1214 IEXT U16        Istatusvalue;   /* $? */
1215
1216 IEXT struct stat Istatcache;            /* _ */
1217 IEXT GV *       Istatgv;
1218 IEXT SV *       Istatname IINIT(Nullsv);
1219
1220 /* shortcuts to various I/O objects */
1221 IEXT GV *       Istdingv;
1222 IEXT GV *       Ilast_in_gv;
1223 IEXT GV *       Idefgv;
1224 IEXT GV *       Iargvgv;
1225 IEXT GV *       Idefoutgv;
1226 IEXT GV *       Iargvoutgv;
1227
1228 /* shortcuts to regexp stuff */
1229 IEXT GV *       Ileftgv;
1230 IEXT GV *       Iampergv;
1231 IEXT GV *       Irightgv;
1232 IEXT PMOP *     Icurpm;         /* what to do \ interps from */
1233 IEXT I32 *      Iscreamfirst;
1234 IEXT I32 *      Iscreamnext;
1235 IEXT I32        Imaxscream IINIT(-1);
1236 IEXT SV *       Ilastscream;
1237
1238 /* shortcuts to debugging objects */
1239 IEXT GV *       IDBgv;
1240 IEXT GV *       IDBline;
1241 IEXT GV *       IDBsub;
1242 IEXT SV *       IDBsingle;
1243 IEXT SV *       IDBtrace;
1244 IEXT SV *       IDBsignal;
1245 IEXT AV *       Ilineary;       /* lines of script for debugger */
1246 IEXT AV *       Idbargs;        /* args to call listed by caller function */
1247
1248 /* symbol tables */
1249 IEXT HV *       Idefstash;      /* main symbol table */
1250 IEXT HV *       Icurstash;      /* symbol table for current package */
1251 IEXT HV *       Idebstash;      /* symbol table for perldb package */
1252 IEXT SV *       Icurstname;     /* name of current package */
1253 IEXT AV *       Ibeginav;       /* names of BEGIN subroutines */
1254 IEXT AV *       Iendav;         /* names of END subroutines */
1255 IEXT AV *       Ipad;           /* storage for lexically scoped temporaries */
1256 IEXT AV *       Ipadname;       /* variable names for "my" variables */
1257
1258 /* memory management */
1259 IEXT SV **      Itmps_stack;
1260 IEXT I32        Itmps_ix IINIT(-1);
1261 IEXT I32        Itmps_floor IINIT(-1);
1262 IEXT I32        Itmps_max;
1263 IEXT I32        Isv_count;      /* how many SV* are currently allocated */
1264 IEXT I32        Isv_objcount;   /* how many objects are currently allocated */
1265 IEXT SV*        Isv_root;       /* storage for SVs belonging to interp */
1266 IEXT SV*        Isv_arenaroot;  /* list of areas for garbage collection */
1267
1268 /* funky return mechanisms */
1269 IEXT I32        Ilastspbase;
1270 IEXT I32        Ilastsize;
1271 IEXT int        Iforkprocess;   /* so do_open |- can return proc# */
1272
1273 /* subprocess state */
1274 IEXT AV *       Ifdpid;         /* keep fd-to-pid mappings for my_popen */
1275 IEXT HV *       Ipidstatus;     /* keep pid-to-status mappings for waitpid */
1276
1277 /* internal state */
1278 IEXT VOL int    Iin_eval;       /* trap "fatal" errors? */
1279 IEXT OP *       Irestartop;     /* Are we propagating an error from croak? */
1280 IEXT int        Idelaymagic;    /* ($<,$>) = ... */
1281 IEXT bool       Idirty;         /* In the middle of tearing things down? */
1282 IEXT bool       Ilocalizing;    /* are we processing a local() list? */
1283 IEXT bool       Itainted;       /* using variables controlled by $< */
1284 IEXT bool       Itainting;      /* doing taint checks */
1285
1286 /* trace state */
1287 IEXT I32        Idlevel;
1288 IEXT I32        Idlmax IINIT(128);
1289 IEXT char *     Idebname;
1290 IEXT char *     Idebdelim;
1291
1292 /* current interpreter roots */
1293 IEXT OP *       Imain_root;
1294 IEXT OP *       Imain_start;
1295 IEXT OP *       Ieval_root;
1296 IEXT OP *       Ieval_start;
1297
1298 /* runtime control stuff */
1299 IEXT COP * VOL  Icurcop IINIT(&compiling);
1300 IEXT line_t     Icopline IINIT(NOLINE);
1301 IEXT CONTEXT *  Icxstack;
1302 IEXT I32        Icxstack_ix IINIT(-1);
1303 IEXT I32        Icxstack_max IINIT(128);
1304 IEXT jmp_buf    Itop_env;
1305 IEXT I32        Irunlevel;
1306
1307 /* stack stuff */
1308 IEXT AV *       Istack;         /* THE STACK */
1309 IEXT AV *       Imainstack;     /* the stack when nothing funny is happening */
1310 IEXT SV **      Imystack_base;  /* stack->array_ary */
1311 IEXT SV **      Imystack_sp;    /* stack pointer now */
1312 IEXT SV **      Imystack_max;   /* stack->array_ary + stack->array_max */
1313
1314 /* format accumulators */
1315 IEXT SV *       Iformtarget;
1316 IEXT SV *       Ibodytarget;
1317 IEXT SV *       Itoptarget;
1318
1319 /* statics moved here for shared library purposes */
1320 IEXT SV         Istrchop;       /* return value from chop */
1321 IEXT int        Ifilemode;      /* so nextargv() can preserve mode */
1322 IEXT int        Ilastfd;        /* what to preserve mode on */
1323 IEXT char *     Ioldname;       /* what to preserve mode on */
1324 IEXT char **    IArgv;          /* stuff to free from do_aexec, vfork safe */
1325 IEXT char *     ICmd;           /* stuff to free from do_aexec, vfork safe */
1326 IEXT OP *       Isortcop;       /* user defined sort routine */
1327 IEXT HV *       Isortstash;     /* which is in some package or other */
1328 IEXT GV *       Ifirstgv;       /* $a */
1329 IEXT GV *       Isecondgv;      /* $b */
1330 IEXT AV *       Isortstack;     /* temp stack during pp_sort() */
1331 IEXT AV *       Isignalstack;   /* temp stack during sighandler() */
1332 IEXT SV *       Imystrk;        /* temp key string for do_each() */
1333 IEXT I32        Idumplvl;       /* indentation level on syntax tree dump */
1334 IEXT PMOP *     Ioldlastpm;     /* for saving regexp context during debugger */
1335 IEXT I32        Igensym;        /* next symbol for getsym() to define */
1336 IEXT bool       Ipreambled;
1337 IEXT int        Ilaststatval IINIT(-1);
1338 IEXT I32        Ilaststype IINIT(OP_STAT);
1339
1340 #undef IEXT
1341 #undef IINIT
1342
1343 #ifdef MULTIPLICITY
1344 };
1345 #else
1346 struct interpreter {
1347     char broiled;
1348 };
1349 #endif
1350
1351 #include "pp.h"
1352
1353 #ifdef __cplusplus
1354 extern "C" {
1355 #endif
1356
1357 #ifdef __cplusplus
1358 #  ifndef I_STDARG
1359 #    define I_STDARG 1
1360 #  endif
1361 #endif
1362
1363 #ifdef I_STDARG
1364 #  include <stdarg.h>
1365 #else
1366 #  ifdef I_VARARGS
1367 #    include <varargs.h>
1368 #  endif
1369 #endif
1370
1371 #include "proto.h"
1372
1373 #ifdef EMBED
1374 #define Perl_sv_setptrobj(rv,ptr,name) Perl_sv_setref_iv(rv,name,(IV)ptr)
1375 #define Perl_sv_setptrref(rv,ptr) Perl_sv_setref_iv(rv,Nullch,(IV)ptr)
1376 #else
1377 #define sv_setptrobj(rv,ptr,name) sv_setref_iv(rv,name,(IV)ptr)
1378 #define sv_setptrref(rv,ptr) sv_setref_iv(rv,Nullch,(IV)ptr)
1379 #endif
1380
1381 #ifdef __cplusplus
1382 };
1383 #endif
1384
1385 /* The following must follow proto.h */
1386
1387 #ifdef DOINIT
1388 MGVTBL vtbl_sv =        {magic_get,
1389                                 magic_set,
1390                                         magic_len,
1391                                                 0,      0};
1392 MGVTBL vtbl_env =       {0,     0,      0,      0,      0};
1393 MGVTBL vtbl_envelem =   {0,     magic_setenv,
1394                                         0,      magic_clearenv,
1395                                                         0};
1396 MGVTBL vtbl_sig =       {0,     0,               0, 0, 0};
1397 MGVTBL vtbl_sigelem =   {0,     magic_setsig,
1398                                         0,      0,      0};
1399 MGVTBL vtbl_pack =      {0,     0,      0,      magic_wipepack,
1400                                                         0};
1401 MGVTBL vtbl_packelem =  {magic_getpack,
1402                                 magic_setpack,
1403                                         0,      magic_clearpack,
1404                                                         0};
1405 MGVTBL vtbl_dbline =    {0,     magic_setdbline,
1406                                         0,      0,      0};
1407 MGVTBL vtbl_isa =       {0,     magic_setisa,
1408                                         0,      0,      0};
1409 MGVTBL vtbl_isaelem =   {0,     magic_setisa,
1410                                         0,      0,      0};
1411 MGVTBL vtbl_arylen =    {magic_getarylen,
1412                                 magic_setarylen,
1413                                         0,      0,      0};
1414 MGVTBL vtbl_glob =      {magic_getglob,
1415                                 magic_setglob,
1416                                         0,      0,      0};
1417 MGVTBL vtbl_mglob =     {0,     magic_setmglob,
1418                                         0,      0,      0};
1419 MGVTBL vtbl_taint =     {magic_gettaint,magic_settaint,
1420                                         0,      0,      0};
1421 MGVTBL vtbl_substr =    {0,     magic_setsubstr,
1422                                         0,      0,      0};
1423 MGVTBL vtbl_vec =       {0,     magic_setvec,
1424                                         0,      0,      0};
1425 MGVTBL vtbl_pos =       {magic_getpos,
1426                                 magic_setpos,
1427                                         0,      0,      0};
1428 MGVTBL vtbl_bm =        {0,     magic_setbm,
1429                                         0,      0,      0};
1430 MGVTBL vtbl_uvar =      {magic_getuvar,
1431                                 magic_setuvar,
1432                                         0,      0,      0};
1433
1434 #ifdef OVERLOAD
1435 MGVTBL vtbl_amagic =       {0,     magic_setamagic,
1436                                         0,      0,      0};
1437 MGVTBL vtbl_amagicelem =   {0,     magic_setamagic,
1438                                         0,      0,      0};
1439 #endif /* OVERLOAD */
1440
1441 #else
1442 EXT MGVTBL vtbl_sv;
1443 EXT MGVTBL vtbl_env;
1444 EXT MGVTBL vtbl_envelem;
1445 EXT MGVTBL vtbl_sig;
1446 EXT MGVTBL vtbl_sigelem;
1447 EXT MGVTBL vtbl_pack;
1448 EXT MGVTBL vtbl_packelem;
1449 EXT MGVTBL vtbl_dbline;
1450 EXT MGVTBL vtbl_isa;
1451 EXT MGVTBL vtbl_isaelem;
1452 EXT MGVTBL vtbl_arylen;
1453 EXT MGVTBL vtbl_glob;
1454 EXT MGVTBL vtbl_mglob;
1455 EXT MGVTBL vtbl_taint;
1456 EXT MGVTBL vtbl_substr;
1457 EXT MGVTBL vtbl_vec;
1458 EXT MGVTBL vtbl_pos;
1459 EXT MGVTBL vtbl_bm;
1460 EXT MGVTBL vtbl_uvar;
1461
1462 #ifdef OVERLOAD
1463 EXT MGVTBL vtbl_amagic;
1464 EXT MGVTBL vtbl_amagicelem;
1465 #endif /* OVERLOAD */
1466
1467 #endif
1468
1469 #ifdef OVERLOAD
1470 EXT long amagic_generation;
1471
1472 #define NofAMmeth 27
1473 #ifdef DOINIT
1474 EXT char * AMG_names[NofAMmeth][2] = {
1475   {"fallback","abs"},
1476   {"bool", "nomethod"},
1477   {"\"\"", "0+"},
1478   {"+","+="},
1479   {"-","-="},
1480   {"*", "*="},
1481   {"/", "/="},
1482   {"%", "%="},
1483   {"**", "**="},
1484   {"<<", "<<="},
1485   {">>", ">>="},
1486   {"<", "<="},
1487   {">", ">="},
1488   {"==", "!="},
1489   {"<=>", "cmp"},
1490   {"lt", "le"},
1491   {"gt", "ge"},
1492   {"eq", "ne"},
1493   {"&", "^"},
1494   {"|", "neg"},
1495   {"!", "~"},
1496   {"++", "--"},
1497   {"atan2", "cos"},
1498   {"sin", "exp"},
1499   {"log", "sqrt"},
1500   {"x","x="},
1501   {".",".="}
1502 };
1503 #else
1504 EXT char * AMG_names[NofAMmeth][2];
1505 #endif /* def INITAMAGIC */
1506
1507 struct  am_table        {
1508   long was_ok_sub;
1509   long was_ok_am;
1510   CV* table[NofAMmeth*2];
1511   long fallback;
1512 };
1513 typedef struct am_table AMT;
1514
1515 #define AMGfallNEVER    1
1516 #define AMGfallNO       2
1517 #define AMGfallYES      3
1518
1519 enum {
1520   fallback_amg, abs_amg,
1521   bool__amg,    nomethod_amg,
1522   string_amg,   numer_amg,
1523   add_amg,      add_ass_amg,
1524   subtr_amg,    subtr_ass_amg,
1525   mult_amg,     mult_ass_amg,
1526   div_amg,      div_ass_amg,
1527   mod_amg,      mod_ass_amg,
1528   pow_amg,      pow_ass_amg,
1529   lshift_amg,   lshift_ass_amg,
1530   rshift_amg,   rshift_ass_amg,
1531   lt_amg,       le_amg,
1532   gt_amg,       ge_amg,
1533   eq_amg,       ne_amg,
1534   ncmp_amg,     scmp_amg,
1535   slt_amg,      sle_amg,
1536   sgt_amg,      sge_amg,
1537   seq_amg,      sne_amg,
1538   band_amg,     bxor_amg,
1539   bor_amg,      neg_amg,
1540   not_amg,      compl_amg,
1541   inc_amg,      dec_amg,
1542   atan2_amg,    cos_amg,
1543   sin_amg,      exp_amg,
1544   log_amg,      sqrt_amg,
1545   repeat_amg,   repeat_ass_amg,
1546   concat_amg,   concat_ass_amg
1547 };
1548 #endif /* OVERLOAD */
1549
1550 #endif /* Include guard */