perl 4.0 patch 14: patch #11, continued
[p5sagit/p5-mst-13.2.git] / perl.h
diff --git a/perl.h b/perl.h
index c911e2b..4ab86d9 100644 (file)
--- a/perl.h
+++ b/perl.h
@@ -1,89 +1,32 @@
-/* $Header: perl.h,v 3.0.1.10 90/11/10 01:44:13 lwall Locked $
+/* $RCSfile: perl.h,v $$Revision: 4.0.1.3 $$Date: 91/06/10 01:25:10 $
  *
- *    Copyright (c) 1989, Larry Wall
+ *    Copyright (c) 1991, Larry Wall
  *
- *    You may distribute under the terms of the GNU General Public License
- *    as specified in the README file that comes with the perl 3.0 kit.
+ *    You may distribute under the terms of either the GNU General Public
+ *    License or the Artistic License, as specified in the README file.
  *
  * $Log:       perl.h,v $
- * Revision 3.0.1.10  90/11/10  01:44:13  lwall
- * patch38: more msdos/os2 upgrades
+ * Revision 4.0.1.3  91/06/10  01:25:10  lwall
+ * patch10: certain pattern optimizations were botched
  * 
- * Revision 3.0.1.9  90/10/15  17:59:41  lwall
- * patch29: some machines didn't like unsigned C preprocessor values
+ * Revision 4.0.1.2  91/06/07  11:28:33  lwall
+ * patch4: new copyright notice
+ * patch4: made some allowances for "semi-standard" C
+ * patch4: many, many itty-bitty portability fixes
  * 
- * Revision 3.0.1.8  90/08/09  04:10:53  lwall
- * patch19: various MSDOS and OS/2 patches folded in
- * patch19: did preliminary work toward debugging packages and evals
- * patch19: added -x switch to extract script from input trash
+ * Revision 4.0.1.1  91/04/11  17:49:51  lwall
+ * patch1: hopefully straightened out some of the Xenix mess
  * 
- * Revision 3.0.1.7  90/03/27  16:12:52  lwall
- * patch16: MSDOS support
- * patch16: support for machines that can't cast negative floats to unsigned ints
- * 
- * Revision 3.0.1.6  90/03/12  16:40:43  lwall
- * patch13: did some ndir straightening up for Xenix
- * 
- * Revision 3.0.1.5  90/02/28  17:52:28  lwall
- * patch9: Configure now determines whether volatile is supported
- * patch9: volatilized some more variables for super-optimizing compilers
- * patch9: unused VREG symbol deleted
- * patch9: perl can now start up other interpreters scripts  
- * patch9: you may now undef $/ to have no input record separator
- * patch9: nested evals clobbered their longjmp environment
- * 
- * Revision 3.0.1.4  89/12/21  20:07:35  lwall
- * patch7: arranged for certain registers to be restored after longjmp()
- * patch7: Configure now compiles a test program to figure out time.h fiasco
- * patch7: Configure now detects DG/UX thingies like [sg]etpgrp2 and utime.h
- * patch7: memcpy() and memset() return void in __STDC__
- * patch7: errno may now be a macro with an lvalue
- * patch7: ANSI strerror() is now supported
- * patch7: Xenix support for sys/ndir.h, cross compilation
- * 
- * Revision 3.0.1.3  89/11/17  15:28:57  lwall
- * patch5: byteorder now is a hex value
- * patch5: Configure now looks for <time.h> including <sys/time.h>
- * 
- * Revision 3.0.1.2  89/11/11  04:39:38  lwall
- * patch2: Configure may now set -DDEBUGGING
- * patch2: netinet/in.h needed sys/types.h some places
- * patch2: more <sys/time.h> and <time.h> wrangling
- * patch2: yydebug moved to where type doesn't matter  
- * 
- * Revision 3.0.1.1  89/10/26  23:17:08  lwall
- * patch1: vfork now conditionally defined based on VFORK
- * patch1: DEC risc machines have a buggy memcmp
- * patch1: perl.h now includes <netinet/in.h> if it exists
- * 
- * Revision 3.0  89/10/18  15:21:21  lwall
- * 3.0 baseline
+ * Revision 4.0  91/03/20  01:37:56  lwall
+ * 4.0 baseline.
  * 
  */
 
