Commit | Line | Data |
79072805 |
1 | #define ABORT() abort(); |
a0d0e21e |
2 | |
137443ea |
3 | #ifndef SH_PATH |
55497cff |
4 | #define SH_PATH "/bin/sh" |
137443ea |
5 | #endif |
55497cff |
6 | |
7 | #ifdef DJGPP |
3fe9a6f1 |
8 | # define BIT_BUCKET "nul" |
9 | # define OP_BINARY O_BINARY |
39e571d4 |
10 | # define PERL_SYS_INIT(c,v) Perl_DJGPP_init(c,v) |
11 | # include <signal.h> |
12 | # define HAS_UTIME |
13 | # define HAS_KILL |
14 | char *djgpp_pathexp (const char*); |
15 | # if (DJGPP==2 && DJGPP_MINOR < 2) |
16 | # define NO_LOCALECONV_MON_THOUSANDS_SEP |
17 | # endif |
18 | # ifdef USE_THREADS |
19 | # define NEED_PTHREAD_INIT |
20 | # define OLD_PTHREADS_API |
21 | # define YIELD pthread_yield(NULL) |
22 | # define DETACH(t) \ |
23 | STMT_START { \ |
24 | if (pthread_detach(&(t)->self)) { \ |
25 | MUTEX_UNLOCK(&(t)->mutex); \ |
26 | croak("panic: DETACH"); \ |
27 | } \ |
28 | } STMT_END |
29 | # define pthread_mutexattr_default NULL |
30 | # define pthread_condattr_default NULL |
39e571d4 |
31 | # define pthread_addr_t any_t |
32 | # endif |
3fe9a6f1 |
33 | #else /* DJGPP */ |
3fe9a6f1 |
34 | # ifdef WIN32 |
ad2e33dc |
35 | # define PERL_SYS_INIT(c,v) Perl_win32_init(c,v) |
3fe9a6f1 |
36 | # define BIT_BUCKET "nul" |
37 | # else |
ad2e33dc |
38 | # define PERL_SYS_INIT(c,v) |
3fe9a6f1 |
39 | # define BIT_BUCKET "\\dev\\nul" /* "wanna be like, umm, Newlined, or somethin?" */ |
40 | # endif |
41 | #endif /* DJGPP */ |
55497cff |
42 | |
dc86dda3 |
43 | #define PERL_SYS_TERM() MALLOC_TERM |
8cc95fdb |
44 | #define dXSUB_SYS |
e632a5f6 |
45 | #define TMPPATH "plXXXXXX" |
c07a80fd |
46 | |
55497cff |
47 | /* |
48 | * 5.003_07 and earlier keyed on #ifdef MSDOS for determining if we were |
49 | * running on DOS, *and* if we had to cope with 16 bit memory addressing |
50 | * constraints, *and* we need to have memory allocated as unsigned long. |
51 | * |
52 | * with the advent of *real* compilers for DOS, they are not locked together. |
53 | * MSDOS means "I am running on MSDOS". HAS_64K_LIMIT means "I have |
54 | * 16 bit memory addressing constraints". |
55 | * |
56 | * if you need the last, try #DEFINE MEM_SIZE unsigned long. |
57 | */ |
58 | #ifdef MSDOS |
59 | #ifndef DJGPP |
60 | #define HAS_64K_LIMIT |
61 | #endif |
62 | #endif |
63 | |
e6aa3164 |
64 | /* USEMYBINMODE |
65 | * This symbol, if defined, indicates that the program should |
66 | * use the routine my_binmode(FILE *fp, char iotype) to insure |
67 | * that a file is in "binary" mode -- that is, that no translation |
68 | * of bytes occurs on read or write operations. |
69 | */ |
70 | #undef USEMYBINMODE |
71 | |
61bb5906 |
72 | /* Stat_t: |
73 | * This symbol holds the type used to declare buffers for information |
74 | * returned by stat(). It's usually just struct stat. It may be necessary |
75 | * to include <sys/stat.h> and <sys/types.h> to get any typedef'ed |
76 | * information. |
77 | */ |
78 | #define Stat_t struct stat |
79 | |
e6aa3164 |
80 | /* USE_STAT_RDEV: |
81 | * This symbol is defined if this system has a stat structure declaring |
82 | * st_rdev |
83 | */ |
84 | #define USE_STAT_RDEV /**/ |
85 | |
86 | /* ACME_MESS: |
87 | * This symbol, if defined, indicates that error messages should be |
88 | * should be generated in a format that allows the use of the Acme |
89 | * GUI/editor's autofind feature. |
90 | */ |
91 | #undef ACME_MESS /**/ |
92 | |
44a8e56a |
93 | /* ALTERNATE_SHEBANG: |
94 | * This symbol, if defined, contains a "magic" string which may be used |
95 | * as the first line of a Perl program designed to be executed directly |
96 | * by name, instead of the standard Unix #!. If ALTERNATE_SHEBANG |
97 | * begins with a character other then #, then Perl will only treat |
98 | * it as a command line if if finds the string "perl" in the first |
99 | * word; otherwise it's treated as the first line of code in the script. |
100 | * (IOW, Perl won't hand off to another interpreter via an alternate |
101 | * shebang sequence that might be legal Perl code.) |
102 | */ |
103 | /* #define ALTERNATE_SHEBANG "#!" / **/ |
104 | |
a0d0e21e |
105 | /* |
106 | * fwrite1() should be a routine with the same calling sequence as fwrite(), |
107 | * but which outputs all of the bytes requested as a single stream (unlike |
108 | * fwrite() itself, which on some systems outputs several distinct records |
109 | * if the number_of_items parameter is >1). |
110 | */ |
111 | #define fwrite1 fwrite |
112 | |
a0d0e21e |
113 | #define Fstat(fd,bufptr) fstat((fd),(bufptr)) |
a5f75d66 |
114 | #define Fflush(fp) fflush(fp) |
8cc95fdb |
115 | #define Mkdir(path,mode) mkdir((path),(mode)) |
3fe9a6f1 |
116 | |
117 | #ifndef WIN32 |
118 | # define Stat(fname,bufptr) stat((fname),(bufptr)) |
119 | #else |
2d7a9237 |
120 | # define HAS_IOCTL |
121 | # define HAS_UTIME |
122 | # define HAS_KILL |
123 | # define HAS_WAIT |
3fe9a6f1 |
124 | /* |
f3986ebb |
125 | * This provides a layer of functions and macros to ensure extensions will |
126 | * get to use the same RTL functions as the core. |
3fe9a6f1 |
127 | */ |
2d7a9237 |
128 | # ifndef HASATTRIBUTE |
76e3520e |
129 | # ifndef PERL_OBJECT |
130 | # include <win32iop.h> |
131 | # endif |
2d7a9237 |
132 | # endif |
3fe9a6f1 |
133 | #endif /* WIN32 */ |