(w32_pass_multimedia_buttons_to_system): New user option.
[bpt/emacs.git] / src / s / ms-w32.h
CommitLineData
95ed0025 1/* System description file for Windows NT.
429ab54e
GM
2 Copyright (C) 1993, 1994, 1995, 2001, 2002, 2003, 2004,
3 2005, 2006, 2007 Free Software Foundation, Inc.
95ed0025
RS
4
5This file is part of GNU Emacs.
6
7GNU Emacs is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
4a9f99bd 9the Free Software Foundation; either version 3, or (at your option)
95ed0025
RS
10any later version.
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
18along with GNU Emacs; see the file COPYING. If not, write to
364c38d3
LK
19the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20Boston, MA 02110-1301, USA. */
95ed0025
RS
21
22/*
23 * Define symbols to identify the version of Unix this is.
24 * Define all the symbols that apply correctly.
25 */
26
27/* #define UNIPLUS */
28/* #define USG5 */
29/* #define USG */
30/* #define HPUX */
31/* #define UMAX */
32/* #define BSD4_1 */
33/* #define BSD4_2 */
34/* #define BSD4_3 */
8e4c450d 35/* #define BSD_SYSTEM */
95ed0025
RS
36/* #define VMS */
37#ifndef WINDOWSNT
38#define WINDOWSNT
39#endif
40#ifndef DOS_NT
41#define DOS_NT /* MSDOS or WINDOWSNT */
42#endif
43
3360970a
KH
44/* If you are compiling with a non-C calling convention but need to
45 declare vararg routines differently, put it here */
46#define _VARARGS_ __cdecl
47
48/* If you are providing a function to something that will call the
49 function back (like a signal handler and signal, or main) its calling
50 convention must be whatever standard the libraries expect */
51#define _CALLBACK_ __cdecl
52
95ed0025
RS
53/* SYSTEM_TYPE should indicate the kind of system you are using.
54 It sets the Lisp variable system-type. */
55
56#define SYSTEM_TYPE "windows-nt"
57#define SYMS_SYSTEM syms_of_ntterm ()
58
124abc74 59#define NO_MATHERR 1
95ed0025
RS
60
61/* NOMULTIPLEJOBS should be defined if your system's shell
62 does not have "job control" (the ability to stop a program,
63 run some other program, then continue the first one). */
64
124abc74 65/* #define NOMULTIPLEJOBS 1 */
95ed0025
RS
66
67/* Emacs can read input using SIGIO and buffering characters itself,
68 or using CBREAK mode and making C-g cause SIGINT.
69 The choice is controlled by the variable interrupt_input.
70
71 Define INTERRUPT_INPUT to make interrupt_input = 1 the default (use SIGIO)
72
73 Emacs uses the presence or absence of the SIGIO macro to indicate
74 whether or not signal-driven I/O is possible. It uses
75 INTERRUPT_INPUT to decide whether to use it by default.
76
77 SIGIO can be used only on systems that implement it (4.2 and 4.3).
78 CBREAK mode has two disadvantages
79 1) At least in 4.2, it is impossible to handle the Meta key properly.
80 I hear that in system V this problem does not exist.
81 2) Control-G causes output to be discarded.
82 I do not know whether this can be fixed in system V.
83
84 Another method of doing input is planned but not implemented.
85 It would have Emacs fork off a separate process
86 to read the input and send it to the true Emacs process
87 through a pipe. */
88
124abc74 89/* #define INTERRUPT_INPUT 1 */
95ed0025
RS
90
91/* Letter to use in finding device name of first pty,
92 if system supports pty's. 'a' means it is /dev/ptya0 */
93
94#define FIRST_PTY_LETTER 'a'
95
96/*
97 * Define HAVE_TERMIOS if the system provides POSIX-style
98 * functions and macros for terminal control.
99 *
100 * Define HAVE_TERMIO if the system provides sysV-style ioctls
101 * for terminal control.
102 *
103 * Do not define both. HAVE_TERMIOS is preferred, if it is
104 * supported on your system.
105 */
106
124abc74
AI
107/* #define HAVE_TERMIOS 1 */
108/* #define HAVE_TERMIO 1 */
95ed0025
RS
109
110/*
111 * Define HAVE_TIMEVAL if the system supports the BSD style clock values.
112 * Look in <sys/time.h> for a timeval structure.
113 */
114
124abc74 115#define HAVE_TIMEVAL 1
95ed0025
RS
116
117/*
118 * Define HAVE_SELECT if the system supports the `select' system call.
119 */
120
124abc74 121/* #define HAVE_SELECT 1 */
95ed0025
RS
122
123/*
124 * Define HAVE_PTYS if the system supports pty devices.
125 */
126
124abc74 127/* #define HAVE_PTYS 1 */
95ed0025
RS
128
129/*
130 * Define NONSYSTEM_DIR_LIBRARY to make Emacs emulate
131 * The 4.2 opendir, etc., library functions.
132 */
133
134/* #define NONSYSTEM_DIR_LIBRARY */
135
4e36126c
GV
136/* NT supports Winsock which is close enough (with some hacks) */
137
124abc74 138#define HAVE_SOCKETS 1
4e36126c 139
69fd7dbf
KS
140/* But our select implementation doesn't allow us to make non-blocking
141 connects. So until that is fixed, this is necessary: */
142
143#define BROKEN_NON_BLOCKING_CONNECT 1
144
401ea527
KS
145/* And the select implementation does 1-byte read-ahead waiting
146 for received packets, so datagrams are broken too. */
147
148#define BROKEN_DATAGRAM_SOCKETS 1
149
95ed0025
RS
150/* Define this symbol if your system has the functions bcopy, etc. */
151
152#define BSTRING
153#define bzero(b, l) memset(b, 0, l)
7f470eff 154#define bcopy(s, d, l) memmove(d, s, l)
95ed0025
RS
155#define bcmp(a, b, l) memcmp(a, b, l)
156
7f470eff 157/* bcopy (aka memmove aka memcpy at least on x86) under MSVC is quite safe */
124abc74 158#define GAP_USE_BCOPY 1
7f470eff
GV
159#define BCOPY_UPWARD_SAFE 1
160#define BCOPY_DOWNWARD_SAFE 1
161
95ed0025
RS
162/* subprocesses should be defined if you want to
163 have code for asynchronous subprocesses
164 (as used in M-x compile and M-x shell).
165 This is generally OS dependent, and not supported
166 under most USG systems. */
167
124abc74 168#define subprocesses 1
95ed0025
RS
169
170/* If your system uses COFF (Common Object File Format) then define the
171 preprocessor symbol "COFF". */
172
124abc74 173#define COFF 1
95ed0025
RS
174
175/* define MAIL_USE_FLOCK if the mailer uses flock
176 to interlock access to /usr/spool/mail/$USER.
177 The alternative is that a lock file named
178 /usr/spool/mail/$USER.lock. */
179
180/* #define MAIL_USE_FLOCK */
124abc74
AI
181#define MAIL_USE_POP 1
182#define MAIL_USE_SYSTEM_LOCK 1
95ed0025
RS
183
184/* Define CLASH_DETECTION if you want lock files to be written
185 so that Emacs can tell instantly when you try to modify
186 a file that someone else has modified in his Emacs. */
187
124abc74 188/* #define CLASH_DETECTION 1 */
95ed0025
RS
189
190/* Define this if your operating system declares signal handlers to
191 have a type other than the usual. `The usual' is `void' for ANSI C
192 systems (i.e. when the __STDC__ macro is defined), and `int' for
193 pre-ANSI systems. If you're using GCC on an older system, __STDC__
194 will be defined, but the system's include files will still say that
195 signal returns int or whatever; in situations like that, define
196 this to be what the system's include files want. */
197/* #define SIGTYPE int */
198
199/* If the character used to separate elements of the executable path
200 is not ':', #define this to be the appropriate character constant. */
201#define SEPCHAR ';'
202
cc48c6e7
AI
203#define ORDINARY_LINK 1
204
95ed0025
RS
205/* ============================================================ */
206
207/* Here, add any special hacks needed
208 to make Emacs work on this system. For example,
209 you might define certain system call names that don't
210 exist on your system, or that do different things on
211 your system and must be used only through an encapsulation
212 (Which you should place, by convention, in sysdep.c). */
213
95ed0025 214/* Define this to be the separator between path elements */
4e36126c 215#define DIRECTORY_SEP XINT (Vdirectory_sep_char)
95ed0025
RS
216
217/* Define this to be the separator between devices and paths */
218#define DEVICE_SEP ':'
219
220/* We'll support either convention on NT. */
221#define IS_DIRECTORY_SEP(_c_) ((_c_) == '/' || (_c_) == '\\')
222#define IS_ANY_SEP(_c_) (IS_DIRECTORY_SEP (_c_) || IS_DEVICE_SEP (_c_))
223
224/* The null device on Windows NT. */
225#define NULL_DEVICE "NUL:"
95ed0025
RS
226
227#ifndef MAXPATHLEN
228#define MAXPATHLEN _MAX_PATH
229#endif
230
f60ae425 231#define HAVE_SOUND 1
124abc74 232#define LISP_FLOAT_TYPE 1
3360970a 233
2a741506 234#undef HAVE_SYS_SELECT_H
124abc74
AI
235#define HAVE_SYS_TIMEB_H 1
236#define HAVE_SYS_TIME_H 1
237#define HAVE_UNISTD_H 1
2a741506
GV
238#undef HAVE_UTIME_H
239#undef HAVE_LINUX_VERSION_H
240#undef HAVE_SYS_SYSTEMINFO_H
241#undef HAVE_TERMIOS_H
242#define HAVE_LIMITS_H 1
124abc74 243#define HAVE_STRING_H 1
c8f7c76b 244#define HAVE_STDLIB_H 1
47539b85 245#define HAVE_PWD_H 1
2a741506 246#define STDC_HEADERS 1
124abc74 247#define TIME_WITH_SYS_TIME 1
4e36126c 248
124abc74
AI
249#define HAVE_GETTIMEOFDAY 1
250#define HAVE_GETHOSTNAME 1
2a741506 251#undef HAVE_GETDOMAINNAME
124abc74
AI
252#define HAVE_DUP2 1
253#define HAVE_RENAME 1
254#define HAVE_CLOSEDIR 1
a5a7d30f 255#define HAVE_FSYNC 1 /* fsync is called _commit in MSVC. */
4e36126c 256
2a741506
GV
257#undef TM_IN_SYS_TIME
258#undef HAVE_TM_ZONE
4e36126c 259
124abc74 260#define HAVE_LONG_FILE_NAMES 1
4e36126c 261
124abc74
AI
262#define HAVE_MKDIR 1
263#define HAVE_RMDIR 1
264#define HAVE_RANDOM 1
2a741506
GV
265#undef HAVE_SYSINFO
266#undef HAVE_LRAND48
124abc74
AI
267#define HAVE_BCOPY 1
268#define HAVE_BCMP 1
269#define HAVE_LOGB 1
270#define HAVE_FREXP 1
271#define HAVE_FMOD 1
2a741506
GV
272#undef HAVE_RINT
273#undef HAVE_CBRT
124abc74 274#define HAVE_FTIME 1
2a741506
GV
275#undef HAVE_RES_INIT /* For -lresolv on Suns. */
276#undef HAVE_SETSID
277#undef HAVE_FPATHCONF
7b7262a7 278#define HAVE_SELECT 1
2a741506
GV
279#define HAVE_MKTIME 1
280#undef HAVE_EUIDACCESS
124abc74 281#define HAVE_GETPAGESIZE 1
2a741506 282#define HAVE_TZSET 1
124abc74 283#define HAVE_SETLOCALE 1
2a741506
GV
284#undef HAVE_UTIMES
285#undef HAVE_SETRLIMIT
286#undef HAVE_SETPGID
287#undef HAVE_GETCWD
124abc74 288#define HAVE_SHUTDOWN 1
b2140d4b 289#define HAVE_STRFTIME 1
2a741506 290
dabe36a8 291#define LOCALTIME_CACHE
99674eec 292#define HAVE_INET_SOCKETS 1
2a741506
GV
293
294#undef HAVE_AIX_SMT_EXP
295
296/* Define if you have the ANSI `strerror' function.
297 Otherwise you must have the variable `char *sys_errlist[]'. */
124abc74 298#define HAVE_STRERROR 1
2a741506
GV
299
300/* Define if `struct utimbuf' is declared by <utime.h>. */
301#undef HAVE_STRUCT_UTIMBUF
4e36126c 302
124abc74
AI
303#define HAVE_MOUSE 1
304#define HAVE_H_ERRNO 1
1cd47f14 305
a4926668
JR
306#define MULTI_KBOARD 1
307
4a1ba222 308#ifdef HAVE_NTGUI
124abc74
AI
309#define HAVE_WINDOW_SYSTEM 1
310#define HAVE_FACES 1
311#define HAVE_MENUS 1
4a1ba222
GV
312#endif
313
1cd47f14 314#define MODE_LINE_BINARY_TEXT(_b_) (NILP ((_b_)->buffer_file_type) ? "T" : "B")
95ed0025 315
4e36126c
GV
316/* get some redefinitions in place */
317
124abc74
AI
318#ifdef emacs
319
a14724c8 320/* calls that are emulated or shadowed */
7f470eff 321#undef access
4e36126c 322#define access sys_access
7f470eff 323#undef chdir
4e36126c 324#define chdir sys_chdir
7f470eff 325#undef chmod
4e36126c 326#define chmod sys_chmod
0e20b3a3 327#define chown sys_chown
7f470eff 328#undef close
4e36126c 329#define close sys_close
7f470eff 330#undef creat
4e36126c
GV
331#define creat sys_creat
332#define ctime sys_ctime
7f470eff 333#undef dup
4e36126c 334#define dup sys_dup
7f470eff 335#undef dup2
4e36126c
GV
336#define dup2 sys_dup2
337#define fopen sys_fopen
338#define link sys_link
339#define mkdir sys_mkdir
7f470eff 340#undef mktemp
4e36126c 341#define mktemp sys_mktemp
7f470eff 342#undef open
4e36126c
GV
343#define open sys_open
344#define pipe sys_pipe
7f470eff 345#undef read
4e36126c
GV
346#define read sys_read
347#define rename sys_rename
348#define rmdir sys_rmdir
349#define select sys_select
350#define sleep sys_sleep
a14724c8 351#define strerror sys_strerror
7f470eff 352#undef unlink
4e36126c 353#define unlink sys_unlink
7f470eff 354#undef write
4e36126c
GV
355#define write sys_write
356
4e36126c
GV
357/* subprocess calls that are emulated */
358#define spawnve sys_spawnve
359#define wait sys_wait
360#define kill sys_kill
361#define signal sys_signal
362
124abc74
AI
363#endif /* emacs */
364
4e36126c
GV
365/* map to MSVC names */
366#define execlp _execlp
367#define execvp _execvp
368#define fcloseall _fcloseall
369#define fdopen _fdopen
370#define fgetchar _fgetchar
23bf9efb 371#ifndef fileno
4e36126c 372#define fileno _fileno
23bf9efb 373#endif
4e36126c
GV
374#define flushall _flushall
375#define fputchar _fputchar
a5a7d30f
AI
376#define fsync _commit
377#define ftruncate _chsize
4e36126c
GV
378#define getw _getw
379#define getpid _getpid
9b67f3aa
EZ
380#ifdef _MSC_VER
381typedef int pid_t;
382#endif
4e36126c
GV
383#define isatty _isatty
384#define logb _logb
385#define _longjmp longjmp
386#define lseek _lseek
387#define popen _popen
388#define pclose _pclose
389#define putw _putw
390#define umask _umask
719072f5 391#define utimbuf _utimbuf
4e36126c
GV
392#define index strchr
393#define rindex strrchr
bfba227f
AI
394#define strdup _strdup
395#define strupr _strupr
396#define strnicmp _strnicmp
397#define stricmp _stricmp
398#define tzset _tzset
e37b3faf
JR
399
400#if !defined (_MSC_VER) || (_MSC_VER < 1400)
bfba227f 401#define tzname _tzname
bc5f466c 402#define utime _utime
e37b3faf 403#endif
95ed0025 404
7f470eff
GV
405/* this is hacky, but is necessary to avoid warnings about macro
406 redefinitions using the SDK compilers */
407#ifndef __STDC__
408#define __STDC__ 1
409#define MUST_UNDEF__STDC__
410#endif
411#include <direct.h>
412#include <io.h>
413#include <stdio.h>
414#ifdef MUST_UNDEF__STDC__
415#undef __STDC__
416#undef MUST_UNDEF__STDC__
417#endif
418
95ed0025
RS
419/* Defines that we need that aren't in the standard signal.h */
420#define SIGHUP 1 /* Hang up */
421#define SIGQUIT 3 /* Quit process */
422#define SIGTRAP 5 /* Trace trap */
423#define SIGKILL 9 /* Die, die die */
424#define SIGPIPE 13 /* Write on pipe with no readers */
425#define SIGALRM 14 /* Alarm */
426#define SIGCHLD 18 /* Death of child */
427
bfba227f
AI
428#ifndef NSIG
429#define NSIG 23
430#endif
431
95ed0025
RS
432/* For integration with MSDOS support. */
433#define getdisk() (_getdrive () - 1)
445f44d2
RS
434#ifdef emacs
435#define getdefdir(_drv, _buf) ((_buf[0] = (_drv + 'A' - 1), _buf[1] = ':', _buf[2] = '/', _buf[3] = 0), 1)
436#else
95ed0025 437#define getdefdir(_drv, _buf) _getdcwd (_drv, _buf, MAXPATHLEN)
445f44d2 438#endif
95ed0025 439
bfba227f
AI
440extern char *get_emacs_configuration (void);
441extern char *get_emacs_configuration_options (void);
3360970a 442#define EMACS_CONFIGURATION get_emacs_configuration ()
bfba227f 443#define EMACS_CONFIG_OPTIONS get_emacs_configuration_options ()
3360970a 444
4e36126c
GV
445/* Define this so that winsock.h definitions don't get included with
446 windows.h. For this to have proper effect, config.h must always be
447 included before windows.h. */
95ed0025 448#define _WINSOCKAPI_ 1
bfba227f 449#define _WINSOCK_H
95ed0025 450
1cd47f14 451/* Defines size_t and alloca (). */
bfba227f
AI
452#ifdef USE_CRT_DLL
453#define malloc e_malloc
454#define free e_free
455#define realloc e_realloc
456#define calloc e_calloc
457#endif
1cd47f14
KH
458#include <malloc.h>
459
3360970a 460#include <sys/stat.h>
3360970a 461
177c0ea7 462/* Define for those source files that do not include enough NT
3360970a
KH
463 system files. */
464#ifndef NULL
465#ifdef __cplusplus
466#define NULL 0
467#else
468#define NULL ((void *)0)
469#endif
470#endif
896c0d8b 471
4a1ba222
GV
472/* For proper declaration of environ. */
473#include <stdlib.h>
bfba227f
AI
474#ifndef sys_nerr
475#define sys_nerr _sys_nerr
476#endif
4e36126c 477#include <string.h>
4a1ba222 478
4bba3064 479/* We need a little extra space, see ../../lisp/loadup.el.
0d95f6b2
EZ
480 The number below comes from 23923 bytes worth (as of 2006-04)
481 of w32-specific files loaded by loadup.el, plus 1K spare. */
ff709c3a 482#define SYSTEM_PURESIZE_EXTRA 50000
e3be3bfd 483
7f470eff
GV
484/* For unexec to work on Alpha systems, we need to put Emacs'
485 initialized data into a separate section from the CRT initialized
486 data (because the Alpha linker freely reorders data variables, even
487 across libraries, so our data and the CRT data get intermingled).
488
489 Starting with MSVC 5.0, we must also place the uninitialized data
490 into its own section. VC5 intermingles uninitialized data from the CRT
491 between Emacs' static uninitialized data and its public uninitialized
492 data. A separate .bss section for Emacs groups both static and
493 public uninitalized together.
494
495 Note that unexnt.c relies on this fact, and must be modified
496 accordingly if this section name is changed, or if this pragma is
497 removed. Also, obviously, all files that define initialized data
498 must include config.h to pick up this pragma. */
499
500/* Names must be < 8 bytes */
52c7f9ee 501#ifdef _MSC_VER
7f470eff
GV
502#pragma data_seg("EMDATA")
503#pragma bss_seg("EMBSS")
52c7f9ee 504#endif
7f470eff
GV
505
506/* #define FULL_DEBUG */
507/* #define EMACSDEBUG */
508
509#ifdef EMACSDEBUG
510extern void _DebPrint (const char *fmt, ...);
511#define DebPrint(stuff) _DebPrint stuff
512#else
513#define DebPrint(stuff)
514#endif
515
516
3360970a 517/* ============================================================ */
ab5796a9
MB
518
519/* arch-tag: 5d4a3a1c-40dc-4dea-9c7c-38fed9ae0eae
520 (do not change this comment) */