X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/0d85d8777a6ec9fdcc93593180474ebff6fbbccb..02b54f9d07226e99a30271314e02617d5629b511:/dosish.h diff --git a/dosish.h b/dosish.h index 589bd56..8a1ce98 100644 --- 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 -# 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. */ @@ -63,7 +52,11 @@ * to include and 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 @@ -83,13 +76,15 @@ * 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 + /* * 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 @@ -110,13 +105,15 @@ # 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 -# endif -# endif -#endif /* WIN32 */