1 /* GNU Emacs site configuration template file. -*- C -*-
2 Copyright (C) 1988, 1993, 1994 Free Software Foundation, Inc.
4 This file is part of GNU Emacs.
6 GNU Emacs is distributed in the hope that it will be useful,
7 but WITHOUT ANY WARRANTY. No author or distributor
8 accepts responsibility to anyone for the consequences of using it
9 or for whether it serves any particular purpose or works at all,
10 unless he says so in writing. Refer to the GNU Emacs General Public
11 License for full details.
13 Everyone is granted permission to copy, modify and redistribute
14 GNU Emacs, but only under the conditions described in the
15 GNU Emacs General Public License. A copy of this license is
16 supposed to have been given to you along with GNU Emacs so you
17 can know your rights and responsibilities. It should be in a
18 file named COPYING. Among other things, the copyright notice
19 and this notice must be preserved on all copies. */
22 /* No code in Emacs #includes config.h twice, but some of the code
23 intended to work with other packages as well (like gmalloc.c)
24 think they can include it as many times as they like. */
25 #ifndef EMACS_CONFIG_H
26 #define EMACS_CONFIG_H
29 /* These are all defined in the top-level Makefile by configure.
30 They're here only for reference. */
32 /* Define LISP_FLOAT_TYPE if you want emacs to support floating-point
34 #undef LISP_FLOAT_TYPE
36 /* Define GNU_MALLOC if you want to use the *new* GNU memory allocator. */
39 /* Define REL_ALLOC if you want to use the relocating allocator for
43 /* Define HAVE_X_WINDOWS if you want to use the X window system. */
46 /* Define HAVE_X11 if you want to use version 11 of X windows.
47 Otherwise, Emacs expects to use version 10. */
50 /* Define if using an X toolkit. */
53 /* Define this if you're using XFree386. */
56 /* Define HAVE_X_MENU if you want to use the X window menu system.
57 This appears to work on some machines that support X
61 /* Define if we have the X11R6 or newer version of Xt. */
64 /* If we're using any sort of window system, define MULTI_FRAME. */
69 /* Define USE_TEXT_PROPERTIES to support visual and other properties
71 #define USE_TEXT_PROPERTIES
73 /* Define USER_FULL_NAME to return a string
74 that is the user's full name.
75 It can assume that the variable `pw'
76 points to the password file entry for this user.
78 At some sites, the pw_gecos field contains
79 the user's full name. If neither this nor any other
80 field contains the right thing, use pw_name,
81 giving the user's login name, since that is better than nothing. */
82 #define USER_FULL_NAME pw->pw_gecos
84 /* Define AMPERSAND_FULL_NAME if you use the convention
85 that & in the full name stands for the login id. */
86 #undef AMPERSAND_FULL_NAME
88 /* Some things figured out by the configure script, grouped as they are in
90 #undef HAVE_SYS_TIMEB_H
91 #undef HAVE_SYS_TIME_H
94 #undef TIME_WITH_SYS_TIME
101 #undef HAVE_GETTIMEOFDAY
102 #undef HAVE_GETHOSTNAME
107 #undef TM_IN_SYS_TIME
113 #undef HAVE_LONG_FILE_NAMES
115 #undef CRAY_STACKSEG_END
116 #undef STACK_DIRECTION
121 #undef HAVE_XRMSETDATABASE
122 #undef HAVE_XSCREENRESOURCESTRING
123 #undef HAVE_XSCREENNUMBEROFSCREEN
124 #undef HAVE_XSETWMPROTOCOLS
135 #undef HAVE_RES_INIT /* For -lresolv on Suns. */
137 #undef HAVE_FPATHCONF
139 #undef HAVE_INET_SOCKETS
141 #undef HAVE_AIX_SMT_EXP
143 /* Define if `sys_siglist' is declared by <signal.h>. */
144 #undef SYS_SIGLIST_DECLARED
146 /* If using GNU, then support inline function declarations. */
148 #define INLINE __inline__
153 #undef EMACS_CONFIGURATION
155 /* The configuration script defines opsysfile to be the name of the
156 s/*.h file that describes the system type you are using. The file
157 is chosen based on the configuration name you give.
159 See the file ../etc/MACHINES for a list of systems and the
160 configuration names to use for them.
162 See s/template.h for documentation on writing s/*.h files. */
163 #undef config_opsysfile
164 #include config_opsysfile
166 /* The configuration script defines machfile to be the name of the
167 m/*.h file that describes the machine you are using. The file is
168 chosen based on the configuration name you give.
170 See the file ../etc/MACHINES for a list of machines and the
171 configuration names to use for them.
173 See m/template.h for documentation on writing m/*.h files. */
174 #undef config_machfile
175 #include config_machfile
177 /* These typedefs shouldn't appear when alloca.s or Makefile.in
178 includes config.h. */
180 #ifndef SPECIAL_EMACS_INT
181 typedef long EMACS_INT;
182 typedef unsigned long EMACS_UINT;
186 /* Load in the conversion definitions if this system
187 needs them and the source file being compiled has not
188 said to inhibit this. There should be no need for you
189 to alter these lines. */
192 #ifndef NO_SHORTNAMES
193 #include "../shortnames/remap.h"
194 #endif /* not NO_SHORTNAMES */
195 #endif /* SHORTNAMES */
197 /* Define `subprocesses' should be defined if you want to
198 have code for asynchronous subprocesses
199 (as used in M-x compile and M-x shell).
200 These do not work for some USG systems yet;
201 for the ones where they work, the s/*.h file defines this flag. */
205 /* #define subprocesses */
209 /* Define LD_SWITCH_SITE to contain any special flags your loader may need. */
210 #undef LD_SWITCH_SITE
212 /* Define C_SWITCH_SITE to contain any special flags your compiler needs. */
215 /* Define LD_SWITCH_X_SITE to contain any special flags your loader
216 may need to deal with X Windows. For instance, if you've defined
217 HAVE_X_WINDOWS above and your X libraries aren't in a place that
218 your loader can find on its own, you might want to add "-L/..." or
219 something similar. */
220 #undef LD_SWITCH_X_SITE
222 /* Define LD_SWITCH_X_SITE_AUX with an -R option
223 in case it's needed (for Solaris, for example). */
224 #undef LD_SWITCH_X_SITE_AUX
226 /* Define C_SWITCH_X_SITE to contain any special flags your compiler
227 may need to deal with X Windows. For instance, if you've defined
228 HAVE_X_WINDOWS above and your X include files aren't in a place
229 that your compiler can find on its own, you might want to add
230 "-I/..." or something similar. */
231 #undef C_SWITCH_X_SITE
233 /* Define the return type of signal handlers if the s-xxx file
234 did not already do so. */
235 #define RETSIGTYPE void
237 /* SIGTYPE is the macro we actually use. */
239 #define SIGTYPE RETSIGTYPE
242 /* The rest of the code currently tests the CPP symbol BSTRING.
243 Override any claims made by the system-description files.
244 Note that on some SCO version it is possible to have bcopy and not bcmp. */
246 #if defined (HAVE_BCOPY) && defined (HAVE_BCMP)
250 /* Define if you have the ANSI `strerror' function.
251 Otherwise you must have the variable `char *sys_errlist[]'. */
254 /* Non-ANSI C compilers usually don't have volatile. */
255 #ifndef HAVE_VOLATILE
261 #if 0 /* This should be taken care of by autoconf now. */
262 /* joe@zircon.uucp says that in order to use XFree386, you have to
263 link against -lXbsd, which insists on defining the random
265 faith@cs.unc.edu says this is bogus for Linux and several other OS's.
266 Eventually, we should have autoconf test for this. Anyone want to
268 #if defined (HAVE_XFREE386) && !defined (LINUX)
269 #define LIBX11_SYSTEM -lXbsd
274 /* Some of the files of Emacs which are intended for use with other
275 programs assume that if you have a config.h file, you must declare
278 This declaration shouldn't appear when alloca.s or Makefile.in
279 includes config.h. */
281 extern char *getenv ();
284 #endif /* EMACS_CONFIG_H */