Mercurial > emacs
annotate src/s/usg5-4.h @ 96428:51371c50583a
Fix typo in comments.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Mon, 30 Jun 2008 02:12:47 +0000 |
parents | 206c2cd0bbcc |
children | cb1bfa1dca4f |
rev | line source |
---|---|
456 | 1 /* Definitions file for GNU Emacs running on AT&T's System V Release 4 |
94715
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
2 Copyright (C) 1987, 1990, 1999, 2000, 2001, 2002, 2003, 2004, 2005, |
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
3 2006, 2007, 2008 Free Software Foundation, Inc. |
456 | 4 |
5 This file is part of GNU Emacs. | |
6 | |
94715
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
7 GNU Emacs is free software: you can redistribute it and/or modify |
1039 | 8 it under the terms of the GNU General Public License as published by |
94715
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
9 the Free Software Foundation, either version 3 of the License, or |
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
10 (at your option) any later version. |
456 | 11 |
1039 | 12 GNU Emacs is distributed in the hope that it will be useful, |
13 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 GNU General Public License for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
94715
1f134b61867c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
456 | 19 |
20 /* This file written by James Van Artsdalen of Dell Computer Corporation. | |
2116
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
21 * james@bigtex.cactus.org. Subsequently improved for Dell 2.2 by Eric |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
22 * S. Raymond <esr@snark.thyrsus.com>. |
456 | 23 */ |
24 | |
25 /* Use the SysVr3 file for at least base configuration. */ | |
26 | |
96303 | 27 #define USG /* System III, System V, etc */ |
456 | 28 |
96303 | 29 #define USG5 |
456 | 30 #define USG5_4 |
31 | |
96303 | 32 /* SYSTEM_TYPE should indicate the kind of system you are using. |
33 It sets the Lisp variable system-type. */ | |
34 | |
35 #define SYSTEM_TYPE "usg-unix-v" | |
36 | |
37 /* Default is to set interrupt_input to 0: don't do input buffering within Emacs */ | |
38 | |
39 /* #define INTERRUPT_INPUT */ | |
40 | |
41 /* | |
42 * Define HAVE_TERMIO if the system provides sysV-style ioctls | |
43 * for terminal control. | |
44 */ | |
45 | |
46 #define HAVE_TERMIO | |
456 | 47 |
96303 | 48 /* |
49 * Define HAVE_PTYS if the system supports pty devices. | |
50 */ | |
51 | |
52 /* Some versions of V.3 have this, but not all. | |
53 #define HAVE_PTYS | |
54 #define SYSV_PTYS */ | |
55 | |
56 /* Define HAVE_SOCKETS if system supports 4.2-compatible sockets. */ | |
57 | |
58 /* #define HAVE_SOCKETS */ | |
59 | |
60 /* | |
61 * Define NONSYSTEM_DIR_LIBRARY to make Emacs emulate | |
62 * The 4.2 opendir, etc., library functions. | |
63 */ | |
64 | |
65 /* #define NONSYSTEM_DIR_LIBRARY */ | |
456 | 66 |
96303 | 67 /* |
68 * Define SYSV_SYSTEM_DIR to use the V.3 getdents/readir | |
69 * library functions. Almost, but not quite the same as | |
70 * the 4.2 functions | |
71 */ | |
72 #define SYSV_SYSTEM_DIR | |
73 | |
74 /* Define this symbol if your system has the functions bcopy, etc. */ | |
75 | |
76 /* #define BSTRING */ | |
77 | |
78 /* subprocesses should be defined if you want to | |
79 have code for asynchronous subprocesses | |
80 (as used in M-x compile and M-x shell). | |
81 This is supposed to work now on system V release 2. */ | |
82 | |
83 #define subprocesses | |
84 | |
85 /* If your system uses COFF (Common Object File Format) then define the | |
86 preprocessor symbol "COFF". */ | |
87 | |
88 #define COFF | |
89 | |
90 /* define MAIL_USE_FLOCK if the mailer uses flock | |
91 to interlock access to /usr/spool/mail/$USER. | |
92 The alternative is that a lock file named | |
93 /usr/spool/mail/$USER.lock. */ | |
94 | |
95 /* #define MAIL_USE_FLOCK */ | |
96 | |
97 /* Define CLASH_DETECTION if you want lock files to be written | |
98 so that Emacs can tell instantly when you try to modify | |
99 a file that someone else has modified in his Emacs. */ | |
100 | |
101 /* #define CLASH_DETECTION */ | |
456 | 102 |
96303 | 103 /* The file containing the kernel's symbol table is called /unix. */ |
104 | |
105 #define KERNEL_FILE "/unix" | |
106 | |
107 /* The symbol in the kernel where the load average is found | |
108 is named avenrun. */ | |
109 | |
110 #define LDAV_SYMBOL "avenrun" | |
111 | |
112 /* Define this if system V IPC is available. */ | |
113 | |
114 #define HAVE_SYSVIPC | |
115 | |
116 /* Special hacks needed to make Emacs run on this system. */ | |
117 | |
118 /* | |
119 * Make the sigsetmask function go away. Don't know what the | |
120 * ramifications of this are, but doesn't seem possible to | |
121 * emulate it properly anyway at this point. | |
122 */ | |
123 | |
124 #define sigsetmask(mask) /* Null expansion */ | |
125 | |
126 /* setjmp and longjmp can safely replace _setjmp and _longjmp, | |
127 but they will run slower. */ | |
128 | |
129 #define _setjmp setjmp | |
130 #define _longjmp longjmp | |
4336
96d3869ae231
(bzero, bcmp, bcopy): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
4295
diff
changeset
|
131 |
96303 | 132 /* On USG systems these have different names */ |
133 #ifndef HAVE_INDEX | |
134 #define index strchr | |
135 #endif /* ! defined (HAVE_INDEX) */ | |
136 #ifndef HAVE_RINDEX | |
137 #define rindex strrchr | |
138 #endif /* ! defined (HAVE_RINDEX) */ | |
139 | |
140 /* USG systems tend to put everything declared static | |
141 into the initialized data area, which becomes pure after dumping Emacs. | |
142 Foil this. Emacs carefully avoids static vars inside functions. */ | |
143 | |
144 #define static | |
145 | |
146 /* Compiler bug bites on many systems when default ADDR_CORRECT is used. */ | |
147 | |
148 #define ADDR_CORRECT(x) (x) | |
149 | |
150 /* Use terminfo instead of termcap. */ | |
151 | |
152 #define TERMINFO | |
153 | |
154 | |
155 /* The docs for system V/386 suggest v.3 has sigpause, | |
156 so let's give it a try. */ | |
157 #define HAVE_SYSV_SIGPAUSE | |
158 | |
159 | |
160 /* If we're using the System V X port, BSD bstring functions will be handy */ | |
161 | |
162 #ifdef HAVE_X_WINDOWS | |
163 #define BSTRING | |
164 #endif /* HAVE_X_WINDOWS */ | |
165 | |
166 /* Enable support for shared libraries in unexec. */ | |
167 | |
168 #define USG_SHARED_LIBRARIES | |
169 | |
170 /* On USG systems signal handlers return void */ | |
171 | |
172 #define SIGTYPE void | |
173 | |
96378
1163f7459d65
Fix previous change: keep the correct branch of a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96303
diff
changeset
|
174 #define ORDINARY_LINK |
1163f7459d65
Fix previous change: keep the correct branch of a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96303
diff
changeset
|
175 |
1163f7459d65
Fix previous change: keep the correct branch of a
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96303
diff
changeset
|
176 #define LIB_STANDARD |
456 | 177 |
2116
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
178 /* there are no -lg libraries on this system, and no libPW */ |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
179 |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
180 #define LIBS_DEBUG |
456 | 181 |
182 /* Undump with ELF */ | |
183 | |
184 #undef COFF | |
185 | |
186 #define UNEXEC unexelf.o | |
187 | |
8300
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
188 /* <sys/stat.h> *defines* stat(2) as a static function. If "static" |
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
189 * is blank, then many files will have a public definition for stat(2). |
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
190 */ |
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
191 |
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
192 #undef static |
95b09cdfc59d
Move #undef static before the includes.
Richard M. Stallman <rms@gnu.org>
parents:
8283
diff
changeset
|
193 |
456 | 194 /* Get FIONREAD from <sys/filio.h>. Get <sys/ttold.h> to get struct |
195 * tchars. But get <termio.h> first to make sure ttold.h doesn't | |
196 * interfere. And don't try to use SIGIO yet. | |
197 */ | |
198 | |
13466
e31afd8b6355
Always include sys/wait.h unless NOT_C_CODE;
Richard M. Stallman <rms@gnu.org>
parents:
12734
diff
changeset
|
199 #ifndef NOT_C_CODE |
e31afd8b6355
Always include sys/wait.h unless NOT_C_CODE;
Richard M. Stallman <rms@gnu.org>
parents:
12734
diff
changeset
|
200 #include <sys/wait.h> |
e31afd8b6355
Always include sys/wait.h unless NOT_C_CODE;
Richard M. Stallman <rms@gnu.org>
parents:
12734
diff
changeset
|
201 #endif |
e31afd8b6355
Always include sys/wait.h unless NOT_C_CODE;
Richard M. Stallman <rms@gnu.org>
parents:
12734
diff
changeset
|
202 |
456 | 203 #ifdef emacs |
15844
090728aee80a
Don't include filio.h if NO_FILIO_H.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
204 #ifndef NO_FILIO_H |
456 | 205 #include <sys/filio.h> |
15844
090728aee80a
Don't include filio.h if NO_FILIO_H.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
206 #endif |
456 | 207 #include <termio.h> |
208 #include <sys/ttold.h> | |
209 #include <signal.h> | |
1039 | 210 #include <sys/stream.h> |
211 #include <sys/stropts.h> | |
212 #include <sys/termios.h> | |
26090 | 213 #define BROKEN_SIGIO |
456 | 214 #endif |
215 | |
2116
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
216 /* Some SVr4s don't define NSIG in sys/signal.h for ANSI environments; |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
217 * instead, there's a system variable _sys_nsig. Unfortunately, we need the |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
218 * constant to dimension an array. So wire in the appropriate value here. |
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
219 */ |
26090 | 220 #define NSIG_MINIMUM 32 |
2116
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
221 |
456 | 222 /* We can support this */ |
223 | |
224 #define CLASH_DETECTION | |
225 | |
226 #define HAVE_PTYS | |
2116
76df2de3dd55
* s/usg5-4.h: Changes from Eric Raymond:
Jim Blandy <jimb@redhat.com>
parents:
1868
diff
changeset
|
227 #define HAVE_TERMIOS |
456 | 228 |
229 /* It is possible to receive SIGCHLD when there are no children | |
230 waiting, because a previous waitsys(2) cleaned up the carcass of child | |
231 without clearing the SIGCHLD pending info. So, use a non-blocking | |
232 wait3 instead, which maps to waitpid(2) in SysVr4. */ | |
233 | |
234 #define HAVE_WAIT_HEADER | |
235 #define WAITTYPE int | |
236 #define wait3(status, options, rusage) \ | |
8283
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
237 waitpid ((pid_t) -1, (status), (options)) |
456 | 238 #define WRETCODE(w) (w >> 8) |
239 | |
240 /* TIOCGPGRP is broken in SysVr4, so we can't send signals to PTY | |
241 subprocesses the usual way. But TIOCSIGNAL does work for PTYs, and | |
242 this is all we need. */ | |
243 | |
244 #define TIOCSIGSEND TIOCSIGNAL | |
245 | |
246 /* This change means that we don't loop through allocate_pty too many | |
247 times in the (rare) event of a failure. */ | |
248 | |
249 #define FIRST_PTY_LETTER 'z' | |
250 | |
251 /* This sets the name of the master side of the PTY. */ | |
252 | |
253 #define PTY_NAME_SPRINTF strcpy (pty_name, "/dev/ptmx"); | |
254 | |
255 /* This sets the name of the slave side of the PTY. On SysVr4, | |
256 grantpt(3) forks a subprocess, so keep sigchld_handler() from | |
257 intercepting that death. If any child but grantpt's should die | |
258 within, it should be caught after sigrelse(2). */ | |
259 | |
8283
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
260 #define PTY_TTY_NAME_SPRINTF \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
261 { \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
262 char *ptsname (), *ptyname; \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
263 \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
264 sighold (SIGCLD); \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
265 if (grantpt (fd) == -1) \ |
26090 | 266 { emacs_close (fd); return -1; } \ |
8283
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
267 sigrelse (SIGCLD); \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
268 if (unlockpt (fd) == -1) \ |
26090 | 269 { emacs_close (fd); return -1; } \ |
8283
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
270 if (!(ptyname = ptsname (fd))) \ |
26090 | 271 { emacs_close (fd); return -1; } \ |
8283
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
272 strncpy (pty_name, ptyname, sizeof (pty_name)); \ |
32427329c42c
(PTY_TTY_NAME_SPRINTF): Fail smoothly if cannot get pty.
Richard M. Stallman <rms@gnu.org>
parents:
7947
diff
changeset
|
273 pty_name[sizeof (pty_name) - 1] = 0; \ |
456 | 274 } |
275 | |
276 /* Push various streams modules onto a PTY channel. */ | |
277 | |
278 #define SETUP_SLAVE_PTY \ | |
279 if (ioctl (xforkin, I_PUSH, "ptem") == -1) \ | |
280 fatal ("ioctl I_PUSH ptem", errno); \ | |
281 if (ioctl (xforkin, I_PUSH, "ldterm") == -1) \ | |
282 fatal ("ioctl I_PUSH ldterm", errno); \ | |
283 if (ioctl (xforkin, I_PUSH, "ttcompat") == -1) \ | |
284 fatal ("ioctl I_PUSH ttcompat", errno); | |
285 | |
1039 | 286 /* Tell x11term.c and keyboard.c we have the system V streams feature. */ |
287 #define SYSV_STREAMS | |
288 | |
289 /* This definition was suggested for next release. | |
290 So give it a try. */ | |
291 #define HAVE_SOCKETS | |
4336
96d3869ae231
(bzero, bcmp, bcopy): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
4295
diff
changeset
|
292 |
26678
54fc79fa7000
(LIBS_SYSTEM): Add -lgen because that's needed
Gerd Moellmann <gerd@gnu.org>
parents:
26090
diff
changeset
|
293 /* Markus Weiand <weiand@khof.com> says this is needed for Motif on |
54fc79fa7000
(LIBS_SYSTEM): Add -lgen because that's needed
Gerd Moellmann <gerd@gnu.org>
parents:
26090
diff
changeset
|
294 SINIX. */ |
54fc79fa7000
(LIBS_SYSTEM): Add -lgen because that's needed
Gerd Moellmann <gerd@gnu.org>
parents:
26090
diff
changeset
|
295 #define LIBS_SYSTEM -lgen |
52401 | 296 |
297 /* arch-tag: 1a0ed909-5faa-434b-b7c3-9d86c63d53a6 | |
298 (do not change this comment) */ |