-#define VOIDUSED 1
+#define VOIDWANT 1
 #include "config.h"
 
 #ifdef MSDOS
-/*
- * BUGGY_MSC:
- *     This symbol is defined if you are the unfortunate owner of a buggy
- *     Microsoft C compiler and want to use intrinsic functions.  Versions
- *     up to 5.1 are known conform to this definition.  This is not needed
- *     under Unix.
- */
-#define BUGGY_MSC                      /**/
-/*
- * BINARY:
- *     This symbol is defined if you run under an operating system that
- *     distinguishes between binary and text files.  If so the function
- *     setmode will be used to set the file into binary mode.  Unix
- *     doesn't distinguish.
- */
-#define BINARY                         /**/
-
-#define I_FCNTL
-
+/* This stuff now in the MS-DOS config.h file. */
 #else /* !MSDOS */
 
 /*
  * are not checked by the configuration script, but are directly defined
  * here.
  */
-#define CHOWN
-#define CHROOT
-#define FORK
-#define GETLOGIN
-#define GETPPID
-#define KILL
-#define LINK
-#define PIPE
-#define WAIT
-#define UMASK
+#define HAS_ALARM
+#define HAS_CHOWN
+#define HAS_CHROOT
+#define HAS_FORK
+#define HAS_GETLOGIN
+#define HAS_GETPPID
+#define HAS_KILL
+#define HAS_LINK
+#define HAS_PIPE
+#define HAS_WAIT
+#define HAS_UMASK
 /*
  * The following symbols are defined if your operating system supports
  * password and group functions in general.  All Unix systems do.
  */
-#define GROUP
-#define PASSWD
+#define HAS_GROUP
+#define HAS_PASSWD
 
 #endif /* !MSDOS */
 
-#if defined(HASVOLATILE) || defined(__STDC__)
+#if defined(__STDC__) || defined(_AIX) || defined(__stdc__)
+# define STANDARD_C 1
+#endif
+
+#if defined(HASVOLATILE) || defined(STANDARD_C)
 #define VOLATILE volatile
 #else
 #define VOLATILE
 #   endif
 #endif
 
-#ifndef VFORK
+#ifndef HAS_VFORK
 #   define vfork fork
 #endif
 
-#ifdef GETPGRP2
-#   ifndef GETPGRP
-#      define GETPGRP
+#ifdef HAS_GETPGRP2
+#   ifndef HAS_GETPGRP
+#      define HAS_GETPGRP
 #   endif
 #   define getpgrp getpgrp2
 #endif
 
-#ifdef SETPGRP2
-#   ifndef SETPGRP
-#      define SETPGRP
+#ifdef HAS_SETPGRP2
+#   ifndef HAS_SETPGRP
+#      define HAS_SETPGRP
 #   endif
 #   define setpgrp setpgrp2
 #endif
 
-#if defined(MEMCMP) && defined(mips) && BYTEORDER == 0x1234
-#undef MEMCMP
+#include <stdio.h>
+#include <ctype.h>
+#include <setjmp.h>
+#ifndef MSDOS
+#ifdef PARAM_NEEDS_TYPES
+#include <sys/types.h>
+#endif
+#include <sys/param.h>
 #endif
+#ifdef STANDARD_C
+/* Use all the "standard" definitions */
+#include <stdlib.h>
+#include <string.h>
+#endif /* STANDARD_C */
 
