This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Correct code-like snippet in documentation
[perl5.git] / dosish.h
index 589bd56..8a1ce98 100644 (file)
--- a/dosish.h
+++ b/dosish.h
@@ -1,57 +1,46 @@
+/*    dosish.h
+ *
+ *    Copyright (C) 1993, 1994, 1996, 1997, 1998, 1999,
+ *    2000, 2001, 2002, 2007, by Larry Wall and others
+ *
+ *    You may distribute under the terms of either the GNU General Public
+ *    License or the Artistic License, as specified in the README file.
+ *
+ */
 #define ABORT() abort();
 
 #ifndef SH_PATH
 #define SH_PATH "/bin/sh"
 #endif
 
-#ifdef DJGPP
+#ifdef WIN32
+#  define PERL_SYS_INIT_BODY(c,v)                                      \
+      MALLOC_CHECK_TAINT2(*c,*v) Perl_win32_init(c,v); PERLIO_INIT
+#  define PERL_SYS_TERM_BODY()   Perl_win32_term()
 #  define BIT_BUCKET "nul"
-#  define OP_BINARY O_BINARY
-#  define PERL_SYS_INIT(c,v) Perl_DJGPP_init(c,v)
-#  include <signal.h>
-#  define HAS_UTIME
-#  define HAS_KILL
-   char *djgpp_pathexp (const char*);
-#  if (DJGPP==2 && DJGPP_MINOR < 2)
-#    define NO_LOCALECONV_MON_THOUSANDS_SEP
-#  endif
-#  ifdef USE_THREADS
-#    define OLD_PTHREADS_API
-#  endif
-#else  /* DJGPP */
-#  ifdef WIN32
-#    define PERL_SYS_INIT(c,v) Perl_win32_init(c,v)
-#    define BIT_BUCKET "nul"
-#  else
-#    define PERL_SYS_INIT(c,v)
-#    define BIT_BUCKET "\\dev\\nul" /* "wanna be like, umm, Newlined, or somethin?" */
-#  endif
-#endif /* DJGPP */
-
-#define PERL_SYS_TERM() MALLOC_TERM
-#define dXSUB_SYS
-#define TMPPATH "plXXXXXX"
+#else
+#  define PERL_SYS_INIT_BODY(c,v)              \
+    MALLOC_CHECK_TAINT2(*c,*v); PERLIO_INIT
+#  define BIT_BUCKET "\\dev\\nul" /* "wanna be like, umm, Newlined, or somethin?" */
+#endif
 
-/*
- * 5.003_07 and earlier keyed on #ifdef MSDOS for determining if we were 
- * running on DOS, *and* if we had to cope with 16 bit memory addressing 
- * constraints, *and* we need to have memory allocated as unsigned long.
- *
- * with the advent of *real* compilers for DOS, they are not locked together.
- * MSDOS means "I am running on MSDOS". HAS_64K_LIMIT means "I have 
- * 16 bit memory addressing constraints".
+/* Generally add things last-in first-terminated.  IO and memory terminations
+ * need to be generally last
  *
- * if you need the last, try #DEFINE MEM_SIZE unsigned long.
- */
-#ifdef MSDOS
- #ifndef DJGPP
-  #define HAS_64K_LIMIT
- #endif
+ * BEWARE that using PerlIO in these will be using freed memory, so may appear
+ * to work, but must NOT be retained in production code. */
+#ifndef PERL_SYS_TERM_BODY
+#  define PERL_SYS_TERM_BODY()                         \
+    ENV_TERM; USER_PROP_MUTEX_TERM; LOCALE_TERM;       \
+    HINTS_REFCNT_TERM; KEYWORD_PLUGIN_MUTEX_TERM;      \
+    OP_CHECK_MUTEX_TERM; OP_REFCNT_TERM;               \
+    PERLIO_TERM; MALLOC_TERM; 
 #endif
+#define dXSUB_SYS dNOOP
 
 /* USEMYBINMODE
  *     This symbol, if defined, indicates that the program should
- *     use the routine my_binmode(FILE *fp, char iotype) to insure
+ *     use the routine my_binmode(FILE *fp, char iotype, int mode) to insure
  *     that a file is in "binary" mode -- that is, that no translation
  *     of bytes occurs on read or write operations.
  */
  *     to include <sys/stat.h> and <sys/types.h> to get any typedef'ed
  *     information.
  */
-#define Stat_t struct stat
+#if defined(WIN32)
+#  define Stat_t struct w32_stat
+#else
+#  define Stat_t struct _stati64
+#endif
 
 /* USE_STAT_RDEV:
  *     This symbol is defined if this system has a stat structure declaring
  *     as the first line of a Perl program designed to be executed directly
  *     by name, instead of the standard Unix #!.  If ALTERNATE_SHEBANG
  *     begins with a character other then #, then Perl will only treat
- *     it as a command line if if finds the string "perl" in the first
+ *     it as a command line if it finds the string "perl" in the first
  *     word; otherwise it's treated as the first line of code in the script.
  *     (IOW, Perl won't hand off to another interpreter via an alternate
  *     shebang sequence that might be legal Perl code.)
  */
 /* #define ALTERNATE_SHEBANG "#!" / **/
 
+#include <signal.h>
+
 /*
  * fwrite1() should be a routine with the same calling sequence as fwrite(),
  * but which outputs all of the bytes requested as a single stream (unlike
@@ -99,7 +94,7 @@
 #define fwrite1 fwrite
 
 #define Fstat(fd,bufptr)   fstat((fd),(bufptr))
-#define Fflush(fp)         fflush(fp)
+#define Fflush(fp)      fflush(fp)
 #define Mkdir(path,mode)   mkdir((path),(mode))
 
 #ifndef WIN32
 #  define HAS_KILL
 #  define HAS_WAIT
 #  define HAS_CHOWN
+#endif /* WIN32 */
+
+/* Don't go reading from /dev/urandom */
+#define PERL_NO_DEV_RANDOM
+
+#ifdef WIN32
+#  define NO_ENVIRON_ARRAY
+#endif
+
 /*
- * This provides a layer of functions and macros to ensure extensions will
- * get to use the same RTL functions as the core.
+ * ex: set ts=8 sts=4 sw=4 et:
  */
-#  ifndef HASATTRIBUTE
-#    ifndef PERL_OBJECT
-#      include <win32iop.h>
-#    endif
-#  endif
-#endif /* WIN32 */