* w32fns.c (Fx_create_frame): Remove duplicate unwind_protect.
[bpt/emacs.git] / src / s / darwin.h
CommitLineData
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
5This file is part of GNU Emacs.
6
4b158629 7GNU Emacs is free software: you can redistribute it and/or modify
e0f712ba 8it under the terms of the GNU General Public License as published by
4b158629
GM
9the Free Software Foundation, either version 3 of the License, or
10(at your option) any later version.
e0f712ba
AC
11
12GNU Emacs is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
4b158629 18along 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) */