-#ifdef MEMCPY
-#ifndef memcpy
-#if defined(__STDC__ ) || defined(MSDOS)
-extern void *memcpy(), *memset();
-#else
-extern char *memcpy(), *memset();
+#if defined(HAS_MEMCMP) && defined(mips) && BYTEORDER == 0x1234
+#undef HAS_MEMCMP
 #endif
+
+#ifdef HAS_MEMCPY
+
+#  ifndef STANDARD_C
+#    ifndef memcpy
+extern char * memcpy(), *memset();
 extern int memcmp();
-#endif
-#define bcopy(s1,s2,l) memcpy(s2,s1,l)
-#define bzero(s,l) memset(s,0,l)
-#endif
-#ifndef BCMP           /* prefer bcmp slightly 'cuz it doesn't order */
-#define bcmp(s1,s2,l) memcmp(s1,s2,l)
-#endif
+#    endif /* ndef memcpy */
+#  endif /* ndef STANDARD_C */
 
-#include <stdio.h>
-#include <ctype.h>
-#include <setjmp.h>
-#ifndef MSDOS
-#include <sys/param.h> /* if this needs types.h we're still wrong */
+#   ifndef bcopy
+#      define bcopy(s1,s2,l) memcpy(s2,s1,l)
+#   endif
+#   ifndef bzero
+#      define bzero(s,l) memset(s,0,l)
+#   endif
+#endif /* HAS_MEMCPY */
+
+#ifndef HAS_BCMP               /* prefer bcmp slightly 'cuz it doesn't order */
+#   ifndef bcmp
+#      define bcmp(s1,s2,l) memcmp(s1,s2,l)
+#   endif
 #endif
 
 #ifndef _TYPES_                /* If types.h defines this it's easy. */
@@ -184,7 +147,7 @@ extern int memcmp();
 #   include <time.h>
 #endif
 
-#ifdef I_SYSTIME
+#ifdef I_SYS_TIME
 #   ifdef SYSTIMEKERNEL
 #      define KERNEL
 #   endif
@@ -198,8 +161,8 @@ extern int memcmp();
 #include <sys/times.h>
 #endif
 
-#if defined(STRERROR) && (!defined(MKDIR) || !defined(RMDIR))
-#undef STRERROR
+#if defined(HAS_STRERROR) && (!defined(HAS_MKDIR) || !defined(HAS_RMDIR))
+#undef HAS_STRERROR
 #endif
 
 #include <errno.h>
@@ -209,13 +172,15 @@ extern int errno;     /* ANSI allows errno to be an lvalue expr */
 #endif
 #endif
 
-#ifdef STRERROR
+#ifndef strerror
+#ifdef HAS_STRERROR
 char *strerror();
 #else
 extern int sys_nerr;
 extern char *sys_errlist[];
 #define strerror(e) ((e) < 0 || (e) >= sys_nerr ? "(unknown)" : sys_errlist[e])
 #endif
+#endif
 
 #ifdef I_SYSIOCTL
 #ifndef _IOCTL_
@@ -224,22 +189,34 @@ extern char *sys_errlist[];
 #endif
 
 #if defined(mc300) || defined(mc500) || defined(mc700) /* MASSCOMP */
-#ifdef SOCKETPAIR
-#undef SOCKETPAIR
+#ifdef HAS_SOCKETPAIR
+#undef HAS_SOCKETPAIR
 #endif
-#ifdef NDBM
-#undef NDBM
+#ifdef HAS_NDBM
+#undef HAS_NDBM
 #endif
 #endif
 
-#ifdef NDBM
+#ifdef HAS_GDBM
+#ifdef I_GDBM
+#include <gdbm.h>
+#endif
+#define SOME_DBM
+#ifdef HAS_NDBM
+#undef HAS_NDBM
+#endif
+#ifdef HAS_ODBM
+#undef HAS_ODBM
+#endif
+#else
+#ifdef HAS_NDBM
 #include <ndbm.h>
 #define SOME_DBM
