1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
|
/* Definitions file for GNU Emacs running on Data General's DG/UX
version 4.32 upto and including 5.4.1.
Copyright (C) 1994 Free Software Foundation, Inc.
This file is part of GNU Emacs.
GNU Emacs is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Emacs is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Emacs; see the file COPYING. If not, write to
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
/*
* Define symbols to identify the version of Unix this is.
* Define all the symbols that apply correctly.
*/
/* #define UNIPLUS */
/* #define USG5 */
/* #define USG */
/* #define HPUX */
/* #define UMAX */
/* #define BSD4_1 */
#define BSD4_2
#define BSD4_3
#define BSD4_4
#define BSD
/* SYSTEM_TYPE should indicate the kind of system you are using.
It sets the Lisp variable system-type. */
#define SYSTEM_TYPE "dgux"
/* NOMULTIPLEJOBS should be defined if your system's shell
does not have "job control" (the ability to stop a program,
run some other program, then continue the first one). */
/* #define NOMULTIPLEJOBS */
/* Emacs can read input using SIGIO and buffering characters itself,
or using CBREAK mode and making C-g cause SIGINT.
The choice is controlled by the variable interrupt_input.
Define INTERRUPT_INPUT to make interrupt_input = 1 the default (use SIGIO)
SIGIO can be used only on systems that implement it (4.2 and 4.3).
CBREAK mode has two disadvantages
1) At least in 4.2, it is impossible to handle the Meta key properly.
I hear that in system V this problem does not exist.
2) Control-G causes output to be discarded.
I do not know whether this can be fixed in system V.
Another method of doing input is planned but not implemented.
It would have Emacs fork off a separate process
to read the input and send it to the true Emacs process
through a pipe.
*/
#define INTERRUPT_INPUT
/*
* Define HAVE_SOCKETS if the system supports sockets.
*/
#define HAVE_SOCKETS
/*
* Define HAVE_UNIX_DOMAIN if the system supports Unix
* domain sockets.
*/
#define HAVE_UNIX_DOMAIN
/*
* Define HAVE_PTYS if the system supports pty devices.
*/
#define HAVE_PTYS
/* (Assume) we do have vfork. */
#define HAVE_VFORK
/*
* Define NONSYSTEM_DIR_LIBRARY to make Emacs emulate
* The 4.2 opendir, etc., library functions.
*/
/* #define NONSYSTEM_DIR_LIBRARY */
/* Define this symbol if your system has the functions bcopy, etc. */
#define BSTRING
/* subprocesses should be defined if you want to
have code for asynchronous subprocesses
(as used in M-x compile and M-x shell).
This is generally OS dependent, and not supported
under most USG systems. */
#define subprocesses
/* If your system uses COFF (Common Object File Format) then define the
preprocessor symbol "COFF".
DGUX can use either COFF or ELF; the default is ELF.
To compile for COFF (or BCS) use the TARGET_BINARY_INTERFACE
environment variable. */
#if defined(_DGUXCOFF_TARGET) || defined(_DGUXBCS_TARGET)
#undef ELF
#ifndef COFF
#define COFF
#endif /* COFF */
#else /* defined(_DGUXCOFF_TARGET) || defined(_DGUXBCS_TARGET) */
#undef COFF
#ifndef ELF
#define ELF
#endif /* ELF */
#endif /* defined(_DGUXCOFF_TARGET) || defined(_DGUXBCS_TARGET) */
#ifndef COFF /* People will probably find this apparently unreliable
till the NFS dumping bug is fixed. */
/* It is possible to undump to ELF with DG/UX 5.4, but for revisions below
5.4.1 the undump MUST be done on a local file system, or the kernel will
panic. ELF executables have the advantage of using shared libraries,
while COFF executables will still work on 4.2x systems. */
#define UNEXEC unexelf.o
/* This makes sure that all segments in the executable are undumped,
not just text, data, and bss. In the case of Mxdb and shared
libraries, additional information is stored in other sections.
It does not hurt to have this defined if you don't use Mxdb or
shared libraries. In fact, it makes no difference. */
/* Necessary for shared libraries and Mxdb debugging information. */
#define USG_SHARED_LIBRARIES
#endif
/* define MAIL_USE_FLOCK if the mailer uses flock
to interlock access to /usr/spool/mail/$USER.
The alternative is that a lock file named
/usr/spool/mail/$USER.lock. */
/* #define MAIL_USE_FLOCK */
/* Define CLASH_DETECTION if you want lock files to be written
so that Emacs can tell instantly when you try to modify
a file that someone else has modified in his Emacs. */
/* #define CLASH_DETECTION */
/* Define a replacement for the baud rate switch, since DG/UX uses a different
from BSD. */
#define BAUD_CONVERT { 0, 110, 134, 150, 300, 600, 1200, 1800, 2400, \
4800, 9600, 19200, 38400 }
/*
* Define NLIST_STRUCT if the system has nlist.h
*/
#define NLIST_STRUCT
/*
* Make WM Interface Compliant.
*/
#define XICCC
/* Here, on a separate page, add any special hacks needed
to make Emacs work on this system. For example,
you might define certain system call names that don't
exist on your system, or that do different things on
your system and must be used only through an encapsulation
(Which you should place, by convention, in sysdep.c). */
/* Some compilers tend to put everything declared static
into the initialized data area, which becomes pure after dumping Emacs.
On these systems, you must #define static as nothing to foil this.
Note that emacs carefully avoids static vars inside functions. */
/* #define static */
/* DG/UX SPECIFIC ADDITIONS TO TEMPLATE FOLLOW: */
/* Use the Berkeley flavors of the library routines, instead of System V. */
#define setpgrp(pid,pgrp) setpgrp2(pid,pgrp)
#define getpgrp(pid) getpgrp2(pid)
/* Act like Berkeley. */
#define _setjmp(env) sigsetjmp(env,0)
#define _longjmp(env,val) longjmp(env,val)
/* Use TERMINFO instead of termcap */
#define TERMINFO
/*
* Send signals to subprocesses using characters.
*
*/
#define SIGNALS_VIA_CHARACTERS
/*
* Define HAVE_TERMIOS since this is POSIX,
* for terminal control. Prevent redundant inclusion of termio.h.
*/
#define HAVE_TERMIOS
#define NO_TERMIO
/*
* Use a Berkeley style sys/wait.h.
* This makes WIF* macros operate on structures instead of ints.
*/
#define _BSD_WAIT_FLAVOR
/*
* Use BSD and POSIX-style signals. This is crucial!
*/
/* #define SYSTEM_MALLOC */
/* MAKING_MAKEFILE must be defined in "ymakefile" before including config.h */
#ifndef NOT_C_CODE
/* Make sure signal.h is included so macros below don't mess with it. */
/* DG/UX include files prevent multiple inclusion. */
#include <signal.h>
/* but undefine the sigmask and sigpause macros since they will get
#define'd later. */
#undef sigmask
#undef sigpause
#define POSIX_SIGNALS
/* Define this if you use System 5 Release 4 Streams */
#define open sys_open
#define close sys_close
#define read sys_read
#define write sys_write
#define INTERRUPTIBLE_OPEN
#define INTERRUPTIBLE_CLOSE
/* can't hurt to define these, even though read/write should auto restart */
#define INTERRUPTIBLE_IO
/* Can't use sys_signal because then etc/server.c would need sysdep.o. */
extern struct sigaction act, oact;
#define signal(SIG,FUNC) berk_signal(SIG,FUNC)
#endif /* not NOT_C_CODE */
#ifndef __GNUC__
#error You must use GCC to compiler Emascs on DGUX
#endif
#define ORDINARY_LINK
#define START_FILES pre-crt0.o
#define LIB_GCC /usr/lib/gcc/libgcc.a
#ifdef _M88KBCS_TARGET
/* Karl Berry says: the environment
recommended by gcc (88/open, a.k.a. m88kbcs) doesn't support some system
functions, and gcc doesn't make it easy to switch environments. */
#define NO_GET_LOAD_AVG
#endif
/* definitions for xmakefile production */
#ifdef COFF
/* Define the following to use all of the available pty's. */
#define PTY_ITERATION \
for (c = 'p'; c < 't'; c++) \
for (i = 0; (((c == 'p') && (i < 64)) || ((c != 'p') && (i < 16))); i++)
#define PTY_NAME_SPRINTF \
if (c == 'p') \
sprintf (pty_name, "/dev/pty%c%d", c, i); \
else \
sprintf (pty_name, "/dev/pty%c%x", c, i);
#define PTY_TTY_NAME_SPRINTF \
if (c == 'p') \
sprintf (pty_name, "/dev/tty%c%d", c, i); \
else \
sprintf (pty_name, "/dev/tty%c%x", c, i);
#define C_DEBUG_SWITCH -g
#else /* not COFF */
/* We are generating ELF object format. This makes the system more
SVR4 like. */
#define SVR4
/* Pseudo-terminal support under SVR4 only loops to deal with errors. */
#define PTY_ITERATION for (i = 0; i < 1; i++)
/* This sets the name of the master side of the PTY. */
#define PTY_NAME_SPRINTF strcpy (pty_name, "/dev/ptmx");
/* This sets the name of the slave side of the PTY. On SysVr4,
grantpt(3) forks a subprocess, so keep sigchld_handler() from
intercepting that death. If any child but grantpt's should die
within, it should be caught after sigrelse(2). */
#define PTY_TTY_NAME_SPRINTF \
{ \
char *ptsname(), *ptyname; \
\
sigblock(sigmask(SIGCLD)); \
if (grantpt(fd) == -1) \
fatal("could not grant slave pty"); \
sigunblock(sigmask(SIGCLD)); \
if (unlockpt(fd) == -1) \
fatal("could not unlock slave pty"); \
if (!(ptyname = ptsname(fd))) \
fatal ("could not enable slave pty"); \
strncpy(pty_name, ptyname, sizeof(pty_name)); \
pty_name[sizeof(pty_name) - 1] = 0; \
}
/* Push various streams modules onto a PTY channel. */
#define SETUP_SLAVE_PTY \
if (ioctl (xforkin, I_PUSH, "ptem") == -1) \
fatal ("ioctl I_PUSH ptem", errno); \
if (ioctl (xforkin, I_PUSH, "ldterm") == -1) \
fatal ("ioctl I_PUSH ldterm", errno); \
if (ioctl (xforkin, I_PUSH, "ttcompat") == -1) \
fatal ("ioctl I_PUSH ttcompat", errno);
#ifdef __GNUC__
#define C_DEBUG_SWITCH -g -V2 -mversion-03.00 -mstandard
#endif
#endif /* ELF */
/* Extra stuff which probably should be someplace else but is here out
of expediency. */
#define LIB_X11_LIB -lX11
#define LIB_MOTIF -lXm -lgen
/* Process groups work in the traditional BSD manner. */
#define BSD_PGRPS
|