Initial revision
[bpt/emacs.git] / src / s / irix3-3.h
1 /* Definitions file for GNU Emacs running on Silicon Graphics Irix system 3.3.
2 Copyright (C) 1987,1990 Free Software Foundation, Inc.
3
4 This file is part of GNU Emacs.
5
6 GNU Emacs is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 1, or (at your option)
9 any later version.
10
11 GNU Emacs is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GNU Emacs; see the file COPYING. If not, write to
18 the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
19
20
21 /*
22 * Define symbols to identify the version of Unix this is.
23 * Define all the symbols that apply correctly.
24 */
25
26 #define USG
27 #define USG5
28 #define IRIS
29
30 /* SYSTEM_TYPE should indicate the kind of system you are using.
31 It sets the Lisp variable system-type. */
32
33 #define SYSTEM_TYPE "irix"
34
35 /* nomultiplejobs should be defined if your system's shell
36 does not have "job control" (the ability to stop a program,
37 run some other program, then continue the first one). */
38
39 /* #define NOMULTIPLEJOBS */
40
41 /* Default is to set interrupt_input to 0: don't do input buffering within Emacs */
42
43 /* #define INTERRUPT_INPUT */
44
45 /* Letter to use in finding device name of first pty,
46 if system supports pty's. 'a' means it is /dev/ptya0 */
47
48 #define FIRST_PTY_LETTER 'a'
49
50 /*
51 * Define HAVE_TERMIO if the system provides sysV-style ioctls
52 * for terminal control.
53 */
54
55 #define HAVE_TERMIO
56
57 /*
58 * Define HAVE_TIMEVAL if the system supports the BSD style clock values.
59 * Look in <sys/time.h> for a timeval structure.
60 */
61
62 #define HAVE_TIMEVAL
63
64 /* `utime' system call doesn't understand timevals. */
65
66 #define IRIS_UTIME
67
68 /*
69 * Define HAVE_SELECT if the system supports the `select' system call.
70 */
71
72 #define HAVE_SELECT
73
74 /*
75 * Define HAVE_PTYS if the system supports pty devices.
76 */
77
78 #define HAVE_PTYS
79
80 /* Define HAVE_SOCKETS if system supports 4.2-compatible sockets. */
81
82 #define HAVE_SOCKETS
83
84 /*
85 * Define NONSYSTEM_DIR_LIBRARY to make Emacs emulate
86 * The 4.2 opendir, etc., library functions.
87 */
88
89 /* #define NONSYSTEM_DIR_LIBRARY */
90
91 /* Define this symbol if your system has the functions bcopy, etc. */
92
93 #define BSTRING
94
95 /* subprocesses should be defined if you want to
96 have code for asynchronous subprocesses
97 (as used in M-x compile and M-x shell).
98 This is generally OS dependent, and not supported
99 under most USG systems. */
100
101 #define subprocesses
102
103 /* If your system uses COFF (Common Object File Format) then define the
104 preprocessor symbol "COFF". */
105
106 /* #define COFF */
107
108 /* define MAIL_USE_FLOCK if the mailer uses flock
109 to interlock access to /usr/spool/mail/$USER.
110 The alternative is that a lock file named
111 /usr/spool/mail/$USER.lock. */
112
113 /* #define MAIL_USE_FLOCK */
114
115 /* Define CLASH_DETECTION if you want lock files to be written
116 so that Emacs can tell instantly when you try to modify
117 a file that someone else has modified in his Emacs. */
118
119 /* #define CLASH_DETECTION */
120
121 /* We use the Berkeley (and usg5.2.2) interface to nlist. */
122
123 #define NLIST_STRUCT
124
125 /* The file containing the kernel's symbol table is called /unix. */
126
127 #define KERNEL_FILE "/unix"
128
129 /* The symbol in the kernel where the load average is found
130 is named _avenrun. */
131
132 #define LDAV_SYMBOL "avenrun"
133
134 \f
135 /* setjmp and longjmp can safely replace _setjmp and _longjmp,
136 but they will run slower. */
137
138 #define _setjmp setjmp
139 #define _longjmp longjmp
140
141 /* On USG systems the system calls are interruptable by signals
142 that the user program has elected to catch. Thus the system call
143 must be retried in these cases. To handle this without massive
144 changes in the source code, we remap the standard system call names
145 to names for our own functions in sysdep.c that do the system call
146 with retries. */
147
148 #define read sys_read
149 #define open sys_open
150 #define write sys_write
151
152 #define INTERRUPTIBLE_OPEN
153 #define INTERRUPTIBLE_IO
154
155 /* On USG systems these have different names */
156
157 #define index strchr
158 #define rindex strrchr
159
160 /* USG systems tend to put everything declared static
161 into the initialized data area, which becomes pure after dumping Emacs.
162 Foil this. Emacs carefully avoids static vars inside functions. */
163
164 /* #define static */
165
166 /* This is how to get the device name of the tty end of a pty. */
167 #define PTY_TTY_NAME_SPRINTF \
168 sprintf (ptyname, "/dev/ttyq%d", minor (stb.st_rdev));
169
170
171 /* getwd is defined. */
172
173 #define HAVE_GETWD
174
175 #define HAVE_SYSVIPC