-#ifdef ODBM
-#undef ODBM
+#ifdef HAS_ODBM
+#undef HAS_ODBM
 #endif
 #else
-#ifdef ODBM
+#ifdef HAS_ODBM
 #ifdef NULL
 #undef NULL            /* suppress redefinition message */
 #endif
@@ -254,8 +231,9 @@ extern char *sys_errlist[];
 #define dbm_store(db,dkey,dcontent,flags) store(dkey,dcontent)
 #define dbm_close(db) dbmclose()
 #define dbm_firstkey(db) firstkey()
-#endif /* ODBM */
-#endif /* NDBM */
+#endif /* HAS_ODBM */
+#endif /* HAS_NDBM */
+#endif /* HAS_GDBM */
 #ifdef SOME_DBM
 EXT char *dbmkey;
 EXT int dbmlen;
@@ -269,15 +247,15 @@ EXT int dbmlen;
 #define ntohi ntohl
 #endif
 
-#if defined(I_DIRENT) && !defined(M_XENIX)
+#if defined(I_DIRENT)
 #   include <dirent.h>
 #   define DIRENT dirent
 #else
-#   ifdef I_SYSNDIR
+#   ifdef I_SYS_NDIR
 #      include <sys/ndir.h>
 #      define DIRENT direct
 #   else
-#      ifdef I_SYSDIR
+#      ifdef I_SYS_DIR
 #          ifdef hp9000s500
 #              include <ndir.h>        /* may be wrong in the future */
 #          else
@@ -288,6 +266,117 @@ EXT int dbmlen;
 #   endif
 #endif
 
+#ifdef FPUTS_BOTCH
+/* work around botch in SunOS 4.0.1 and 4.0.2 */
+#   ifndef fputs
+#      define fputs(str,fp) fprintf(fp,"%s",str)
+#   endif
+#endif
+
+/*
+ * The following gobbledygook brought to you on behalf of __STDC__.
+ * (I could just use #ifndef __STDC__, but this is more bulletproof
+ * in the face of half-implementations.)
+ */
+
+#ifndef S_IFMT
+#   ifdef _S_IFMT
+#      define S_IFMT _S_IFMT
+#   else
+#      define S_IFMT 0170000
+#   endif
+#endif
+
+#ifndef S_ISDIR
+#   define S_ISDIR(m) ((m & S_IFMT) == S_IFDIR)
+#endif
+
+#ifndef S_ISCHR
+#   define S_ISCHR(m) ((m & S_IFMT) == S_IFCHR)
+#endif
+
+#ifndef S_ISBLK
+#   ifdef S_IFBLK
+#      define S_ISBLK(m) ((m & S_IFMT) == S_IFBLK)
+#   else
+#      define S_ISBLK(m) (0)
+#   endif
+#endif
+
+#ifndef S_ISREG
+#   define S_ISREG(m) ((m & S_IFMT) == S_IFREG)
+#endif
+
+#ifndef S_ISFIFO
+#   ifdef S_IFIFO
+#      define S_ISFIFO(m) ((m & S_IFMT) == S_IFIFO)
+#   else
+#      define S_ISFIFO(m) (0)
+#   endif
+#endif
+
+#ifndef S_ISLNK
+#   ifdef _S_ISLNK
+#      define S_ISLNK(m) _S_ISLNK(m)
+#   else
+#      ifdef _S_IFLNK
+#          define S_ISLNK(m) ((m & S_IFMT) == _S_IFLNK)
+#      else
+#          ifdef S_IFLNK
+#              define S_ISLNK(m) ((m & S_IFMT) == S_IFLNK)
+#          else
+#              define S_ISLNK(m) (0)
+#          endif
+#      endif
+#   endif
+#endif
+
+#ifndef S_ISSOCK
+#   ifdef _S_ISSOCK
+#      define S_ISSOCK(m) _S_ISSOCK(m)
+#   else
+#      ifdef _S_IFSOCK
+#          define S_ISSOCK(m) ((m & S_IFMT) == _S_IFSOCK)
+#      else
+#          ifdef S_IFSOCK
+#              define S_ISSOCK(m) ((m & S_IFMT) == S_IFSOCK)
+#          else
+#              define S_ISSOCK(m) (0)
+#          endif
+#      endif
+#   endif
+#endif
+
+#ifndef S_IRUSR
+#   ifdef S_IREAD
+#      define S_IRUSR S_IREAD
+#      define S_IWUSR S_IWRITE
+#      define S_IXUSR S_IEXEC
+#   else
+#      define S_IRUSR 0400
+#      define S_IWUSR 0200
+#      define S_IXUSR 0100
+#   endif
+#   define S_IRGRP (S_IRUSR>>3)
+#   define S_IWGRP (S_IWUSR>>3)
+#   define S_IXGRP (S_IXUSR>>3)
+#   define S_IROTH (S_IRUSR>>6)
+#   define S_IWOTH (S_IWUSR>>6)
+#   define S_IXOTH (S_IXUSR>>6)
+#endif
+
+#ifndef S_ISUID
+#   define S_ISUID 04000
+#endif
+
+#ifndef S_ISGID
+#   define S_ISGID 02000
+#endif
+
+#ifdef f_next
+#undef f_next
+#endif
+
 typedef unsigned int STRLEN;
 
 typedef struct arg ARG;
