Commit | Line | Data |
---|---|---|
e0f712ba | 1 | /* System description header file for Darwin (Mac OS X). |
4b158629 GM |
2 | Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, |
3 | 2008 Free Software Foundation, Inc. | |
e0f712ba AC |
4 | |
5 | This file is part of GNU Emacs. | |
6 | ||
4b158629 | 7 | GNU Emacs is free software: you can redistribute it and/or modify |
e0f712ba | 8 | it under the terms of the GNU General Public License as published by |
4b158629 GM |
9 | the Free Software Foundation, either version 3 of the License, or |
10 | (at your option) any later version. | |
e0f712ba AC |
11 | |
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 | |
4b158629 | 18 | along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
e0f712ba AC |
19 | |
20 | ||
21 | /* | |
22 | * Define symbols to identify the version of Unix this is. | |
23 | * Define all the symbols that apply correctly. | |
24 | */ | |
25 | ||
e0f712ba AC |
26 | #define BSD4_2 |
27 | /* BSD4_3 and BSD4_4 are already defined in sys/param.h */ | |
28 | /* #define BSD4_3 */ | |
29 | /* #define BSD4_4 */ | |
30 | #define BSD_SYSTEM | |
31 | /* #define VMS */ | |
32 | ||
33 | /* MAC_OS is used to conditionally compile code common to both MAC_OS8 | |
34 | and MAC_OSX. */ | |
35 | #ifdef MAC_OSX | |
9794a8cd | 36 | #ifdef HAVE_CARBON |
e0f712ba | 37 | #define MAC_OS |
80ca7302 DN |
38 | /* We need a little extra space, see ../../lisp/loadup.el. */ |
39 | #define SYSTEM_PURESIZE_EXTRA 30000 | |
b7ea0894 | 40 | |
caf49fb0 DN |
41 | #endif |
42 | #endif | |
80ca7302 | 43 | |
e0f712ba AC |
44 | /* SYSTEM_TYPE should indicate the kind of system you are using. |
45 | It sets the Lisp variable system-type. */ | |
46 | ||
47 | #define SYSTEM_TYPE "darwin" | |
48 | ||
49 | /* NOMULTIPLEJOBS should be defined if your system's shell | |
50 | does not have "job control" (the ability to stop a program, | |
51 | run some other program, then continue the first one). */ | |
52 | ||
53 | /* #define NOMULTIPLEJOBS */ | |
54 | ||
55 | /* Emacs can read input using SIGIO and buffering characters itself, | |
56 | or using CBREAK mode and making C-g cause SIGINT. | |
57 | The choice is controlled by the variable interrupt_input. | |
58 | ||
59 | Define INTERRUPT_INPUT to make interrupt_input = 1 the default (use SIGIO) | |
60 | ||
61 | Emacs uses the presence or absence of the SIGIO and BROKEN_SIGIO macros | |
62 | to indicate whether or not signal-driven I/O is possible. It uses | |
63 | INTERRUPT_INPUT to decide whether to use it by default. | |
64 | ||
65 | SIGIO can be used only on systems that implement it (4.2 and 4.3). | |
66 | CBREAK mode has two disadvantages | |
67 | 1) At least in 4.2, it is impossible to handle the Meta key properly. | |
68 | I hear that in system V this problem does not exist. | |
69 | 2) Control-G causes output to be discarded. | |
70 | I do not know whether this can be fixed in system V. | |
71 | ||
72 | Another method of doing input is planned but not implemented. | |
73 | It would have Emacs fork off a separate process | |
74 | to read the input and send it to the true Emacs process | |
75 | through a pipe. */ | |
76 | ||
77 | #define INTERRUPT_INPUT | |
78 | ||
79 | /* Letter to use in finding device name of first pty, | |
80 | if system supports pty's. 'a' means it is /dev/ptya0 */ | |
81 | ||
82 | #define FIRST_PTY_LETTER 'p' | |
83 | ||
84 | /* | |
85 | * Define HAVE_TERMIOS if the system provides POSIX-style | |
86 | * functions and macros for terminal control. | |
87 | * | |
88 | * Define HAVE_TERMIO if the system provides sysV-style ioctls | |
89 | * for terminal control. | |
90 | * | |
91 | * Do not define both. HAVE_TERMIOS is preferred, if it is | |
92 | * supported on your system. | |
93 | */ | |
94 | ||
95 | #define HAVE_TERMIOS | |
96 | /* #define HAVE_TERMIO */ | |
97 | ||
98 | #define NO_TERMIO | |
99 | ||
100 | /* | |
101 | * Define HAVE_PTYS if the system supports pty devices. | |
d9e7c622 | 102 | * Note: PTYs are broken on darwin <6. Use at your own risk. |
e0f712ba AC |
103 | */ |
104 | ||
105 | #define HAVE_PTYS | |
106 | ||
d9e7c622 ST |
107 | /** |
108 | * PTYs only work correctly on Darwin 7 or higher. So make the | |
109 | * default for process-connection-type dependent on the kernel | |
110 | * version. | |
a15252fd | 111 | */ |
bb4c0e89 | 112 | #define MIN_PTY_KERNEL_VERSION '7' |
a15252fd | 113 | |
e0f712ba AC |
114 | /* |
115 | * Define NONSYSTEM_DIR_LIBRARY to make Emacs emulate | |
116 | * The 4.2 opendir, etc., library functions. | |
117 | */ | |
118 | ||
119 | /* #define NONSYSTEM_DIR_LIBRARY */ | |
120 | ||
121 | /* Define this symbol if your system has the functions bcopy, etc. */ | |
122 | ||
123 | #define BSTRING | |
124 | ||
125 | /* subprocesses should be defined if you want to | |
126 | have code for asynchronous subprocesses | |
127 | (as used in M-x compile and M-x shell). | |
128 | This is generally OS dependent, and not supported | |
129 | under most USG systems. */ | |
130 | ||
131 | #define subprocesses | |
132 | ||
133 | /* If your system uses COFF (Common Object File Format) then define the | |
134 | preprocessor symbol "COFF". */ | |
135 | ||
136 | /* #define COFF */ | |
137 | ||
138 | /* define MAIL_USE_FLOCK if the mailer uses flock | |
139 | to interlock access to /usr/spool/mail/$USER. | |
140 | The alternative is that a lock file named | |
141 | /usr/spool/mail/$USER.lock. */ | |
142 | ||
143 | #define MAIL_USE_FLOCK | |
144 | ||
145 | /* Define CLASH_DETECTION if you want lock files to be written | |
146 | so that Emacs can tell instantly when you try to modify | |
147 | a file that someone else has modified in his Emacs. */ | |
148 | ||
149 | #define CLASH_DETECTION | |
150 | ||
151 | /* Define this if your operating system declares signal handlers to | |
152 | have a type other than the usual. `The usual' is `void' for ANSI C | |
153 | systems (i.e. when the __STDC__ macro is defined), and `int' for | |
154 | pre-ANSI systems. If you're using GCC on an older system, __STDC__ | |
155 | will be defined, but the system's include files will still say that | |
156 | signal returns int or whatever; in situations like that, define | |
157 | this to be what the system's include files want. */ | |
158 | /* #define SIGTYPE int */ | |
159 | ||
160 | /* If the character used to separate elements of the executable path | |
161 | is not ':', #define this to be the appropriate character constant. */ | |
162 | /* #define SEPCHAR ':' */ | |
163 | ||
164 | /* Define this if the system can use mmap for buffer text allocation. */ | |
165 | /* #define USE_MMAP_FOR_BUFFERS 1 */ | |
166 | ||
167 | /* ============================================================ */ | |
168 | ||
169 | /* Here, add any special hacks needed | |
170 | to make Emacs work on this system. For example, | |
171 | you might define certain system call names that don't | |
172 | exist on your system, or that do different things on | |
173 | your system and must be used only through an encapsulation | |
174 | (Which you should place, by convention, in sysdep.c). */ | |
175 | ||
176 | /* Some compilers tend to put everything declared static | |
177 | into the initialized data area, which becomes pure after dumping Emacs. | |
178 | On these systems, you must #define static as nothing to foil this. | |
179 | Note that emacs carefully avoids static vars inside functions. */ | |
180 | ||
181 | /* #define static */ | |
182 | ||
183 | /* If the system's imake configuration file defines `NeedWidePrototypes' | |
184 | as `NO', we must define NARROWPROTO manually. Such a define is | |
177c0ea7 | 185 | generated in the Makefile generated by `xmkmf'. If we don't |
e0f712ba AC |
186 | define NARROWPROTO, we will see the wrong function prototypes |
187 | for X functions taking float or double parameters. */ | |
188 | ||
189 | /* #define NARROWPROTO 1 */ | |
190 | ||
191 | /* ============================================================ */ | |
192 | ||
193 | /* After adding support for a new system, modify the large case | |
194 | statement in the `configure' script to recognize reasonable | |
195 | configuration names, and add a description of the system to | |
196 | `etc/MACHINES'. | |
197 | ||
198 | If you've just fixed a problem in an existing configuration file, | |
199 | you should also check `etc/MACHINES' to make sure its descriptions | |
200 | of known problems in that configuration should be updated. */ | |
201 | ||
202 | ||
203 | /* Avoid the use of the name init_process (process.c) because it is | |
204 | also the name of a Mach system call. */ | |
205 | #define init_process emacs_init_process | |
206 | ||
e0f712ba AC |
207 | /* Used in dispnew.c. Copied from freebsd.h. */ |
208 | #define PENDING_OUTPUT_COUNT(FILE) ((FILE)->_p - (FILE)->_bf._base) | |
209 | ||
e0f712ba AC |
210 | /* System uses OXTABS instead of the expected TAB3. (Copied from |
211 | bsd386.h.) */ | |
212 | #define TAB3 OXTABS | |
213 | ||
214 | /* Darwin ld insists on the use of malloc routines in the System | |
215 | framework. */ | |
216 | #define SYSTEM_MALLOC | |
217 | ||
218 | /* Define HAVE_SOCKETS if system supports 4.2-compatible sockets. */ | |
219 | #define HAVE_SOCKETS | |
220 | ||
fc7a70cc ST |
221 | /* In Carbon, asynchronous I/O (using SIGIO) can't be used for window |
222 | events because they don't come from sockets, even though it works | |
223 | fine on tty's. */ | |
224 | #ifdef HAVE_CARBON | |
225 | #define NO_SOCK_SIGIO | |
226 | #endif | |
227 | ||
e0f712ba | 228 | /* Extra initialization calls in main for Mac OS X system type. */ |
9794a8cd | 229 | #ifdef HAVE_CARBON |
e0f712ba | 230 | #define SYMS_SYSTEM syms_of_mac() |
9794a8cd | 231 | #endif |
e0f712ba AC |
232 | |
233 | /* Definitions for how to dump. Copied from nextstep.h. */ | |
234 | ||
235 | #define UNEXEC unexmacosx.o | |
236 | ||
237 | #define START_FILES pre-crt0.o | |
238 | ||
239 | /* start_of_text isn't actually used, so make it compile without error. */ | |
240 | #define TEXT_START (0) | |
241 | ||
242 | /* This seems to be right for end_of_text, but it may not be used anyway. */ | |
243 | #define TEXT_END get_etext() | |
244 | ||
245 | /* This seems to be right for end_of_data, but it may not be used anyway. */ | |
246 | #define DATA_END get_edata() | |
247 | ||
248 | /* Definitions for how to compile & link. */ | |
249 | ||
bb4c0e89 YM |
250 | /* Indicate that we are compiling for Mac OS X. */ |
251 | #define C_SWITCH_SYSTEM -fpascal-strings -DMAC_OSX | |
e0f712ba | 252 | |
50eff40f YM |
253 | #ifdef HAVE_CARBON |
254 | ||
255 | #ifdef HAVE_AVAILABILITYMACROS_H | |
256 | #include <AvailabilityMacros.h> | |
257 | #endif | |
258 | ||
259 | /* Whether to use the Image I/O framework for reading images. */ | |
260 | #ifndef USE_MAC_IMAGE_IO | |
261 | #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1040 && (MAC_OS_X_VERSION_MIN_REQUIRED >= 1040 || MAC_OS_X_VERSION_MIN_REQUIRED < 1020) | |
262 | #define USE_MAC_IMAGE_IO 1 | |
263 | #endif | |
264 | #endif | |
265 | ||
266 | /* If the Image I/O framework is not used, fall back on QuickTime. */ | |
267 | #if USE_MAC_IMAGE_IO | |
268 | #define LIBS_IMAGE | |
269 | #else | |
270 | #define LIBS_IMAGE -framework QuickTime | |
271 | #endif | |
272 | ||
273 | #endif /* HAVE_CARBON */ | |
274 | ||
640a0770 ST |
275 | /* Link in the Carbon lib. */ |
276 | #ifdef HAVE_CARBON | |
50eff40f | 277 | #define LIBS_CARBON -framework Carbon LIBS_IMAGE |
640a0770 | 278 | #else |
29b585db | 279 | #define LIBS_CARBON |
640a0770 ST |
280 | #endif |
281 | ||
282 | /* The -headerpad option tells ld (see man page) to leave room at the | |
283 | end of the header for adding load commands. Needed for dumping. | |
284 | 0x690 is the total size of 30 segment load commands (at 56 | |
285 | each). */ | |
286 | #define LD_SWITCH_SYSTEM_TEMACS -prebind LIBS_CARBON -Xlinker -headerpad -Xlinker 690 | |
e0f712ba AC |
287 | |
288 | #define C_SWITCH_SYSTEM_TEMACS -Dtemacs | |
289 | ||
f00691a3 AC |
290 | /* The ncurses library has been moved out of the System framework in |
291 | Mac OS X 10.2. So if ./configure detects it, set the command-line | |
292 | option to use it. */ | |
293 | #ifdef HAVE_LIBNCURSES | |
294 | #define LIBS_TERMCAP -lncurses | |
ad8d730c AC |
295 | /* This prevents crashes when running Emacs in Terminal.app under |
296 | 10.2. */ | |
297 | #define TERMINFO | |
f00691a3 AC |
298 | #endif |
299 | ||
e0f712ba AC |
300 | /* Link this program just by running cc. */ |
301 | #define ORDINARY_LINK | |
302 | ||
303 | /* We don't have a g library, so override the -lg LIBS_DEBUG switch. */ | |
304 | #define LIBS_DEBUG | |
305 | ||
306 | /* Adding -lm confuses the dynamic linker, so omit it. */ | |
307 | #define LIB_MATH | |
308 | ||
309 | /* Tell src/Makefile.in to create files in the Mac OS X application | |
310 | bundle mac/Emacs.app. */ | |
9794a8cd | 311 | #ifdef HAVE_CARBON |
e0f712ba | 312 | #define OTHER_FILES macosx-app |
9794a8cd | 313 | #endif |
e0f712ba AC |
314 | |
315 | ||
316 | /* Define the following so emacs symbols will not conflict with those | |
317 | in the System framework. Otherwise -prebind will not work. */ | |
318 | ||
319 | /* Do not define abort in emacs.c. */ | |
320 | #define NO_ABORT | |
321 | ||
322 | /* Do not define matherr in floatfns.c. */ | |
323 | #define NO_MATHERR | |
324 | ||
325 | ||
511ca371 AC |
326 | /* The following solves the problem that Emacs hangs when evaluating |
327 | (make-comint "test0" "/nodir/nofile" nil "") when /nodir/nofile | |
328 | does not exist. */ | |
329 | #undef HAVE_WORKING_VFORK | |
330 | #define vfork fork | |
a7a4eb95 YM |
331 | |
332 | /* Don't close pty in process.c to make it as controlling terminal. | |
333 | It is already a controlling terminal of subprocess, because we did | |
334 | ioctl TIOCSCTTY. */ | |
5cb724f0 | 335 | #define DONT_REOPEN_PTY |
09740ad8 | 336 | |
e0f712ba AC |
337 | #ifdef temacs |
338 | #define malloc unexec_malloc | |
339 | #define realloc unexec_realloc | |
340 | #define free unexec_free | |
341 | #endif | |
8030369c | 342 | |
7a262394 SM |
343 | /* This makes create_process in process.c save and restore signal |
344 | handlers correctly. Suggested by Nozomu Ando.*/ | |
345 | #define POSIX_SIGNALS | |
346 | ||
8030369c AC |
347 | /* Reroute calls to SELECT to the version defined in mac.c to fix the |
348 | problem of Emacs requiring an extra return to be typed to start | |
349 | working when started from the command line. */ | |
a6311b2f | 350 | #if defined (HAVE_CARBON) && (defined (emacs) || defined (temacs)) |
8030369c AC |
351 | #define select sys_select |
352 | #endif | |
ab5796a9 | 353 | |
3f080e4e AC |
354 | /* Use the GC_MAKE_GCPROS_NOOPS (see lisp.h) method for marking the |
355 | stack. */ | |
356 | #define GC_MARK_STACK GC_MAKE_GCPROS_NOOPS | |
357 | ||
ab5796a9 MB |
358 | /* arch-tag: 481d443d-4f89-43ea-b5fb-49706d95fa41 |
359 | (do not change this comment) */ |