Mercurial > hg > xemacs-beta
annotate src/config.h.in @ 5211:cdca98f2d36f
Move `default-file-system-ignore-case' to C; fix bug in directory hash tables
src/ChangeLog addition:
2010-05-16 Aidan Kehoe <kehoea@parhasard.net>
Move `default-file-system-ignore-case' to C; pay attention to it
in creating the directory hash tables for #'locate-file. Fix a bug
where #'eq was specified when creating directory hash tables in
dired.c.
* config.h.in (DEFAULT_FILE_SYSTEM_IGNORE_CASE): This is 1 on
Darwin.
* dired.c (make_directory_hash_table): If
#'file-system-ignore-case-p gives non-nil for a directory, created
the associated hash table with #'equalp as its test. Never use
#'eq as a directory hash table test.
* fileio.c (vars_of_fileio):
Move `default-file-system-ignore-case' here, so it can be a
constant boolean reflecting a compile-time #define.
* lisp.h: Update the declaration of make_directory_hash_table;
remove the declaration of wasteful_word_to_lisp, which was
#ifdef'd out.
* lread.c (Flocate_file): Take out a debugging statement from
this function.
(locate_file_refresh_hashing): Call make_directory_hash_table with
a Lisp string, not an Ibyte pointer.
(vars_of_lread): If DEFAULT_FILE_SYSTEM_IGNORE_CASE is defined,
use #'equalp as the hash table test for locate-file-hash-table,
not #'equal.
* s/win32-common.h (DEFAULT_FILE_SYSTEM_IGNORE_CASE):
Case should normally be ignored in file names on Win32.
lisp/ChangeLog addition:
2010-05-16 Aidan Kehoe <kehoea@parhasard.net>
* files.el (default-file-system-ignore-case):
Move this to fileio.c, where it's a constant boolean variable
initialised at dump time.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sun, 16 May 2010 12:33:21 +0100 |
parents | 97c45e3ad810 |
children | 18c0b5909d16 |
rev | line source |
---|---|
428 | 1 /* XEmacs site configuration template file. -*- C -*- |
2 Copyright (C) 1986, 1991-1994, 1998, 1999 Free Software Foundation, Inc. | |
4991
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
3 Copyright (C) 2000, 2001, 2002, 2004, 2005, 2010 Ben Wing. |
428 | 4 |
5 This file is part of XEmacs. | |
6 | |
7 XEmacs is free software; you can redistribute it and/or modify it | |
8 under the terms of the GNU General Public License as published by the | |
9 Free Software Foundation; either version 2, or (at your option) any | |
10 later version. | |
11 | |
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
15 for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
18 along with XEmacs; see the file COPYING. If not, write to | |
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
20 Boston, MA 02111-1307, USA. */ | |
21 | |
22 /* Significantly divergent from FSF. */ | |
23 | |
24 /* No code in XEmacs #includes config.h twice, but some of the code | |
25 intended to work with other packages as well (like gmalloc.c) | |
26 think they can include it as many times as they like. */ | |
27 #ifndef _SRC_CONFIG_H_ | |
28 #define _SRC_CONFIG_H_ | |
29 | |
2367 | 30 /* The proper format of this file: |
31 | |
32 1. All #undef statements that are changed by configure should go together, | |
33 BEFORE the inclusion of the s&m files, and need to be bracketed by | |
34 #ifndef WIN32_NO_CONFIGURE. There is currently only one exception to | |
35 this: SYSTEM_TYPE. | |
36 | |
37 2. All other code, except for the things that may be referenced in s&m | |
38 files (there is very very little of this) need to go AFTER the inclusion | |
39 of s&m files. | |
40 | |
41 Together, this ensures that the s&m files can override configure | |
42 determinations as necessary, and we will properly notice this. | |
43 */ | |
44 | |
771 | 45 /* |
46 This file now serves both as config.h.in and simply as config.h under | |
47 Windows NT. Under Windows NT, there is no configure script that | |
48 operates, so it is necessary for the relevant constants to be set | |
49 manually, either by the user (for user options) or in s/windowsnt.h. | |
50 | |
51 Formerly, under NT there were three different places where constants | |
52 were defined -- nt/config.h, nt/xemacs.mak and s/windowsnt.h; now only | |
53 the latter two are used. (This separate config.h was a hassle because | |
54 it required constant synchronization between it and src/config.h.in.) | |
55 Since the options that are substituted by configure are written in | |
56 config.h.in with #undef, it is easy to make this file serve as | |
57 config.h under Windows NT. Options that are set by the user are | |
58 specified in the file config.inc.samp, which is included by xemacs.mak | |
872 | 59 \(the makefile) and used to set command-line options to the |
771 | 60 compiler. The sorts of options that relate to the system and not to |
61 the user and which are normally auto-determined by configure are set | |
62 in windowsnt.h. | |
63 | |
64 What this means is that a little more care has to be taken in the way | |
65 things are arranged in config.h.in. In particular: | |
66 | |
67 -- Everything that is written with a #undef should be bracketed by | |
68 #ifdef WIN32_NO_CONFIGURE, and these #ifdefs should in general be | |
69 grouped together as much as possible. | |
70 | |
71 -- Things that are not #undefs should not go inside this bracketed | |
72 #ifdef, because these things typically set constants based on other | |
73 constants and those latter constants may be set elsewhere under | |
74 Windows NT. | |
75 | |
76 -- Any #ifdefs that depend on constants that may be set in windowsnt.h | |
77 need to be moved after the point at which this file is | |
78 included. This applies for example to the error checking macros. | |
79 */ | |
80 | |
81 #if defined (WIN32_NATIVE) && !defined (MINGW) | |
82 # define WIN32_NO_CONFIGURE | |
83 #endif | |
84 | |
428 | 85 /* Use this to add code in a structured way to FSF-maintained source |
86 files so as to make it obvious where XEmacs changes are. */ | |
87 #define XEMACS 1 | |
88 | |
771 | 89 #ifndef WIN32_NO_CONFIGURE /* Defined in xemacs.mak or s/windowsnt.h: */ |
90 | |
442 | 91 /* Program name */ |
92 #undef EMACS_PROGNAME | |
93 | |
4448
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4389
diff
changeset
|
94 /* Name of the link to the program to be used with #! scripts */ |
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4389
diff
changeset
|
95 #undef SHEBANG_PROGNAME |
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4389
diff
changeset
|
96 |
428 | 97 /* Allow s&m files to differentiate OS versions without having |
98 multiple files to maintain. */ | |
99 #undef OS_RELEASE | |
100 | |
101 /* The configuration name. This is used as the install directory name | |
102 for the lib-src programs. */ | |
103 #undef EMACS_CONFIGURATION | |
104 | |
105 /* The configuration options. This is exported to Lisp. */ | |
106 #undef EMACS_CONFIG_OPTIONS | |
107 | |
108 /* The version info from version.sh. Used in #pragma ident in emacs.c */ | |
109 #undef EMACS_MAJOR_VERSION | |
110 #undef EMACS_MINOR_VERSION | |
111 #undef EMACS_PATCH_LEVEL | |
112 #undef EMACS_BETA_VERSION | |
113 #undef EMACS_VERSION | |
114 #undef XEMACS_CODENAME | |
975 | 115 #undef XEMACS_EXTRA_NAME |
2602 | 116 #undef XEMACS_RELEASE_DATE |
428 | 117 /* InfoDock versions, not used with XEmacs */ |
118 #undef INFODOCK_MAJOR_VERSION | |
119 #undef INFODOCK_MINOR_VERSION | |
120 #undef INFODOCK_BUILD_VERSION | |
121 | |
442 | 122 /* Make functions from IEEE Stds 1003.[123] available. */ |
123 #undef _POSIX_C_SOURCE | |
124 | |
125 /* Make some functions from Unix98 available. */ | |
126 #undef _XOPEN_SOURCE | |
127 | |
128 /* Make "extensions" from Unix98 available. */ | |
129 #undef _XOPEN_SOURCE_EXTENDED | |
130 | |
428 | 131 /* Make all functions available on AIX. See AC_AIX. */ |
1294 | 132 /* Some AIX compilers (cc) pre-define _ALL_SOURCE, some (xlc) don't. */ |
1284 | 133 #ifndef _ALL_SOURCE |
428 | 134 #undef _ALL_SOURCE |
1284 | 135 #endif |
428 | 136 |
137 /* Make all functions available on GNU libc systems. See features.h. */ | |
138 #undef _GNU_SOURCE | |
139 | |
442 | 140 /* Make all functions available on Solaris 2 systems. */ |
141 #undef __EXTENSIONS__ | |
142 | |
1799 | 143 /* Define to the name of the typeof extension, if the compiler supports one */ |
144 #undef TYPEOF | |
145 | |
428 | 146 /* Used to identify the XEmacs version in stack traces. */ |
147 #undef STACK_TRACE_EYE_CATCHER | |
148 | |
149 /* Allow the configurer to specify if she wants site-lisp. */ | |
150 #undef INHIBIT_SITE_LISP | |
151 | |
152 /* Allow the configurer to specify if she wants site-modules. */ | |
153 #undef INHIBIT_SITE_MODULES | |
154 | |
155 /* Undefine on systems which don't have processes */ | |
156 #undef HAVE_UNIX_PROCESSES | |
157 | |
158 /* Define if you are using the GNU C Library. -- experimental. */ | |
159 #undef DOUG_LEA_MALLOC | |
160 | |
161 /* Define if you are using libmcheck.a from the GNU C Library. */ | |
162 #undef HAVE_LIBMCHECK | |
163 | |
164 /* Define if you are using dlmalloc from the Linux C library. */ | |
165 #undef _NO_MALLOC_WARNING_ | |
166 | |
167 /* Use the system malloc? */ | |
168 #undef USE_SYSTEM_MALLOC | |
169 | |
170 /* Use a debugging malloc? -- experimental */ | |
171 #undef USE_DEBUG_MALLOC | |
172 | |
2367 | 173 /* Use the relocating allocator for buffer space? */ |
174 #undef REL_ALLOC | |
175 | |
176 /* If using the C implementation of alloca, define if you know the | |
177 direction of stack growth for your system; otherwise it will be | |
178 automatically deduced at run-time. | |
179 STACK_DIRECTION > 0 => grows toward higher addresses | |
180 STACK_DIRECTION < 0 => grows toward lower addresses | |
181 STACK_DIRECTION = 0 => direction of growth unknown */ | |
182 #undef STACK_DIRECTION | |
183 | |
184 /* Is alloca() broken when part of an argument to a function call? */ | |
185 #undef BROKEN_ALLOCA_IN_FUNCTION_CALLS | |
186 | |
187 /* Define to 1 if you have `alloca', as a function or macro. */ | |
188 #undef HAVE_ALLOCA | |
189 | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
190 /* Define to 1 if you have <alloca.h> and it should be used. */ |
2367 | 191 #undef HAVE_ALLOCA_H |
192 | |
193 /* Define to 1 if using `alloca.c'. */ | |
194 #undef C_ALLOCA | |
195 | |
428 | 196 /* Compile in TTY support? */ |
197 #undef HAVE_TTY | |
198 | |
199 /* Compile in support for MS windows? */ | |
200 #undef HAVE_MS_WINDOWS | |
201 | |
202 /* special cygwin process handling? */ | |
203 #undef HAVE_MSG_SELECT | |
204 | |
205 /* Compile in support for the X window system? */ | |
206 #undef HAVE_X_WINDOWS | |
207 | |
3354 | 208 /* Compile with support for fontconfig? */ |
209 #undef HAVE_FONTCONFIG | |
210 | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
211 /* Was the spelling of FcConfigGetRescanInterval corrected in this |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
212 fontconfig version? */ |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
213 #undef HAVE_FCCONFIGGETRESCANINTERVAL |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
214 |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
215 /* Was the spelling of FcConfigSetRescanInterval corrected in this |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
216 fontconfig version? */ |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
217 #undef HAVE_FCCONFIGSETRESCANINTERVAL |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3959
diff
changeset
|
218 |
3094 | 219 /* Compile with support for Xft? */ |
4916
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4865
diff
changeset
|
220 #undef HAVE_XFT |
3094 | 221 /* Per-widget stuff will go away? */ |
4916
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4865
diff
changeset
|
222 #undef HAVE_XFT_MENUBARS |
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4865
diff
changeset
|
223 #undef HAVE_XFT_TABS |
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4865
diff
changeset
|
224 #undef HAVE_XFT_GAUGES |
3094 | 225 |
428 | 226 /* Defines for building X applications */ |
227 #ifdef HAVE_X_WINDOWS | |
228 /* The following will be defined if xmkmf thinks they are necessary */ | |
229 #undef SVR4 | |
230 #undef SYSV | |
231 #undef AIXV3 | |
232 #undef _POSIX_SOURCE | |
233 #undef _BSD_SOURCE | |
234 #undef _SVID_SOURCE | |
235 #undef X_LOCALE | |
236 #undef NARROWPROTO | |
771 | 237 #endif /* HAVE_X_WINDOWS */ |
238 | |
462 | 239 /* Defines for building Gtk applications */ |
240 #undef HAVE_GNOME | |
241 #undef HAVE_GTK | |
242 #undef HAVE_GDK_IMLIB_INIT | |
243 #undef HAVE_GLADE_GLADE_H | |
244 #undef HAVE_GLADE_H | |
245 #undef LIBGLADE_XML_TXTDOMAIN | |
246 | |
444 | 247 /* XFree86 has a different prototype for this function */ |
248 #undef HAVE_XREGISTERIMINSTANTIATECALLBACK | |
249 #undef XREGISTERIMINSTANTIATECALLBACK_NONSTANDARD_PROTOTYPE | |
428 | 250 |
251 #undef THIS_IS_X11R4 | |
252 #undef THIS_IS_X11R5 | |
253 #undef THIS_IS_X11R6 | |
254 | |
442 | 255 #undef HAVE_XCONVERTCASE |
2625 | 256 #undef HAVE_XTREGISTERDRAWABLE |
442 | 257 |
258 #undef HAVE_BALLOON_HELP | |
259 | |
428 | 260 /* Where do we find bitmaps? */ |
261 #undef BITMAPDIR | |
262 | |
263 /* Define AMPERSAND_FULL_NAME if you use the convention | |
264 that & in the full name stands for the login id. */ | |
265 #undef AMPERSAND_FULL_NAME | |
266 | |
267 /* Some things figured out by the configure script, grouped as they are in | |
268 configure.in. */ | |
269 #undef HAVE_MCHECK_H | |
442 | 270 #undef HAVE_A_OUT_H |
446 | 271 #undef HAVE_ELF_H |
442 | 272 #undef HAVE_CYGWIN_VERSION_H |
273 #undef HAVE_FCNTL_H | |
274 #undef HAVE_INTTYPES_H | |
275 #undef HAVE_LIBGEN_H | |
276 #undef HAVE_LOCALE_H | |
912 | 277 #undef HAVE_WCHAR_H |
428 | 278 #undef HAVE_MACH_MACH_H |
442 | 279 #undef HAVE_SYS_PARAM_H |
280 #undef HAVE_SYS_PSTAT_H | |
2263 | 281 #undef HAVE_SYS_RESOURCE_H |
442 | 282 #undef HAVE_SYS_TIME_H |
428 | 283 #undef HAVE_SYS_TIMEB_H |
777 | 284 #undef HAVE_SYS_TIMES_H |
442 | 285 #undef HAVE_SYS_UN_H |
2263 | 286 #undef HAVE_SYS_VLIMIT_H |
442 | 287 #undef HAVE_ULIMIT_H |
428 | 288 #undef HAVE_UNISTD_H |
442 | 289 |
428 | 290 #undef HAVE_SYS_WAIT_H |
291 #undef HAVE_LIBINTL_H | |
292 #undef HAVE_X11_XLOCALE_H | |
872 | 293 |
294 /* About __STDC__: Different compilers differ wrt __STDC__. Sunpro C | |
295 defines it, but its value is 0 unless we disable non-ANSI extensions. | |
296 VC++ doesn't define it at all unless we disable non-ANSI extensions. | |
297 But these compilers are all ANSI-compliant. So don't go testing | |
298 __STDC__ anywhere except in code that runs only on known | |
299 compilers. --ben | |
300 | |
301 Jamie wrote the following: | |
302 | |
303 [[ The ANSI standard says that defining __STDC__ to a non-zero value | |
304 means that the compiler conforms to that standard. The standard | |
305 requires certain header files and library functions to be present. | |
306 Therefore, if your compiler defines __STDC__ to non-0 but does not have | |
307 ANSI headers and the ANSI library routines, then your compiler is | |
308 buggy. Conversely, an ANSI-conforming environment (which has both the | |
309 ANSI headers and library routines, i.e., stdlib.h and `memmove') does | |
310 not necessarily define the STDC_HEADERS flag. Lucid Emacs requires an | |
311 ANSI compiler. Therefore, there is no need to consult the abominable | |
312 STDC_HEADERS flag. -- jwz ]] | |
313 | |
314 In reality, we should not be testing STDC_HEADERS at all except | |
315 possibly in code we're purposely keeping in close sync with FSF code. | |
316 STDC_HEADERS should be defined on *ALL* compilers. | |
317 */ | |
318 | |
428 | 319 #undef STDC_HEADERS |
872 | 320 |
428 | 321 #undef TIME_WITH_SYS_TIME |
322 #undef WORDS_BIGENDIAN | |
323 | |
324 #undef HAVE_LONG_FILE_NAMES | |
325 | |
326 /* Use lock files to detect multiple edits of the same file? */ | |
327 #undef CLASH_DETECTION | |
328 | |
329 /* Have shared library support */ | |
330 #undef HAVE_DLOPEN | |
331 #undef HAVE_DLERROR | |
332 #undef HAVE__DLERROR | |
333 #undef HAVE_SHL_LOAD | |
1383 | 334 #undef HAVE_DYLD |
2078 | 335 #undef HAVE_LTDL |
1259 | 336 #undef DLSYM_NEEDS_UNDERSCORE |
1790 | 337 #undef HAVE_SHLIB |
428 | 338 |
4721
19d70297d866
Make readlink_or_correct_case function correctly on Darwin.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4699
diff
changeset
|
339 /* Darwin; realpath corrects for case: */ |
19d70297d866
Make readlink_or_correct_case function correctly on Darwin.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4699
diff
changeset
|
340 #ifdef HAVE_DYLD |
19d70297d866
Make readlink_or_correct_case function correctly on Darwin.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4699
diff
changeset
|
341 #define REALPATH_CORRECTS_CASE 1 |
5211
cdca98f2d36f
Move `default-file-system-ignore-case' to C; fix bug in directory hash tables
Aidan Kehoe <kehoea@parhasard.net>
parents:
4991
diff
changeset
|
342 #define DEFAULT_FILE_SYSTEM_IGNORE_CASE 1 |
4721
19d70297d866
Make readlink_or_correct_case function correctly on Darwin.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4699
diff
changeset
|
343 #endif |
19d70297d866
Make readlink_or_correct_case function correctly on Darwin.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4699
diff
changeset
|
344 |
428 | 345 #undef HAVE_LIBINTL |
346 #undef HAVE_LIBDNET | |
347 #undef HAVE_LIBRESOLV | |
348 | |
349 /* Is `sys_siglist' declared by <signal.h>? */ | |
2651 | 350 #undef HAVE_DECL_SYS_SIGLIST |
428 | 351 |
352 /* Is `struct timeval' declared by <sys/time.h>? */ | |
353 #undef HAVE_TIMEVAL | |
354 | |
355 | |
356 #undef TM_IN_SYS_TIME | |
357 #undef HAVE_TM_ZONE | |
358 #undef HAVE_TZNAME | |
359 | |
442 | 360 /* For `getloadavg' provided by system */ |
361 #undef HAVE_GETLOADAVG | |
362 #undef HAVE_SYS_LOADAVG_H | |
363 /* For implementing `getloadavg' ourselves */ | |
364 #undef HAVE_LIBKSTAT | |
365 #undef HAVE_KSTAT_H | |
366 | |
428 | 367 /* Is `h_errno' declared by <netdb.h>? */ |
368 #undef HAVE_H_ERRNO | |
369 | |
370 /* Does `localtime' cache TZ? */ | |
371 #undef LOCALTIME_CACHE | |
372 | |
373 /* Can `gettimeofday' accept two arguments? */ | |
374 #undef GETTIMEOFDAY_ONE_ARGUMENT | |
375 | |
2367 | 376 /* Is scanf() broken? (Under certain versions of Cygwin) */ |
377 #undef CYGWIN_SCANF_BUG | |
378 | |
4834
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
379 /* UTF-8-aware path-conversion function in Cygwin 1.7 and on */ |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
380 #undef HAVE_CYGWIN_CONV_PATH |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
381 |
428 | 382 #undef HAVE_MMAP |
383 #undef HAVE_STRCOLL | |
384 #undef HAVE_GETPGRP | |
385 #undef GETPGRP_VOID | |
386 | |
387 #undef HAVE_INVERSE_HYPERBOLIC | |
388 | |
2367 | 389 /* Functions in the big list of functions checked for */ |
428 | 390 #undef HAVE_CBRT |
391 #undef HAVE_CLOSEDIR | |
392 #undef HAVE_DUP2 | |
393 #undef HAVE_EACCESS | |
394 #undef HAVE_FMOD | |
395 #undef HAVE_FPATHCONF | |
396 #undef HAVE_FREXP | |
2367 | 397 #undef HAVE_FSYNC |
428 | 398 #undef HAVE_FTIME |
2367 | 399 #undef HAVE_FTRUNCATE |
440 | 400 #undef HAVE_GETADDRINFO |
428 | 401 #undef HAVE_GETHOSTNAME |
440 | 402 #undef HAVE_GETNAMEINFO |
428 | 403 #undef HAVE_GETPAGESIZE |
2263 | 404 #undef HAVE_GETRLIMIT |
428 | 405 #undef HAVE_GETTIMEOFDAY |
406 #undef HAVE_GETCWD | |
771 | 407 #undef HAVE_LINK |
428 | 408 #undef HAVE_LOGB |
409 #undef HAVE_LRAND48 | |
410 #undef HAVE_MATHERR | |
411 #undef HAVE_MKDIR | |
412 #undef HAVE_MKTIME | |
413 #undef HAVE_PERROR | |
414 #undef HAVE_POLL | |
415 #undef HAVE_RANDOM | |
771 | 416 #undef HAVE_READLINK |
428 | 417 #undef HAVE_RENAME |
418 #undef HAVE_RES_INIT | |
419 #undef HAVE_RMDIR | |
420 #undef HAVE_SELECT | |
421 #undef HAVE_SETITIMER | |
422 #undef HAVE_SETPGID | |
423 #undef HAVE_SETSID | |
424 #undef HAVE_SIGBLOCK | |
425 #undef HAVE_SIGHOLD | |
426 #undef HAVE_SIGPROCMASK | |
427 #undef HAVE_SNPRINTF | |
428 #undef HAVE_STRERROR | |
1204 | 429 #undef HAVE_STRLWR |
430 #undef HAVE_STRUPR | |
771 | 431 #undef HAVE_SYMLINK |
428 | 432 #undef HAVE_TZSET |
433 #undef HAVE_ULIMIT | |
2367 | 434 #undef HAVE_UMASK |
428 | 435 #undef HAVE_USLEEP |
2367 | 436 #undef HAVE_VLIMIT |
437 #undef HAVE_VSNPRINTF | |
438 #undef HAVE_WAITPID | |
439 #undef HAVE_WCSCMP | |
440 #undef HAVE_WCSLEN | |
441 | |
3092 | 442 /* Functions and structs checked for vdb. */ |
443 #undef HAVE_MPROTECT | |
444 #undef HAVE_SIGACTION | |
445 #undef HAVE_STRUCT_SIGINFO_SI_ADDR | |
446 #undef HAVE_SIGINFO_T_SI_ADDR | |
447 #undef HAVE_SIGNAL | |
448 #undef HAVE_STRUCT_SIGCONTEXT_CR2 | |
449 | |
460 | 450 #undef HAVE_UTIME |
428 | 451 #undef HAVE_UTIMES |
2367 | 452 #undef HAVE_SIGSETJMP |
442 | 453 |
535 | 454 /* Many flavors of PTY support */ |
2651 | 455 /* glibc's easy pty allocation function */ |
456 #undef HAVE_GETPT | |
457 /* SGI's easy pty allocation function */ | |
458 #undef HAVE__GETPTY | |
459 /* BSD's easy pty allocation function */ | |
460 #undef HAVE_OPENPTY | |
461 /* Unix98 */ | |
462 #undef HAVE_GRANTPT | |
463 /* Unix98 */ | |
464 #undef HAVE_UNLOCKPT | |
465 /* Unix98 */ | |
466 #undef HAVE_PTSNAME | |
467 /* BSD */ | |
468 #undef HAVE_KILLPG | |
469 /* Posix 1 */ | |
470 #undef HAVE_TCGETPGRP | |
471 /* SysV streams */ | |
472 #undef HAVE_ISASTREAM | |
473 /* AIX */ | |
474 #undef HAVE_SYS_PTY_H | |
475 /* HP-UX */ | |
476 #undef HAVE_SYS_PTYIO_H | |
477 /* Linux, Tru64 */ | |
478 #undef HAVE_PTY_H | |
479 /* BSD openpty */ | |
480 #undef HAVE_LIBUTIL_H | |
481 /* NetBSD openpty */ | |
482 #undef HAVE_UTIL_H | |
483 /* SysV streams */ | |
484 #undef HAVE_STROPTS_H | |
485 /* SysV streams TIOCSIGNAL */ | |
486 #undef HAVE_STRTIO_H | |
442 | 487 |
428 | 488 #undef HAVE_SOCKETS |
489 #undef HAVE_SOCKADDR_SUN_LEN | |
490 #undef HAVE_MULTICAST | |
491 #undef HAVE_SYSVIPC | |
438 | 492 #undef HAVE_LOCKF |
493 #undef HAVE_FLOCK | |
428 | 494 |
495 #undef SYSV_SYSTEM_DIR | |
496 #undef NONSYSTEM_DIR_LIBRARY | |
497 | |
498 #undef HAVE_TERMIOS | |
499 #undef HAVE_TERMIO | |
500 #undef NO_TERMIO | |
501 #undef SIGNALS_VIA_CHARACTERS | |
502 | |
503 #undef NLIST_STRUCT | |
504 | |
724 | 505 /* Do IPv6 hostname canonicalization before IPv4 in getaddrinfo()? */ |
506 #undef IPV6_CANONICALIZE | |
507 | |
428 | 508 /* Compile in support for SOCKS? */ |
509 #undef HAVE_SOCKS | |
510 | |
511 /* Compile in support for X pixmaps via the `xpm' library? */ | |
512 #undef HAVE_XPM | |
513 #undef FOR_MSW | |
514 | |
515 /* Compile in support for "X faces" via the `compface' library? | |
516 This enables graphical display of X-face headers in mail/news messages */ | |
517 #undef HAVE_XFACE | |
518 | |
519 /* Compile in support for JPEG images */ | |
520 #undef HAVE_JPEG | |
521 | |
522 /* Compile in support for TIFF images */ | |
523 #undef HAVE_TIFF | |
524 | |
525 /* Compile in support for GIF images */ | |
526 #undef HAVE_GIF | |
527 | |
528 /* Compile in support for PNG images */ | |
529 #undef HAVE_PNG | |
530 | |
771 | 531 /* Compile in support for GZIP compression */ |
532 #undef HAVE_ZLIB | |
533 | |
428 | 534 /* Compile in support for DBM databases? May require libgdbm or libdbm. */ |
535 #undef HAVE_DBM | |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4497
diff
changeset
|
536 /* Full #include file path for GDBM's or platforms ndbm.h */ |
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4497
diff
changeset
|
537 #undef NDBM_H_FILE |
4991
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
538 /* Can we trust the prototypes in ndbm.h? If not, we need to declare our own */ |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
539 #undef TRUST_NDBM_H_PROTOTYPES |
428 | 540 |
3739 | 541 /* Define to 1 if the system has the type `u_int8_t'. */ |
542 #undef HAVE_U_INT8_T | |
543 /* Define to 1 if the system has the type `u_int16_t'. */ | |
544 #undef HAVE_U_INT16_T | |
545 /* Define to 1 if the system has the type `u_int32_t'. */ | |
546 #undef HAVE_U_INT32_T | |
547 /* Define to 1 if the system has the type `u_int64_t'. */ | |
548 #undef HAVE_U_INT64_T | |
549 | |
428 | 550 /* Compile in support for Berkeley DB style databases? May require libdb. */ |
551 #undef HAVE_BERKELEY_DB | |
552 /* Full #include file path for Berkeley DB's db.h */ | |
442 | 553 #undef DB_H_FILE |
428 | 554 |
555 /* Do we have either DBM or Berkeley DB database support? */ | |
556 #undef HAVE_DATABASE | |
557 | |
558 /* Do we have LDAP support? */ | |
559 #undef HAVE_LDAP | |
560 /* Does the library define ldap_set_option () ? */ | |
561 #undef HAVE_LDAP_SET_OPTION | |
562 /* Does the library define ldap_get_lderrno () ? */ | |
563 #undef HAVE_LDAP_GET_LDERRNO | |
564 /* Does the library define ldap_result2error () ? */ | |
565 #undef HAVE_LDAP_RESULT2ERROR | |
566 /* Does the library define ldap_parse_result () ? */ | |
567 #undef HAVE_LDAP_PARSE_RESULT | |
568 | |
442 | 569 /* Do we have PostgreSQL RDBMS support? */ |
570 #undef HAVE_POSTGRESQL | |
571 #undef HAVE_POSTGRESQLV7 | |
2651 | 572 /* main PostgreSQL header file */ |
573 #undef LIBPQ_FE_H_FILE | |
442 | 574 |
428 | 575 /* Do you have the Xauth library present? This will add some extra |
576 functionality to gnuserv. */ | |
577 #undef HAVE_XAUTH | |
578 | |
579 /* Compile in support for gpm (General Purpose Mouse)? */ | |
580 #undef HAVE_GPM | |
581 | |
582 /* Compile in support for ncurses? */ | |
583 #undef HAVE_NCURSES | |
584 /* Full #include file paths for ncurses' curses.h and term.h. */ | |
442 | 585 #undef CURSES_H_FILE |
586 #undef TERM_H_FILE | |
428 | 587 |
588 /* Define USE_ASSERTIONS if you want the abort() to be changed to assert(). | |
589 If the assertion fails, assert_failed() will be called. This is | |
590 recommended for general use because it gives more info about the crash | |
591 than just the abort() message. Too many people "Can't find the corefile" | |
592 or have limit-ed core dumps out of existence. */ | |
593 #undef USE_ASSERTIONS | |
594 | |
595 /* Define one or more of the following if you want lots of extra checks | |
596 (e.g. structure validation) compiled in. These should be turned | |
3959 | 597 on during the beta-test cycle. |
598 | |
599 Keep macro names sorted to help with syncing this file to configure.ac. | |
600 Don't forget the ERROR_CHECK_ALL stuff at the end of this file. */ | |
601 | |
602 /* Minor sanity checking of the bytecode interpreter. Useful for | |
603 debugging the byte compiler. */ | |
604 #undef ERROR_CHECK_BYTE_CODE | |
605 | |
606 /* Sanity-check the redisplay structures after each modification. */ | |
607 #undef ERROR_CHECK_DISPLAY | |
428 | 608 |
609 /* Check the entire extent structure of a buffer each time an extent | |
610 change is done, and do other extent-related checks. */ | |
611 #undef ERROR_CHECK_EXTENTS | |
440 | 612 |
3959 | 613 /* Attempt to catch bugs related to garbage collection (e.g. not GCPRO'ing). */ |
614 #undef ERROR_CHECK_GC | |
615 | |
616 /* Minor sanity checking of glyphs, especially subwindows and | |
617 widgets. */ | |
618 #undef ERROR_CHECK_GLYPHS | |
619 | |
620 /* Attempt to catch freeing of a non-malloc()ed block, heap corruption, etc. */ | |
621 #undef ERROR_CHECK_MALLOC | |
622 | |
623 /* Define for any sanity checks on structures that are not handled by a | |
624 more specific error-checking type. */ | |
625 #undef ERROR_CHECK_STRUCTURES | |
440 | 626 |
800 | 627 /* Turn on checks related to text -- check that text in strings and buffers |
628 is in a valid format before we use it, check that buffer positions are | |
629 valid, etc. */ | |
630 #undef ERROR_CHECK_TEXT | |
440 | 631 |
3959 | 632 /* Turn on checks related to types -- make sure that all X... macros are |
633 dereferencing the correct type, and that all XSET... macros (as much as | |
634 possible) are setting the correct type of structure; check any other | |
635 places that a specific type is expected. */ | |
636 #undef ERROR_CHECK_TYPES | |
800 | 637 |
428 | 638 /* Define DEBUG_XEMACS if you want extra debugging code compiled in. |
639 This is mainly intended for use by developers. */ | |
640 #undef DEBUG_XEMACS | |
641 | |
642 /* Define MEMORY_USAGE_STATS if you want extra code compiled in to | |
643 determine where XEmacs' memory is going. */ | |
644 #undef MEMORY_USAGE_STATS | |
645 | |
460 | 646 /* Define QUANTIFY if using Quantify from Rational Software. |
428 | 647 This adds some additional calls to control data collection. |
648 It is only intended for use by the developers. */ | |
649 #undef QUANTIFY | |
650 | |
460 | 651 /* Define PURIFY if using Purify from Rational Software. |
428 | 652 It is only intended for use by the developers. */ |
653 #undef PURIFY | |
654 | |
4803
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
655 /* Define USE_VALGRIND to compile valgrind hints into the code. |
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
656 It is only intended for use by the developers. */ |
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
657 #undef USE_VALGRIND |
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
658 |
428 | 659 /* Define EXTERNAL_WIDGET to compile support for using the editor as a |
660 widget within another program. */ | |
661 #undef EXTERNAL_WIDGET | |
662 | |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
663 /* There are some special-case defines for gcc, g++ and lcc. */ |
428 | 664 #undef USE_GCC |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
665 #undef USE_GPLUSPLUS |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
666 #undef USE_LCC /* #### Not currently set in configure */ |
428 | 667 |
668 /* Compile in support for CDE (Common Desktop Environment) drag and drop? | |
669 Requires libDtSvc, which typically must be present at runtime. */ | |
670 #undef HAVE_CDE | |
671 | |
672 /* Compile in generic Drag'n'Drop API */ | |
673 #undef HAVE_DRAGNDROP | |
674 | |
675 /* Compile in support for proper handling of WM_COMMAND. */ | |
676 #undef HAVE_WMCOMMAND | |
677 | |
678 /* Define this if you want Mule support (multi-byte character support). | |
679 There may be some performance penalty, although it should be small | |
680 if you're working with ASCII files. */ | |
681 #undef MULE | |
682 | |
771 | 683 /* Define this if you want EOL detection of files to be on by default |
684 in a non-Mule Unix; otherwise, defaults will be set so that all | |
685 files are read in as binary. Doesn't apply to Cygwin or MinGW. */ | |
686 #undef HAVE_DEFAULT_EOL_DETECTION | |
428 | 687 |
1259 | 688 /* Support X FontSets. Evil, yes, but if we're going to make it go away |
689 by using faces in the menubar we should do so. */ | |
690 #undef USE_XFONTSET | |
691 | |
428 | 692 /* Do we want to use X window input methods for use with Mule? (requires X11R5) |
693 If so, use raw Xlib or higher level Motif interface? */ | |
694 #undef HAVE_XIM | |
695 #undef XIM_XLIB | |
696 #undef XIM_MOTIF | |
697 | |
698 /* Non-XIM input methods for use with Mule. */ | |
699 #undef HAVE_CANNA | |
3830 | 700 #undef CANNA_NEW_WCHAR_AWARE |
428 | 701 #undef HAVE_WNN |
702 #undef WNN6 | |
703 | |
442 | 704 /* Debugging development option: Remove inessential but time consuming |
705 actions from happening during build. This saves a lot of time when | |
706 you're repeatedly compiling-running-crashing. This (1) doesn't | |
707 garbage-collect after loading each file during dumping, and (2) | |
708 doesn't automatically rebuild the DOC file. (Remove it by hand to | |
709 get it rebuilt.) | |
710 */ | |
711 #undef QUICK_BUILD | |
428 | 712 |
872 | 713 /* If true, run the compiler with many files at once rather than one at a |
714 time. May speed up compilation time with some compilers, particularly | |
715 if the entire compilation happens in a single process -- the process can | |
716 cache the results of processing include files. This definitely helps | |
717 with VC++ (although it doesn't use Makefile.in.in) but not with GCC, | |
718 which runs many processes per file to compile. */ | |
719 #undef BATCH_COMPILER_RUNS | |
720 | |
771 | 721 /* If defined, use unions instead of ints. A few systems (DEC Alpha) |
722 seem to require this, probably because something with the int | |
723 definitions isn't right with 64-bit systems. */ | |
724 #undef USE_UNION_TYPE | |
725 | |
926 | 726 /* If defined, use experimental pdump-based GC algorithms. */ |
727 #undef USE_KKCC | |
728 | |
3263 | 729 /* If defined, use experimental incremental garbage collector and new |
730 allocator. */ | |
3092 | 731 #undef NEW_GC |
732 | |
733 /* Virtual dirty bit implementation for incremental gc. */ | |
734 #undef VDB_POSIX | |
735 #undef VDB_MACH | |
736 #undef VDB_WIN32 | |
737 #undef VDB_FAKE | |
738 | |
771 | 739 /* Enable special GNU Make features in the Makefiles. */ |
740 #undef USE_GNU_MAKE | |
741 | |
428 | 742 /* Defined by AC_C_CONST in configure.in */ |
743 #undef const | |
744 | |
434 | 745 /* Allow the source to use standard types. Include these before the |
746 s&m files so that they can use them. */ | |
747 #undef ssize_t | |
748 #undef size_t | |
749 #undef pid_t | |
750 #undef mode_t | |
751 #undef off_t | |
752 #undef uid_t | |
753 #undef gid_t | |
442 | 754 #undef socklen_t |
434 | 755 |
2367 | 756 /* Enhanced numeric support */ |
757 #undef WITH_NUMBER_TYPES | |
758 #undef WITH_GMP | |
759 #undef WITH_MP | |
760 #undef MP_PREFIX | |
761 #undef HAVE_MP_MOVE | |
771 | 762 |
2367 | 763 #undef SIZEOF_SHORT |
764 #undef SIZEOF_INT | |
765 #undef SIZEOF_LONG | |
766 #undef SIZEOF_LONG_LONG | |
767 #undef SIZEOF_VOID_P | |
768 #undef SIZEOF_DOUBLE | |
615 | 769 |
2367 | 770 /* some systems (Cygwin) typedef u?intptr_t in <sys/types.h> |
771 but the standard is <inttypes.h> | |
772 ugliness due to last-resort conditional typedef'ing in lisp.h */ | |
773 #undef HAVE_INTPTR_T_IN_SYS_TYPES_H | |
774 | |
775 /* Does the keyword `inline' exist? */ | |
776 #undef inline | |
428 | 777 |
2367 | 778 /* movemail options */ |
779 /* Should movemail use POP3 for mail access? */ | |
780 #undef MAIL_USE_POP | |
781 /* Should movemail use kerberos for POP authentication? */ | |
782 #undef KERBEROS | |
783 /* Should movemail use hesiod for getting POP server host? */ | |
784 #undef HESIOD | |
785 /* Determine type of mail locking. */ | |
786 #undef MAIL_LOCK_LOCKF | |
787 #undef MAIL_LOCK_FLOCK | |
788 #undef MAIL_LOCK_DOT | |
789 #undef MAIL_LOCK_LOCKING | |
790 #undef MAIL_LOCK_MMDF | |
428 | 791 |
2367 | 792 #undef HAVE_MKSTEMP |
428 | 793 |
2367 | 794 #undef PREFIX_USER_DEFINED |
795 #undef EXEC_PREFIX_USER_DEFINED | |
796 #undef MODULEDIR_USER_DEFINED | |
797 #undef SITEMODULEDIR_USER_DEFINED | |
798 #undef DOCDIR_USER_DEFINED | |
799 #undef LISPDIR_USER_DEFINED | |
3179 | 800 #undef EARLY_PACKAGE_DIRECTORIES_USER_DEFINED |
801 #undef LATE_PACKAGE_DIRECTORIES_USER_DEFINED | |
802 #undef LAST_PACKAGE_DIRECTORIES_USER_DEFINED | |
2367 | 803 #undef PACKAGE_PATH_USER_DEFINED |
804 #undef SITELISPDIR_USER_DEFINED | |
805 #undef ARCHLIBDIR_USER_DEFINED | |
806 #undef ETCDIR_USER_DEFINED | |
807 #undef INFODIR_USER_DEFINED | |
808 #undef INFOPATH_USER_DEFINED | |
872 | 809 |
2367 | 810 #undef PDUMP |
872 | 811 |
2720 | 812 /* Define DUMP_IN_EXEC to include the dump file in the executable |
813 file. */ | |
814 #undef DUMP_IN_EXEC | |
815 | |
428 | 816 /* Compile in support for Sun Sparcworks/WorkShop? */ |
817 #undef SUNPRO | |
818 | |
819 /* Sun SparcStations, SGI machines, and HP9000s700s have built-in | |
820 support for playing sound files. (On Suns, the sound support is | |
821 usually found in /usr/demo/SOUND - you may need to install the | |
822 "SUNWaudmo" package.) */ | |
823 #undef HAVE_NATIVE_SOUND | |
771 | 824 |
428 | 825 /* Native sound may be provided via soundcard.h, in various directories */ |
442 | 826 #undef SOUNDCARD_H_FILE |
428 | 827 |
3308 | 828 /* Compile in support for ALSA (Advanced Linux Sound Architecture) */ |
829 #undef HAVE_ALSA_SOUND | |
830 | |
428 | 831 /* Compile in support for NAS (Network Audio System)? |
832 NAS_NO_ERROR_JUMP means that the NAS libraries don't include some | |
833 error handling changes. */ | |
834 #undef HAVE_NAS_SOUND | |
835 #undef NAS_NO_ERROR_JUMP | |
836 | |
837 /* Compile in support for ESD (Enlightened Sound Daemon)? */ | |
838 #undef HAVE_ESD_SOUND | |
839 | |
840 /* Compile in support for SunPro usage-tracking code? */ | |
841 #undef USAGE_TRACKING | |
842 | |
843 /* Compile in support for Tooltalk? */ | |
844 #undef TOOLTALK | |
845 /* tt_c.h might be in "Tt" or "desktop" subdirectories */ | |
442 | 846 #undef TT_C_H_FILE |
428 | 847 |
848 /* Toolkits used by lwlib for various widgets... */ | |
771 | 849 |
428 | 850 #undef LWLIB_USES_MOTIF |
851 #undef LWLIB_USES_ATHENA | |
852 #undef LWLIB_MENUBARS_LUCID | |
853 #undef LWLIB_MENUBARS_MOTIF | |
854 #undef LWLIB_SCROLLBARS_LUCID | |
855 #undef LWLIB_SCROLLBARS_MOTIF | |
856 #undef LWLIB_SCROLLBARS_ATHENA | |
857 #undef LWLIB_SCROLLBARS_ATHENA3D | |
858 #undef LWLIB_DIALOGS_MOTIF | |
859 #undef LWLIB_DIALOGS_ATHENA | |
860 #undef LWLIB_DIALOGS_ATHENA3D | |
861 #undef LWLIB_TABS_LUCID | |
862 #undef LWLIB_WIDGETS_MOTIF | |
863 #undef LWLIB_WIDGETS_ATHENA | |
440 | 864 #undef HAVE_ATHENA_3D |
428 | 865 |
866 /* Other things that can be disabled by configure. */ | |
867 #undef HAVE_MENUBARS | |
868 #undef HAVE_SCROLLBARS | |
869 #undef HAVE_DIALOGS | |
870 #undef HAVE_TOOLBARS | |
871 #undef HAVE_WIDGETS | |
872 | |
771 | 873 #endif /* WIN32_NO_CONFIGURE */ |
874 | |
2994 | 875 #ifdef _MSC_VER |
876 /* Turn off tons of C4996 warnings in VC 8 about standard functions being | |
877 "deprecated" in favor of Microsoft-specific "secure" ones (!) | |
878 This must go *before* the inclusion of any system files. */ | |
879 #define _CRT_SECURE_NO_DEPRECATE | |
4457
2fddd822ce87
#define _CRT_NONSTDC_NO_DEPRECATE on Win32
Aidan Kehoe <kehoea@parhasard.net>
parents:
4448
diff
changeset
|
880 #define _CRT_NONSTDC_NO_DEPRECATE |
2994 | 881 #endif |
882 | |
2367 | 883 /* alloca twiddling. |
884 Because we might be #including alloca.h here, feature test macros | |
885 such as _XOPEN_SOURCE must be defined above. | |
886 | |
887 #### This really should go below the inclusion of s&m files, like | |
888 everything else. */ | |
889 | |
890 #ifndef NOT_C_CODE | |
891 #if defined (__CYGWIN__) | |
892 /* We get complaints about redefinitions if we just use the __GNUC__ | |
893 definition: stdlib.h also includes alloca.h, which defines it slightly | |
894 differently */ | |
895 #include <alloca.h> | |
896 #elif defined (__GNUC__) | |
897 #define alloca __builtin_alloca | |
898 #elif defined (WIN32_NO_CONFIGURE) | |
899 /* Defines size_t and alloca (). */ | |
900 #include <malloc.h> | |
901 #elif defined (__DECC) | |
902 #include <alloca.h> | |
903 #pragma intrinsic(alloca) | |
904 #elif defined (HAVE_ALLOCA_H) | |
905 #include <alloca.h> | |
906 #elif defined (_AIX) | |
907 /* AIX requires this before any "real" code in the translation unit. */ | |
908 #pragma alloca | |
909 #elif ! defined (alloca) | |
910 #ifdef C_ALLOCA | |
911 #define alloca xemacs_c_alloca | |
912 #else | |
913 void *alloca (); | |
914 #endif /* C_ALLOCA */ | |
915 #endif /* !defined (alloca) */ | |
916 #endif /* C code */ | |
917 | |
918 /* The configuration script may define `opsysfile' to be the name of | |
919 the s/...h file that describes your operating system. | |
920 The file name is chosen based on the configuration name. */ | |
921 | |
922 #if defined (__cplusplus) && !defined (NOT_C_CODE) | |
923 extern "C" { | |
924 #endif | |
925 | |
926 #undef config_opsysfile | |
927 #ifdef WIN32_NO_CONFIGURE | |
928 #include "s/windowsnt.h" | |
929 #elif defined (config_opsysfile) | |
930 #include config_opsysfile | |
931 #endif | |
932 | |
4738
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
933 /* Darwin uses this to set BSD appropriately. */ |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
934 #undef USE_PARAM_H |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
935 #ifdef USE_PARAM_H |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
936 # ifndef NOT_C_CODE |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
937 # include <sys/param.h> |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
938 # endif |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
939 #endif |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
940 |
2367 | 941 /* The configuration script may define `machfile' to be the name of |
942 the m/...h file that describes the machine you are using. | |
943 The file name is chosen based on the configuration name. */ | |
944 | |
945 #undef config_machfile | |
946 #ifdef WIN32_NO_CONFIGURE | |
947 #include "m/windowsnt.h" | |
948 #elif defined (config_machfile) | |
949 #include config_machfile | |
950 #endif | |
951 | |
952 #if defined (__cplusplus) && !defined (NOT_C_CODE) | |
953 } | |
954 #endif | |
955 | |
956 /* This will be removed in 19.15. */ | |
957 /* Hah! Try 20.3 ... */ | |
958 /* Hah! Try never ... */ | |
959 /* If at first you don't succeed, try, try again. */ | |
960 /* #define LOSING_BYTECODE */ | |
961 | |
962 /* USER_FULL_NAME returns a string that is the user's full name. | |
963 It can assume that the variable `pw' points to the password file | |
964 entry for this user. | |
965 | |
966 At some sites, the pw_gecos field contains the user's full name. | |
967 If neither this nor any other field contains the right thing, use | |
968 pw_name, giving the user's login name, since that is better than | |
969 nothing. */ | |
970 #define USER_FULL_NAME pw->pw_gecos | |
971 | |
972 #define XEMACS_WANTS_C_ALLOCA | |
973 | |
974 /* s&m files shouldn't be required to define anything, or even to exist. | |
975 If the s&m files don't define SYSTEM_TYPE, configure will select an | |
976 appropriate default value. */ | |
977 #ifndef SYSTEM_TYPE | |
978 #undef SYSTEM_TYPE | |
979 #endif | |
980 | |
981 #if defined (USE_SYSTEM_MALLOC) && !defined (SYSTEM_MALLOC) | |
982 #define SYSTEM_MALLOC | |
983 #endif | |
984 | |
2994 | 985 /* This enables type based information (updated during gc). The output |
986 is used by show-memory-usage to print memory information for each | |
987 type. Since the new allocator does not distinguish between types | |
988 anymore, this functionality is additionally implemented and | |
989 consumes a lot of time. That is why this functionality can be | |
990 disabled; for the moment, we keep it enabled. */ | |
991 #if !defined (MC_ALLOC) || 1 | |
992 # define ALLOC_TYPE_STATS 1 | |
993 #endif | |
994 | |
2367 | 995 /* Define the return type of signal handlers if the s/xxx.h file |
996 did not already do so. */ | |
997 #define RETSIGTYPE void | |
998 | |
999 #ifndef XCDECL | |
1000 #define XCDECL | |
1001 #endif | |
1002 | |
1003 /* SIGTYPE is the macro we actually use. */ | |
1004 #ifndef SIGTYPE | |
1005 #define SIGTYPE RETSIGTYPE XCDECL | |
1006 #define SIGRETURN return | |
1007 #endif | |
1008 | |
1009 /* Define HAVE_WINDOW_SYSTEM if any windowing system is available. */ | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1010 #if defined (HAVE_GTK) || defined (HAVE_X_WINDOWS) || defined (HAVE_MS_WINDOWS) |
2367 | 1011 #define HAVE_WINDOW_SYSTEM |
1012 #endif | |
1013 | |
771 | 1014 #if defined (HAVE_MENUBARS) || defined (HAVE_SCROLLBARS) || defined (HAVE_DIALOGS) || defined (HAVE_TOOLBARS) || defined (HAVE_WIDGETS) |
1015 #define HAVE_GUI_OBJECTS | |
1016 #endif | |
1017 | |
2367 | 1018 #if defined (HAVE_MENUBARS) || defined (HAVE_DIALOGS) |
1019 #define HAVE_POPUPS | |
1020 #endif | |
1021 | |
1022 #if defined (HAVE_GTK) || defined (HAVE_X_WINDOWS) | |
1023 #define HAVE_XLIKE | |
1024 #endif | |
1025 | |
771 | 1026 /* For the moment, Athena widgets and dialogs may be very unstable and not |
1027 working well, but things under Windows work much better. configure by | |
1028 default tries to turn Windows widgets and dialogs on, but the Athena | |
1029 ones off, so let's separate the defines. */ | |
1030 #if defined (HAVE_WIDGETS) && (defined (LWLIB_WIDGETS_MOTIF) || defined (LWLIB_WIDGETS_ATHENA)) | |
1031 #define HAVE_X_WIDGETS | |
1032 #endif | |
1033 | |
1034 #if defined (HAVE_DIALOGS) && (defined (LWLIB_DIALOGS_MOTIF) || defined (LWLIB_DIALOGS_ATHENA) || defined (LWLIB_DIALOGS_ATHENA3D)) | |
1035 #define HAVE_X_DIALOGS | |
1036 #endif | |
428 | 1037 |
2367 | 1038 #ifdef HAVE_X_WINDOWS |
1039 /* The following should always be defined, no matter what xmkmf thinks. */ | |
1040 #ifndef NeedFunctionPrototypes | |
1041 #define NeedFunctionPrototypes 1 | |
1042 #endif | |
1043 #ifndef FUNCPROTO | |
1044 #define FUNCPROTO 15 | |
1045 #endif | |
1046 #endif /* HAVE_X_WINDOWS */ | |
1047 | |
1048 #if (defined (QUANTIFY) || defined (PURIFY)) && !defined (XLIB_ILLEGAL_ACCESS) | |
1049 #define XLIB_ILLEGAL_ACCESS 1 | |
1050 #endif | |
1051 | |
1052 /* Define HAVE_UNIXOID_EVENT_LOOP if we use select() to wait for events. */ | |
1053 #if defined (HAVE_X_WINDOWS) || defined (HAVE_TTY) || defined (HAVE_MSG_SELECT) | |
1054 #define HAVE_UNIXOID_EVENT_LOOP | |
428 | 1055 #endif |
1056 | |
1057 #ifdef HAVE_CANNA | |
1058 # define CANNA_MULE | |
1059 # define CANNA_PURESIZE 0 | |
1060 #else /* not CANNA */ | |
1061 # define CANNA_PURESIZE 0 | |
1062 #endif /* not CANNA */ | |
1063 | |
1064 #if defined (HAVE_SOCKS) && !defined (DO_NOT_SOCKSIFY) | |
1065 #define accept Raccept | |
1066 #define bind Rbind | |
1067 #define connect Rconnect | |
1068 #define getsockname Rgetsockname | |
1069 #define listen Rlisten | |
1070 #endif /* HAVE_SOCKS && !DO_NOT_SOCKSIFY */ | |
1071 | |
1072 #ifndef BITS_PER_CHAR | |
1073 #define BITS_PER_CHAR 8 | |
1074 #endif | |
1075 #define SHORTBITS (SIZEOF_SHORT * BITS_PER_CHAR) | |
1076 #define INTBITS (SIZEOF_INT * BITS_PER_CHAR) | |
1077 #define LONGBITS (SIZEOF_LONG * BITS_PER_CHAR) | |
1078 #define LONG_LONG_BITS (SIZEOF_LONG_LONG * BITS_PER_CHAR) | |
1079 #define VOID_P_BITS (SIZEOF_VOID_P * BITS_PER_CHAR) | |
1983 | 1080 #define DOUBLE_BITS (SIZEOF_DOUBLE * BITS_PER_CHAR) |
1081 | |
442 | 1082 /* Use `INLINE_HEADER' to define inline functions in .h files. |
1083 Use `inline static' to define inline functions in .c files. | |
1084 See the Internals manual for examples and more information. */ | |
1085 | |
4389
4c5cd87620e4
Check that __STDC_VERSION__ is defined before examining it.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4387
diff
changeset
|
1086 #if (defined ( __STDC_VERSION__) && __STDC_VERSION__ >= 199901L) \ |
4c5cd87620e4
Check that __STDC_VERSION__ is defined before examining it.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4387
diff
changeset
|
1087 || defined (__cplusplus) || ! defined (__GNUC__) || ! defined(emacs) |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1088 # define INLINE_HEADERS_ARE_STATIC |
442 | 1089 # define INLINE_HEADER inline static |
1090 #elif defined (DONT_EXTERN_INLINE_HEADER_FUNCTIONS) | |
1091 # define INLINE_HEADER inline | |
1092 #else | |
1093 # define INLINE_HEADER inline extern | |
1094 #endif | |
428 | 1095 |
771 | 1096 /* Use DECLARE_INLINE_HEADER() to declare an inline function in a header |
1097 file, like this: (This avoids the need to write a prototype directly | |
4932 | 1098 followed by the function header itself, in order to avoid a |
1099 "no prototype" warning from GCC.) | |
771 | 1100 |
1101 DECLARE_INLINE_HEADER (int foo (int x)) | |
1102 { | |
1103 return x * x; | |
1104 } | |
1105 | |
1106 */ | |
1107 | |
1108 #define DECLARE_INLINE_HEADER(header) \ | |
1109 INLINE_HEADER header ; INLINE_HEADER header | |
1110 | |
442 | 1111 #ifndef NOT_C_CODE /* Actually means C or C++ */ |
1112 # if defined (__cplusplus) | |
1113 # define EXTERN_C extern "C" | |
1114 # else /* C code */ | |
1115 # define EXTERN_C extern | |
1116 # endif | |
1117 #endif /* C or C++ */ | |
428 | 1118 |
1119 /* Strictly speaking, only int or unsigned int are valid types in a | |
1120 bitfield. In practice, we would like to use enums as bitfields. | |
1121 The following should just result in warning avoidance: | |
1122 warning: nonportable bit-field type */ | |
1123 #ifdef __GNUC__ | |
1124 #define enum_field(enumeration_type) enum enumeration_type | |
1125 #else | |
1126 #define enum_field(enumeration_type) unsigned int | |
1127 #endif | |
1128 | |
1129 /* We want to avoid saving the signal mask if possible, because | |
1130 that necessitates a system call. */ | |
1131 #ifdef HAVE_SIGSETJMP | |
1132 # define SETJMP(x) sigsetjmp (x, 0) | |
1133 # define LONGJMP(x, y) siglongjmp (x, y) | |
1134 # define JMP_BUF sigjmp_buf | |
1135 #else | |
1136 # define SETJMP(x) setjmp (x) | |
1137 # define LONGJMP(x, y) longjmp (x, y) | |
1138 # define JMP_BUF jmp_buf | |
1139 #endif | |
1140 | |
838 | 1141 /* For the moment, we go ahead and keep this, since it's used in mouse.el. |
1142 #### font-lock does its own version using parse-partial-sexp. We should | |
1143 merge the two. */ | |
1144 #define USE_C_FONT_LOCK | |
1145 | |
3959 | 1146 /* Keep the #defines sorted. |
1147 #### Can this code ever be executed? I guess if a developer #defines | |
1148 ERROR_CHECK_ALL above the #include it could be useful. */ | |
800 | 1149 #ifdef ERROR_CHECK_ALL |
3959 | 1150 #define ERROR_CHECK_BYTE_CODE |
1151 #define ERROR_CHECK_DISPLAY | |
800 | 1152 #define ERROR_CHECK_EXTENTS |
1153 #define ERROR_CHECK_GC | |
3959 | 1154 #define ERROR_CHECK_GLYPHS |
800 | 1155 #define ERROR_CHECK_MALLOC |
1156 #define ERROR_CHECK_STRUCTURES | |
3959 | 1157 #define ERROR_CHECK_TEXT |
1158 #define ERROR_CHECK_TYPES | |
800 | 1159 #endif /* ERROR_CHECK_ALL */ |
1160 | |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1161 /* It's very tricky. In some circumstances, if we don't include the |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1162 ERROR_CHECK_TYPES functions in xemacs.def.in.in, we get lots of |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1163 undefined references from eldap.o and postgresql.o; but in other |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1164 circumstances, if we DO include them, we get undefined references |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1165 in xemacs-export.o to the same functions. We try here to grok when |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1166 we need to include them in xemacs.def.in.in. I originally thought |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1167 it was enough to condition on !defined (INLINE_HEADERS_ARE_STATIC) -- |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1168 if they're static, they shouldn't lead to any external references |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1169 in the modules, right? Wrong, under non-optimized builds. So now |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1170 let's try conditioning on !C++ -- by examining inline.o with nm, |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1171 it seems it's the C++ builds where inline.o doesn't get any inline |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1172 functions compiled into it at all, which would lead to problems if |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1173 we reference them in xemacs.def.in.in. |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1174 |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1175 #### FIXME Should we condition on GCC and defined(emacs), like we |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1176 do (inverted) for INLINE_HEADERS_ARE_STATIC? --ben */ |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1177 |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1178 /* Checking for !defined (__cplusplus) doesn't work, because we typically |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1179 aren't using the C++ preprocessor when processing xemacs.def.in.in |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1180 even if we're using a C++ compiler. I suspect we only need this at |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1181 all GCC is being used. */ |
4952
19a72041c5ed
Mule-izing, various fixes related to char * arguments
Ben Wing <ben@xemacs.org>
parents:
4932
diff
changeset
|
1182 #if !defined (USE_GPLUSPLUS) |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1183 /* #if !defined (INLINE_HEADERS_ARE_STATIC) */ |
4952
19a72041c5ed
Mule-izing, various fixes related to char * arguments
Ben Wing <ben@xemacs.org>
parents:
4932
diff
changeset
|
1184 #define XEMACS_DEFS_NEEDS_INLINE_DECLS |
4829
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1185 #endif |
9987da5935bd
try to fix problems with link errors involving inlined functions
Ben Wing <ben@xemacs.org>
parents:
4790
diff
changeset
|
1186 |
428 | 1187 #endif /* _SRC_CONFIG_H_ */ |