@@ -320,7 +409,7 @@ typedef struct callsave CSV;
 #   define I286
 #endif
 
-#ifndef        __STDC__
+#ifndef        STANDARD_C
 #ifdef CHARSPRINTF
     char *sprintf();
 #else
@@ -398,24 +487,24 @@ EXT STR *Str;
 #define BYTEORDER 0x1234
 #endif
 
-#if defined(htonl) && !defined(HTONL)
-#define HTONL
+#if defined(htonl) && !defined(HAS_HTONL)
+#define HAS_HTONL
 #endif
-#if defined(htons) && !defined(HTONS)
-#define HTONS
+#if defined(htons) && !defined(HAS_HTONS)
+#define HAS_HTONS
 #endif
-#if defined(ntohl) && !defined(NTOHL)
-#define NTOHL
+#if defined(ntohl) && !defined(HAS_NTOHL)
+#define HAS_NTOHL
 #endif
-#if defined(ntohs) && !defined(NTOHS)
-#define NTOHS
+#if defined(ntohs) && !defined(HAS_NTOHS)
+#define HAS_NTOHS
 #endif
-#ifndef HTONL
+#ifndef HAS_HTONL
 #if (BYTEORDER & 0xffff) != 0x4321
-#define HTONS
-#define HTONL
-#define NTOHS
-#define NTOHL
+#define HAS_HTONS
+#define HAS_HTONL
+#define HAS_NTOHS
+#define HAS_NTOHL
 #define MYSWAP
 #define htons my_swap
 #define htonl my_htonl
@@ -424,10 +513,10 @@ EXT STR *Str;
 #endif
 #else
 #if (BYTEORDER & 0xffff) == 0x4321
-#undef HTONS
-#undef HTONL
-#undef NTOHS
-#undef NTOHL
+#undef HAS_HTONS
+#undef HAS_HTONL
+#undef HAS_NTOHS
+#undef HAS_NTOHL
 #endif
 #endif
 
@@ -496,7 +585,7 @@ char *scanpat();
 char *scansubst();
 char *scantrans();
 char *scanstr();
-char *scanreg();
+char *scanident();
 char *str_append_till();
 char *str_gets();
 char *str_grow();
@@ -522,6 +611,10 @@ void do_sprintf();
 void do_accept();
 void do_pipe();
 void do_vecset();
+void do_unshift();
+void do_execfree();
+void magicalize();
+void magicname();
 void savelist();
 void saveitem();
 void saveint();
