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