* mark.texi (Mark): Further clarifications.
[emacs.git] / src / s / darwin.h
blobda223e9a41c2eeef6c3a400feedc9b3793263e59
1 /* System description header file for Darwin (Mac OS X).
2 Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007,
3 2008, 2009 Free Software Foundation, Inc.
5 This file is part of GNU Emacs.
7 GNU Emacs is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
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.
17 You should have received a copy of the GNU General Public License
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
22 * Define symbols to identify the version of Unix this is.
23 * Define all the symbols that apply correctly.
26 #define BSD4_2
27 /* BSD4_3 and BSD4_4 are already defined in sys/param.h */
28 #define BSD_SYSTEM
30 /* More specific than the above two. We cannot use __APPLE__ as this
31 may not be defined on non-OSX Darwin, and we cannot define DARWIN
32 here because Panther and lower CoreFoundation.h uses DARWIN to
33 distinguish OS X from pure Darwin. */
35 #define DARWIN_OS
38 /* SYSTEM_TYPE should indicate the kind of system you are using.
39 It sets the Lisp variable system-type. */
41 #define SYSTEM_TYPE "darwin"
43 /* Emacs can read input using SIGIO and buffering characters itself,
44 or using CBREAK mode and making C-g cause SIGINT.
45 The choice is controlled by the variable interrupt_input.
47 Define INTERRUPT_INPUT to make interrupt_input = 1 the default (use SIGIO)
49 Emacs uses the presence or absence of the SIGIO and BROKEN_SIGIO macros
50 to indicate whether or not signal-driven I/O is possible. It uses
51 INTERRUPT_INPUT to decide whether to use it by default.
53 SIGIO can be used only on systems that implement it (4.2 and 4.3).
54 CBREAK mode has two disadvantages
55 1) At least in 4.2, it is impossible to handle the Meta key properly.
56 I hear that in system V this problem does not exist.
57 2) Control-G causes output to be discarded.
58 I do not know whether this can be fixed in system V.
60 Another method of doing input is planned but not implemented.
61 It would have Emacs fork off a separate process
62 to read the input and send it to the true Emacs process
63 through a pipe. */
65 #define INTERRUPT_INPUT
67 /* Letter to use in finding device name of first pty,
68 if system supports pty's. 'a' means it is /dev/ptya0 */
70 #define FIRST_PTY_LETTER 'p'
73 * Define HAVE_TERMIOS if the system provides POSIX-style
74 * functions and macros for terminal control.
76 * Define HAVE_TERMIO if the system provides sysV-style ioctls
77 * for terminal control.
79 * Do not define both. HAVE_TERMIOS is preferred, if it is
80 * supported on your system.
83 #define HAVE_TERMIOS
85 #define NO_TERMIO
88 * Define HAVE_PTYS if the system supports pty devices.
89 * Note: PTYs are broken on darwin <6. Use at your own risk.
92 #define HAVE_PTYS
94 /**
95 * PTYs only work correctly on Darwin 7 or higher. So make the
96 * default for process-connection-type dependent on the kernel
97 * version.
99 #define MIN_PTY_KERNEL_VERSION '7'
101 /* Define this symbol if your system has the functions bcopy, etc. */
103 #define BSTRING
105 /* define MAIL_USE_FLOCK if the mailer uses flock
106 to interlock access to /usr/spool/mail/$USER.
107 The alternative is that a lock file named
108 /usr/spool/mail/$USER.lock. */
110 #define MAIL_USE_FLOCK
112 /* Define CLASH_DETECTION if you want lock files to be written
113 so that Emacs can tell instantly when you try to modify
114 a file that someone else has modified in his Emacs. */
116 #define CLASH_DETECTION
118 /* Avoid the use of the name init_process (process.c) because it is
119 also the name of a Mach system call. */
120 #define init_process emacs_init_process
122 /* Used in dispnew.c. Copied from freebsd.h. */
123 #define PENDING_OUTPUT_COUNT(FILE) ((FILE)->_p - (FILE)->_bf._base)
125 /* System uses OXTABS instead of the expected TAB3. (Copied from
126 bsd386.h.) */
127 #define TAB3 OXTABS
129 /* Darwin ld insists on the use of malloc routines in the System
130 framework. */
131 #define SYSTEM_MALLOC
133 /* Define HAVE_SOCKETS if system supports 4.2-compatible sockets. */
134 #define HAVE_SOCKETS
136 /* Definitions for how to dump. Copied from nextstep.h. */
138 #define UNEXEC unexmacosx.o
140 #define START_FILES pre-crt0.o
142 /* start_of_text isn't actually used, so make it compile without error. */
143 #define TEXT_START (0)
145 /* Definitions for how to compile & link. */
147 #ifdef HAVE_NS
148 #define LIBS_NSGUI -framework AppKit
149 #define SYSTEM_PURESIZE_EXTRA 200000
150 #define HEADERPAD_EXTRA 6C8
151 #else /* !HAVE_NS */
152 #define LIBS_NSGUI
153 #define HEADERPAD_EXTRA 690
154 #endif /* !HAVE_NS */
156 /* On Darwin, res_init appears not to be useful: see bug#562 and
157 http://lists.gnu.org/archive/html/emacs-devel/2007-11/msg01467.html */
159 #undef HAVE_RES_INIT
160 #undef HAVE_LIBRESOLV
162 /* The -headerpad option tells ld (see man page) to leave room at the
163 end of the header for adding load commands. Needed for dumping.
164 0x690 is the total size of 30 segment load commands (at 56
165 each); under Cocoa 31 commands are required. */
166 #define LD_SWITCH_SYSTEM_TEMACS -prebind LIBS_NSGUI -Xlinker -headerpad -Xlinker HEADERPAD_EXTRA
168 #define C_SWITCH_SYSTEM_TEMACS -Dtemacs
170 #ifdef temacs
171 #define malloc unexec_malloc
172 #define realloc unexec_realloc
173 #define free unexec_free
174 #endif
176 /* The ncurses library has been moved out of the System framework in
177 Mac OS X 10.2. So if ./configure detects it, set the command-line
178 option to use it. */
179 #ifdef HAVE_LIBNCURSES
180 #define LIBS_TERMCAP -lncurses
181 /* This prevents crashes when running Emacs in Terminal.app under
182 10.2. */
183 #define TERMINFO
184 #endif
186 /* Link this program just by running cc. */
187 #define ORDINARY_LINK
189 /* We don't have a g library, so override the -lg LIBS_DEBUG switch. */
190 #define LIBS_DEBUG
192 /* Adding -lm confuses the dynamic linker, so omit it. */
193 #define LIB_MATH
195 /* Define the following so emacs symbols will not conflict with those
196 in the System framework. Otherwise -prebind will not work. */
198 /* Do not define abort in emacs.c. */
199 #define NO_ABORT
201 /* Do not define matherr in floatfns.c. */
202 #define NO_MATHERR
204 /* The following solves the problem that Emacs hangs when evaluating
205 (make-comint "test0" "/nodir/nofile" nil "") when /nodir/nofile
206 does not exist. Also, setsid is not allowed in the vfork child's
207 context as of Darwin 9/Mac OS X 10.5. */
208 #undef HAVE_WORKING_VFORK
209 #define vfork fork
211 /* Don't close pty in process.c to make it as controlling terminal.
212 It is already a controlling terminal of subprocess, because we did
213 ioctl TIOCSCTTY. */
214 #define DONT_REOPEN_PTY
216 /* This makes create_process in process.c save and restore signal
217 handlers correctly. Suggested by Nozomu Ando.*/
218 #define POSIX_SIGNALS
220 /* Use the GC_MAKE_GCPROS_NOOPS (see lisp.h) method for marking the
221 stack. */
222 #define GC_MARK_STACK GC_MAKE_GCPROS_NOOPS
224 /* arch-tag: 481d443d-4f89-43ea-b5fb-49706d95fa41
225 (do not change this comment) */