@@ -535,6 +628,9 @@ ARRAY *saveary();
 
 EXT char **origargv;
 EXT int origargc;
+EXT char **origenviron;
+extern char **environ;
+
 EXT line_t subline INIT(0);
 EXT STR *subname INIT(Nullstr);
 EXT int arybase INIT(0);
@@ -580,6 +676,7 @@ EXT STR *DBsignal INIT(Nullstr);
 EXT int lastspbase;
 EXT int lastsize;
 
+EXT char *hexdigit INIT("0123456789abcdef0123456789ABCDEF");
 EXT char *origfilename;
 EXT FILE * VOLATILE rsfp;
 EXT char buf[1024];
@@ -590,7 +687,8 @@ EXT char *bufend;
 
 EXT STR *linestr INIT(Nullstr);
 
-EXT int record_separator INIT('\n');
+EXT char *rs INIT("\n");
+EXT int rschar INIT('\n');     /* final char of rs, or 0777 if none */
 EXT int rslen INIT(1);
 EXT char *ofs INIT(Nullch);
 EXT int ofslen INIT(0);
@@ -603,6 +701,7 @@ EXT char *nointrp INIT("");
 EXT bool preprocess INIT(FALSE);
 EXT bool minus_n INIT(FALSE);
 EXT bool minus_p INIT(FALSE);
+EXT bool minus_l INIT(FALSE);
 EXT bool minus_a INIT(FALSE);
 EXT bool doswitches INIT(FALSE);
 EXT bool dowarn INIT(FALSE);
@@ -614,6 +713,11 @@ EXT bool sawi INIT(FALSE);         /* study must assume case insensitive */
 EXT bool sawvec INIT(FALSE);
 EXT bool localizing INIT(FALSE);       /* are we processing a local() list? */
 
+#ifndef MAXSYSFD
+#   define MAXSYSFD 2
+#endif
+EXT int maxsysfd INIT(MAXSYSFD);       /* top fd to pass to subprocesses */
+
 #ifdef CSH
 char *cshname INIT(CSH);
 int cshlen INIT(0);
@@ -648,6 +752,7 @@ FILE *popen();
 STR *interp();
 void free_arg();
 STIO *stio_new();
+void hoistmust();
 
 EXT struct stat statbuf;
 EXT struct stat statcache;
@@ -675,6 +780,7 @@ EXT char *debdelim;
 #define YYDEBUG 1
 #endif
 EXT int perldb INIT(0);
+#define YYMAXDEPTH 300
 
 EXT line_t cmdline INIT(NOLINE);
 
@@ -719,13 +825,17 @@ EXT int *di;                      /* for tmp use in debuggers */
 EXT char *dc;
 EXT short *ds;
 
+/* Fix these up for __STDC__ */
+EXT long basetime INIT(0);
+char *mktemp();
+#ifndef STANDARD_C
+/* All of these are in stdlib.h or time.h for ANSI C */
 double atof();
 long time();
-EXT long basetime INIT(0);
 struct tm *gmtime(), *localtime();
-char *mktemp();
 char *index(), *rindex();
 char *strcpy(), *strcat();
+#endif /* ! STANDARD_C */
 
 #ifdef EUNICE
 #define UNLINK unlnk
@@ -734,15 +844,15 @@ int unlnk();
 #define UNLINK unlink
 #endif
 
-#ifndef SETREUID
-#ifdef SETRESUID
+#ifndef HAS_SETREUID
+#ifdef HAS_SETRESUID
 #define setreuid(r,e) setresuid(r,e,-1)
-#define SETREUID
+#define HAS_SETREUID
 #endif
 #endif
-#ifndef SETREGID
-#ifdef SETRESGID
+#ifndef HAS_SETREGID
+#ifdef HAS_SETRESGID
 #define setregid(r,e) setresgid(r,e,-1)
-#define SETREGID
+#define HAS_SETREGID
 #endif
 #endif