1 dnl This is an autoconf script.
2 dnl To rebuild the `configure' script from this, execute the command
4 dnl in the directory containing this script. You must have autoconf
5 dnl version 1.4 or later.
7 dnl The following text appears in the resulting `configure' script,
8 dnl explaining how to rebuild it.
10 #### Configuration script for GNU Emacs
11 #### Copyright (C) 1992 Free Software Foundation, Inc.
13 ### Don't edit this script!
14 ### This script was automatically generated by the `autoconf' program
15 ### from the file `./configure.in'.
16 ### To rebuild it, execute the command
18 ### in the this directory. You must have autoconf version 1.4 or later.
20 ### This file is part of GNU Emacs.
22 ### GNU Emacs is free software; you can redistribute it and/or modify
23 ### it under the terms of the GNU General Public License as published by
24 ### the Free Software Foundation; either version 1, or (at your option)
25 ### any later version.
27 ### GNU Emacs is distributed in the hope that it will be useful,
28 ### but WITHOUT ANY WARRANTY; without even the implied warranty of
29 ### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
30 ### GNU General Public License for more details.
32 ### You should have received a copy of the GNU General Public License
33 ### along with GNU Emacs; see the file COPYING. If not, write to
34 ### the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
37 ### Since Emacs has configuration requirements that autoconf can't
38 ### meet, this file is an unholy marriage of custom-baked
39 ### configuration code and autoconf macros.
41 ### We use the m4 quoting characters [ ] (as established by the
42 ### autoconf system) to include large sections of raw sewage - Oops, I
43 ### mean, shell code - in the final configuration script.
45 ### Usage: configure config_name
47 ### If configure succeeds, it leaves its status in config.status.
48 ### If configure fails after disturbing the status quo,
49 ### config.status is removed.
52 ### Remove any more than one leading "." element from the path name.
53 ### If we don't remove them, then another "./" will be prepended to
54 ### the file name each time we use config.status, and the program name
55 ### will get larger and larger. This wouldn't be a problem, except
56 ### that since progname gets recorded in all the Makefiles this script
57 ### produces, move-if-change thinks they're different when they're
60 ### It would be nice if we could put the ./ in a \( \) group and then
61 ### apply the * operator to that, so we remove as many leading ./././'s
62 ### as are present, but some seds (like Ultrix's sed) don't allow you to
63 ### apply * to a \( \) group. Bleah.
64 progname="`echo $0 | sed 's:^\./\./:\./:'`"
69 short_usage="Usage: ${progname} CONFIGURATION [-OPTION[=VALUE] ...]
71 Set compilation and installation parameters for GNU Emacs, and report.
72 CONFIGURATION specifies the machine and operating system to build for.
73 --with-x Support the X Window System.
74 --with-x=no Don't support X.
75 --x-includes=DIR Search for X header files in DIR.
76 --x-libraries=DIR Search for X libraries in DIR.
77 --with-gcc Use GCC to compile Emacs.
78 --with-gcc=no Don't use GCC to compile Emacs.
79 --run-in-place Use libraries and data files directly out of the
81 --srcdir=DIR Look for source in DIR.
82 --prefix=DIR Install files below dir.
84 If successful, ${progname} leaves its status in config.status. If
85 unsuccessful after disturbing the status quo, it removes config.status."
88 #### Option processing.
90 ### Record all the arguments, so we can save them in config.status.
93 ### These values are used to comment and uncomment different values
94 ### for the path variables in the Makefile, to choose the installed
95 ### configuration or the run-in-place configuration.
96 rip_paths='#disabled# '
99 ### Establish some default values.
101 exec_prefix='${prefix}'
103 ### Don't use shift -- that destroys the argument list, which autoconf needs
104 ### to produce config.status. It turns out that "set - ${arguments}" doesn't
107 while [ $index -lt $# ]; do
108 index=`expr $index + 1`
109 arg=`eval echo '$'$index`
112 ## Anything starting with a hyphen we assume is an option.
115 ## Separate the switch name from the value it's being given.
118 opt=`echo ${arg} | sed 's:^-*\([^=]*\)=.*$:\1:'`
119 val=`echo ${arg} | sed 's:^-*[^=]*=\(.*\)$:\1:'`
123 ## If FOO is a boolean argument, --FOO is equivalent to
124 ## --FOO=yes. Otherwise, the value comes from the next
125 ## argument - see below.
126 opt=`echo ${arg} | sed 's:^-*\(.*\)$:\1:'`
132 ## Change `-' in the option name to `_'.
134 opt="`echo ${opt} | tr - _`"
136 ## Process the option.
139 ## Has the user specified which window systems they want to support?
140 "with_x" | "with_x11" | "with_x10" )
141 ## Make sure the value given was either "yes" or "no".
143 y | ye | yes ) val=yes ;;
146 (echo "${progname}: the \`--${optname}' option is supposed to have a boolean value.
147 Set it to either \`yes' or \`no'."
148 echo "${short_usage}") >&2
152 eval "${opt}=\"${val}\""
155 ## Has the user specified whether or not they want GCC?
156 "with_gcc" | "with_gnu_cc" )
157 ## Make sure the value given was either "yes" or "no".
159 y | ye | yes ) val=yes ;;
162 (echo "${progname}: the \`--${optname}' option is supposed to have a boolean value.
163 Set it to either \`yes' or \`no'."
164 echo "${short_usage}") >&2
168 eval "${opt}=\"${val}\""
171 ## Has the user specified a source directory?
173 ## If the value was omitted, get it from the next argument.
174 if [ "${valomitted}" = "yes" ]; then
175 ## Get the next argument from the argument list, if there is one.
176 if [ $index = $# ]; then
177 (echo "${progname}: You must give a value for the \`--${optname}' option, as in
178 \`--${optname}=FOO'."
179 echo "${short_usage}") >&2
182 index=`expr $index + 1`
183 val=`eval echo '$'$index`
188 ## Has the user tried to tell us where the X files are?
189 ## I think these are dopey, but no less than three alpha
190 ## testers, at large sites, have said they have their X files
191 ## installed in odd places.
193 ## If the value was omitted, get it from the next argument.
194 if [ "${valomitted}" = "yes" ]; then
195 ## Get the next argument from the argument list, if there is one.
196 if [ $index = $# ]; then
197 (echo "${progname}: You must give a value for the \`--${optname}' option, as in
198 \`--${optname}=FOO'."
199 echo "${short_usage}") >&2
202 index=`expr $index + 1`
203 val=`eval echo '$'$index`
206 C_SWITCH_X_SITE="-I\"${x_includes}\""
209 ## If the value was omitted, get it from the next argument.
210 if [ "${valomitted}" = "yes" ]; then
211 ## Get the next argument from the argument list, if there is one.
212 if [ $index = $# ]; then
213 (echo "${progname}: You must give a value for the \`--${optname}' option, as in
214 \`--${optname}=FOO'."
215 echo "${short_usage}") >&2
218 index=`expr $index + 1`
219 val=`eval echo '$'$index`
222 LD_SWITCH_X_SITE="-L\"${x_libraries}\""
225 ## Should this use the "development configuration"?
228 inst_paths='#disabled# '
231 ## Has the user specified an installation prefix?
233 ## If the value was omitted, get it from the next argument.
234 if [ "${valomitted}" = "yes" ]; then
235 ## Get the next argument from the argument list, if there is one.
236 if [ $index = $# ]; then
237 (echo "${progname}: You must give a value for the \`--${optname}' option, as in
238 \`--${optname}=FOO'."
239 echo "${short_usage}") >&2
242 index=`expr $index + 1`
243 val=`eval echo '$'$index`
248 ## Has the user specified an installation prefix?
250 ## If the value was omitted, get it from the next argument.
251 if [ "${valomitted}" = "yes" ]; then
252 ## Get the next argument from the argument list, if there is one.
253 if [ $index = $# ]; then
254 (echo "${progname}: You must give a value for the \`--${optname}' option, as in
255 \`--${optname}=FOO'."
256 echo "${short_usage}") >&2
259 index=`expr $index + 1`
260 val=`eval echo '$'$index`
265 ## Verbose flag, tested by autoconf macros.
270 ## Has the user asked for some help?
272 echo "${short_usage}" | more
276 ## We ignore all other options silently.
280 ## Anything not starting with a hyphen we assume is a
281 ## configuration name.
289 if [ "${configuration}" = "" ]; then
290 echo '- You did not tell me what kind of host system you want to configure.
291 - I will attempt to guess the kind of system this is.' 1>&2
292 guesssys=`echo ${progname} | sed 's/configure$/config.guess/'`
293 if configuration=`${guesssys}` ; then
294 echo "- Looks like this is a ${configuration}" 1>&2
296 echo '- Failed to guess the system type. You need to tell me.' 1>&2
297 echo "${short_usage}" >&2
302 #### Decide where the source is.
305 ## If it's not specified, see if `.' or `..' might work.
307 confdir=`echo $0 | sed 's|//|/|' | sed 's|/[^/]*$||'`
308 if [ -f $confdir/src/lisp.h -a -f $confdir/lisp/version.el ]; then
311 if [ -f "./src/lisp.h" -a -f "./lisp/version.el" ]; then
314 if [ -f "../src/lisp.h" -a -f "../lisp/version.el" ]; then
318 ${progname}: Neither the current directory nor its parent seem to
319 contain the Emacs sources. If you do not want to build Emacs in its
320 source tree, you should run \`${progname}' in the directory in which
321 you wish to build Emacs, using its \`--srcdir' option to say where the
322 sources may be found."
323 echo "${short_usage}") >&2
330 ## Otherwise, check if the directory they specified is okay.
332 if [ ! -d "${srcdir}" -o ! -f "${srcdir}/src/lisp.h" -o ! -f "${srcdir}/lisp/version.el" ]; then
334 ${progname}: The directory specified with the \`--srcdir' option,
335 \`${srcdir}', doesn't seem to contain the Emacs sources. You should
336 either run the \`${progname}' script at the top of the Emacs source
337 tree, or use the \`--srcdir' option to specify where the Emacs sources
339 echo "${short_usage}") >&2
345 #### Make srcdir absolute, if it isn't already. It's important to
346 #### avoid running the path through pwd unnecessary, since pwd can
347 #### give you automounter prefixes, which can go away.
351 ## We may be able to use the $PWD environment variable to make this
352 ## absolute. But sometimes PWD is inaccurate.
353 if [ "${PWD}" != "" ] && [ "`(cd ${PWD} ; pwd)`" = "`pwd`" ] ; then
356 srcdir="`(cd ${srcdir}; pwd)`"
359 * ) srcdir="`(cd ${srcdir}; pwd)`" ;;
362 #### Make sure that the source directory doesn't already have a
363 #### configured system in it.
364 if [ `pwd` != `(cd ${srcdir} && pwd)` ] \
365 && [ -f "${srcdir}/src/config.h" ] ; then
366 (echo "${progname}: the directory tree \`${srcdir}' is being used"
367 echo " as a build directory right now; it has been configured in its own"
368 echo " right. You can't use srcdir in this situation.") >&2
372 ### Make the necessary directories, if they don't exist.
373 for dir in ./src ./lib-src ./cpp ./oldXMenu ./etc ; do
374 if [ ! -d ${dir} ]; then
379 #### Given the configuration name, set machfile and opsysfile to the
380 #### names of the m/*.h and s/*.h files we should use.
382 ### Canonicalize the configuration name.
383 echo "Checking the configuration name."
384 if canonical=`${srcdir}/config.sub "${configuration}"` ; then : ; else
388 ### If you add support for a new configuration, add code to this
389 ### switch statement to recognize your configuration name and select
390 ### the appropriate operating system and machine description files.
392 ### You would hope that you could choose an m/*.h file pretty much
393 ### based on the machine portion of the configuration name, and an s-
394 ### file based on the operating system portion. However, it turns out
395 ### that each m/*.h file is pretty manufacturer-specific - for
396 ### example, apollo.h, hp9000s300.h, mega68k, news.h, and tad68k are
397 ### all 68000 machines; mips.h, pmax.h, and news-risc are all MIPS
398 ### machines. So we basically have to have a special case for each
399 ### configuration name.
401 ### As far as handling version numbers on operating systems is
402 ### concerned, make sure things will fail in a fixable way. If
403 ### /etc/MACHINES doesn't say anything about version numbers, be
404 ### prepared to handle anything reasonably. If version numbers
405 ### matter, be sure /etc/MACHINES says something about it.
407 ### Eric Raymond says we should accept strings like "sysvr4" to mean
408 ### "System V Release 4"; he writes, "The old convention encouraged
409 ### confusion between `system' and `release' levels'."
411 machine='' opsys='' unported='false'
412 case "${canonical}" in
415 ## Strictly speaking, we need the version of the alliant operating
416 ## system to choose the right machine file, but currently the
417 ## configuration name doesn't tell us enough to choose the right
418 ## one; we need to give alliants their own operating system name to
419 ## do this right. When someone cares, they can help us.
421 machine=alliant4 opsys=bsd4-2
424 machine=alliant-2800 opsys=bsd4-3
429 machine=altos opsys=usg5-2
434 machine=amdahl opsys=usg5-2-2
437 ## Appallings - I mean, Apollos - running Domain
439 machine=apollo opsys=bsd4-2
442 ## AT&T 3b2, 3b5, 3b15, 3b20
444 machine=att3b opsys=usg5-2-2
447 ## AT&T 3b1 - The Mighty Unix PC!
449 machine=7300 opsys=usg5-2-2
454 machine=dpx2 opsys=usg5-3
459 machine=sps7 opsys=usg5-2
462 ## CCI 5/32, 6/32 -- see "Tahoe".
465 ## I don't know what configuration name to use for this; config.sub
466 ## doesn't seem to know anything about it. Hey, Celerity users, get
468 celerity-celerity-bsd* )
469 machine=celerity opsys=bsd4-2
473 ## What operating systems does this chip run that Emacs has been
477 ## We'll use the catch-all code at the bottom to guess the
483 machine=convex opsys=bsd4-3
488 machine=intel386 opsys=usg5-3
492 cydra*-cydrome-sysv* )
493 machine=cydra5 opsys=usg5-3
496 ## Data General AViiON Machines
498 machine=aviion opsys=dgux
502 mips-dec-ultrix[0-3].* | mips-dec-ultrix4.0 | mips-dec-bsd4.2 )
503 machine=pmax opsys=bsd4-2
505 mips-dec-ultrix* | mips-dec-bsd* )
506 machine=pmax opsys=bsd4-3
509 machine=pmax opsys=osf1
512 ## Motorola Delta machines
513 m68*-motorola-sysv* )
514 machine=delta opsys=usg5-3
516 m88k-motorola-sysv4* )
517 machine=delta88k opsys=usg5-4
519 m88k-motorola-sysv* | m88k-motorola-m88kbcs* )
520 machine=delta88k opsys=usg5-3
525 machine=dual opsys=usg5-2
528 machine=dual opsys=unipl5-2
533 machine=elxsi opsys=usg5-2
538 machine=ns16000 opsys=umax
541 ## The GEC 93 - apparently, this port isn't really finished yet.
543 ## Gould Power Node and NP1
545 machine=gould opsys=bsd4-2
548 machine=gould opsys=bsd4-3
551 machine=gould-np1 opsys=bsd4-3
555 xps*-honeywell-sysv* )
556 machine=xps100 opsys=usg5-2
559 ## HP 9000 series 200 or 300
561 machine=hp9000s300 opsys=bsd4-3
563 ## HP/UX 7, 8 and 9 are supported on these machines.
566 *.08.* ) machine=hp9000s300 opsys=hpux8 ;;
567 *.09.* ) machine=hp9000s300 opsys=hpux9 ;;
568 *) machine=hp9000s300 opsys=hpux ;;
572 ## HP 9000 series 700 and 800, running HP/UX
574 machine=hp9000s800 opsys=hpux
577 machine=hp9000s800 opsys=hpux8
580 machine=hp9000s800 opsys=hpux9
583 ## HP 9000 series 700 and 800, running HP/UX
585 ## Cross-compilation? Nah!
587 *.08.* ) machine=hp9000s800 opsys=hpux8 ;;
588 *.09.* ) machine=hp9000s800 opsys=hpux9 ;;
589 *) machine=hp9000s800 opsys=hpux ;;
595 machine=orion opsys=bsd4-2
598 machine=orion105 opsys=bsd4-2
603 machine=ibmps2-aix opsys=usg5-2-2
605 i386-ibm-aix1.[23] | i386-ibm-aix* )
606 machine=ibmps2-aix opsys=usg5-3
609 machine=ibmrs6000 opsys=aix3-1
611 rs6000-ibm-aix3.2 | rs6000-ibm-aix* )
612 machine=ibmrs6000 opsys=aix3-2
615 machine=ibmrt opsys=bsd4-3
618 machine=ibmrt opsys=bsd4-2
621 machine=ibmrt opsys=bsd4-3
624 machine=ibmrt opsys=bsd4-2
627 machine=ibmrt opsys=bsd4-3
630 machine=ibmrt opsys=bsd4-3
633 machine=ibmrt-aix opsys=usg5-2-2
636 ## Integrated Solutions `Optimum V'
638 machine=isi-ov opsys=bsd4-2
641 machine=isi-ov opsys=bsd4-3
644 ## Intel 386 machines where we do care about the manufacturer
645 i[34]86-intsys-sysv* )
646 machine=is386 opsys=usg5-2-2
651 machine=i386 opsys=usg5-3
656 machine=symmetry opsys=bsd4-3
661 machine=i860 opsys=usg5-4
664 ## Silicon Graphics machines
665 ## Iris 2500 and Iris 2500 Turbo (aka the Iris 3030)
667 machine=irist opsys=iris3-5
669 m68*-sgi-iris3.6 | m68*-sgi-iris*)
670 machine=irist opsys=iris3-6
674 machine=iris4d opsys=irix3-3
676 mips-sgi-irix4.* | mips-sgi-irix* )
677 machine=iris4d opsys=irix4-0
682 machine=masscomp opsys=rtu
687 machine=mega68 opsys=bsd4-2
690 ## Workstations sold by MIPS
691 ## This is not necessarily all workstations using the MIPS processor -
692 ## Irises are produced by SGI, and DECstations by DEC.
694 ## etc/MACHINES lists mips.h and mips4.h as possible machine files,
695 ## and usg5-2-2 and bsd4-3 as possible OS files. The only guidance
696 ## it gives for choosing between the alternatives seems to be "Use
697 ## -machine=mips4 for RISCOS version 4; use -opsystem=bsd4-3 with
698 ## the BSD world." I'll assume that these are instructions for
699 ## handling two odd situations, and that every other situation
700 ## should use mips.h and usg5-2-2, they being listed first.
703 ## Fall through to the general code at the bottom to decide on the OS.
706 machine=mips4 opsys=bsd4-3
709 machine=mips opsys=bsd4-3
712 machine=mips opsys=usg5-2-2
716 m68*-next-mach* | m68*-next-bsd* )
717 machine=next opsys=mach2
720 ## The complete machine from National Semiconductor
722 machine=ns32000 opsys=usg5-2
726 m68*-ncr-sysv2* | m68*-ncr-sysvr2* )
727 machine=tower32 opsys=usg5-2-2
729 m68*-ncr-sysv3* | m68*-ncr-sysvr3* )
730 machine=tower32v3 opsys=usg5-3
735 machine=targon31 opsys=usg5-2-2
740 machine=nu opsys=usg5-2
745 machine=plexus opsys=usg5-2
749 ## I don't really have any idea what sort of processor the Pyramid has,
750 ## so I'm assuming it is its own architecture.
751 pyramid-pyramid-bsd* )
752 machine=pyramid opsys=bsd4-2
756 ns32k-sequent-bsd4.2 )
757 machine=sequent opsys=bsd4-2
759 ns32k-sequent-bsd4.3 )
760 machine=sequent opsys=bsd4-3
765 machine=news opsys=bsd4-2
768 machine=news opsys=bsd4-3
771 machine=news-risc opsys=bsd4-3
776 machine=stride opsys=usg5-2
780 *-sun-sunos* | *-sun-bsd* | *-sun-solaris* )
781 case "${canonical}" in
782 m68*-sunos1* ) machine=sun1 ;;
783 m68*-sunos2* ) machine=sun2 ;;
784 m68* ) machine=sun3 ;;
785 i[34]86* ) machine=sun386 ;;
786 sparc* ) machine=sparc ;;
789 case "${canonical}" in
790 *-sunos4.0* ) opsys=sunos4-0 ;;
791 *-sunos4.1.3* ) opsys=sunos4-1-3 ;;
792 *-sunos4* | *-sunos ) opsys=sunos4-1 ;;
793 *-sunos5* | *-solaris* ) opsys=sol2 ;;
800 machine=tad68k opsys=usg5-3
805 machine=tahoe opsys=bsd4-2
808 machine=tahoe opsys=bsd4-3
811 ## Tandem Integrity S2
813 machine=tandem-s2 opsys=usg5-3
817 m88k-tektronix-sysv3 )
818 machine=tekXD88 opsys=usg5-3
821 ## Tektronix 16000 box (6130?)
822 ns16k-tektronix-bsd* )
823 machine=ns16000 opsys=bsd4-2
826 ## src/m/tek4300.h hints that this is a m68k machine.
827 m68*-tektronix-bsd* )
828 machine=tex4300 opsys=bsd4-3
832 ## We seem to have lost the machine-description file titan.h!
834 machine=titan opsys=usg5-3
837 ## Ustation E30 (SS5E)
838 m68*-unisys-uniplus* )
839 machine=ustation opsystem=unipl5-2
845 case "${canonical}" in
846 *-bsd4.1 ) opsys=bsd4-1 ;;
847 *-bsd4.2 | *-ultrix[0-3].* | *-ultrix4.0 ) opsys=bsd4-2 ;;
848 *-bsd4.3 | *-ultrix* ) opsys=bsd4-3 ;;
849 *-bsd386 ) opsys=bsd386 ;;
850 *-sysv[01]* | *-sysvr[01]* ) opsys=usg5-0 ;;
851 *-sysv2* | *-sysvr2* ) opsys=usg5-2 ;;
852 *-vms* ) opsys=vms ;;
858 ns16k-whitechapel-* )
860 ## We don't know what sort of OS runs on these; we'll let the
861 ## operating system guessing code below try.
866 machine=wicat opsys=usg5-2
869 ## Intel 386 machines where we don't care about the manufacturer
872 case "${canonical}" in
873 *-isc1.* | *-isc2.[01]* ) opsys=386-ix ;;
874 *-isc2.2 ) opsys=isc2-2 ;;
875 *-isc* ) opsys=isc3-0 ;;
876 *-esix5* ) opsys=esix5r4 ;;
877 *-esix* ) opsys=esix ;;
878 *-xenix* ) opsys=xenix ;;
879 *-linux* ) opsys=linux ;;
880 *-sco3.2v4* ) opsys=sco4 ;;
881 *-bsd386* ) opsys=bsd386 ;;
882 *-386bsd ) opsys=386bsd ;;
883 ## Otherwise, we'll fall through to the generic opsys code at the bottom.
892 ### If the code above didn't choose an operating system, just choose
893 ### an operating system based on the configuration name. You really
894 ### only want to use this when you have no idea what the right
895 ### operating system is; if you know what operating systems a machine
896 ### runs, it's cleaner to make it explicit in the case statement
898 if [ x"${opsys}" = x ]; then
899 case "${canonical}" in
900 *-bsd4.[01] ) opsys=bsd4-1 ;;
901 *-bsd4.2 ) opsys=bsd4-2 ;;
902 *-bsd4.3 ) opsys=bsd4-3 ;;
903 *-sysv0 | *-sysvr0 ) opsys=usg5-0 ;;
904 *-sysv2 | *-sysvr2 ) opsys=usg5-2 ;;
905 *-sysv2.2 | *-sysvr2.2 ) opsys=usg5-2-2 ;;
906 *-sysv3 | *-sysvr3 ) opsys=usg5-3 ;;
907 *-sysv4 | *-sysvr4 ) opsys=usg5-4 ;;
908 *-sysv4.2 | *-sysvr4.2 ) opsys=usg5-4-2 ;;
916 (echo "${progname}: Emacs hasn't been ported to \`${canonical}' systems."
917 echo "${progname}: Check \`etc/MACHINES' for recognized configuration names."
922 machfile="m/${machine}.h"
923 opsysfile="s/${opsys}.h"
927 AC_CONFIG_HEADER(src/config.h)
930 #### Choose a compiler.
932 "yes" ) CC="gcc" GCC=1 ;;
938 #### Some other nice autoconf tests. If you add a test here which
939 #### should make an entry in src/config.h, don't forget to add an
940 #### #undef clause to src/config.h.in for autoconf to modify.
942 dnl checks for programs
948 dnl checks for UNIX variants that set `DEFS'
950 dnl checks for header files
951 AC_HAVE_HEADERS(sys/timeb.h sys/time.h)
953 AC_TIME_WITH_SYS_TIME
955 dnl checks for library files
956 AC_HAVE_LIBRARY(-ldnet)
958 dnl checks for typedefs
961 dnl checks for functions
963 AC_HAVE_FUNCS(gettimeofday gethostname dup2 rename closedir)
965 dnl checks for structure members
969 dnl checks for compiler characteristics
972 dnl checks for operating system services
975 dnl other checks for UNIX variants
979 #### Choose a window system.
980 echo "Checking window system."
985 window_system=${window_system}x11
988 window_system=${window_system}none
990 case "${with_x11}" in
992 window_system=${window_system}x11
995 case "${with_x10}" in
997 window_system=${window_system}x10
1001 ### If the user hasn't specified where we should find X, try
1002 ### letting autoconf figure that out.
1003 if [ "0${x_includes}" = 0 ] && [ "0${x_libraries}" = 0 ]; then
1007 if [ "0${x_includes}" != 0 ]; then
1008 C_SWITCH_X_SITE="-I\"${x_includes}\""
1010 if [ "0${x_libraries}" != 0 ]; then
1011 LD_SWITCH_X_SITE="-L\"${x_libraries}\""
1015 case "${window_system}" in
1016 "none" | "x11" | "x10" ) ;;
1018 echo " No window system specified. Looking for X11."
1020 if [ -r /usr/lib/libX11.a \
1021 -o -d /usr/include/X11 \
1022 -o -d /usr/X386/include \
1023 -o -d ${x_includes}/X11 ]; then
1028 echo "Don't specify the window system more than once." >&2
1033 case "${window_system}" in
1047 echo " Using no window system."
1051 ### If we're using X11, we should use the X menu package.
1059 #### Extract some information from the operating system and machine files.
1061 echo "Examining the machine- and system-dependent files to find out"
1062 echo " - which libraries the lib-src programs will want, and"
1063 echo " - whether the GNU malloc routines are usable."
1065 ### It's not important that this name contain the PID; you can't run
1066 ### two configures in the same directory and have anything work
1068 tempcname="conftest.c"
1071 #include "'${srcdir}'/src/'${opsysfile}'"
1072 #include "'${srcdir}'/src/'${machfile}'"
1073 #ifndef LIBS_MACHINE
1074 #define LIBS_MACHINE
1079 #ifndef C_SWITCH_SYSTEM
1080 #define C_SWITCH_SYSTEM
1082 @configure@ libsrc_libs=LIBS_MACHINE LIBS_SYSTEM
1083 @configure@ c_switch_system=C_SWITCH_SYSTEM
1086 @configure@ unexec=UNEXEC
1088 @configure@ unexec=unexec.o
1091 #ifdef SYSTEM_MALLOC
1092 @configure@ system_malloc=yes
1094 @configure@ system_malloc=no
1097 #ifndef C_DEBUG_SWITCH
1098 #define C_DEBUG_SWITCH -g
1101 #ifndef C_OPTIMIZE_SWITCH
1102 #define C_OPTIMIZE_SWITCH -O
1106 @configure@ CFLAGS=C_DEBUG_SWITCH C_OPTIMIZE_SWITCH
1108 @configure@ CFLAGS=C_DEBUG_SWITCH
1111 # The value of CPP is a quoted variable reference, so we need to do this
1112 # to get its actual value...
1113 CPP=`eval "echo $CPP"`
1114 eval `${CPP} -Isrc ${tempcname} \
1115 | grep '@configure@' \
1116 | sed -e 's/^@configure@ \([^=]*=\)\(.*\)$/\1"\2"/'`
1119 ### Compute the unexec source name from the object name.
1120 UNEXEC_SRC="`echo ${unexec} | sed 's/\.o/.c/'`"
1122 # Do the opsystem or machine files prohibit the use of the GNU malloc?
1123 # Assume not, until told otherwise.
1125 if [ "${system_malloc}" = "yes" ]; then
1128 (The GNU allocators don't work with this system configuration.)"
1131 if [ x"${REL_ALLOC}" = x ]; then
1132 REL_ALLOC=${GNU_MALLOC}
1138 #### Add the X libraries to the list, and check for some functions found there.
1139 CFLAGS_save="$CFLAGS"
1140 CFLAGS="${CFLAGS} ${LD_SWITCH_X_SITE}"
1142 AC_HAVE_LIBRARY(-lXbsd)
1145 if [ "${HAVE_X11}" = "yes" ] ; then
1146 LIBS="-lX11 ${LIBS}"
1149 AC_HAVE_FUNCS(XrmSetDatabase random)
1151 CFLAGS="$CFLAGS_save"
1154 case "${window_system}:${LIBS}" in
1156 if [ -d /usr/X386/include ]; then
1158 if [ "${C_SWITCH_X_SITE}" = "" ]; then
1159 C_SWITCH_X_SITE="-I/usr/X386/include"
1165 #### Find out which version of Emacs this is.
1166 version=`grep 'defconst[ ]*emacs-version' ${srcdir}/lisp/version.el \
1167 | sed -e 's/^.*"\([0-9][0-9]*\.[0-9][0-9]*\)\..*$/\1/'`
1168 if [ x"${version}" = x ]; then
1169 echo "${progname}: can't find current emacs version in
1170 \`${srcdir}/lisp/version.el'." >&2
1175 #### Specify what sort of things we'll be editing into Makefile and config.h.
1176 ### Use configuration here uncanonicalized to avoid exceeding size limits.
1178 AC_SUBST(configuration)
1181 AC_SUBST(c_switch_system)
1182 AC_SUBST(libsrc_libs)
1184 AC_SUBST(inst_paths)
1185 AC_SUBST(LD_SWITCH_X_SITE)
1186 AC_SUBST(C_SWITCH_X_SITE)
1189 AC_SUBST(exec_prefix)
1191 AC_DEFINE_UNQUOTED(config_machfile, "\"${machfile}\"")
1192 AC_DEFINE_UNQUOTED(config_opsysfile, "\"${opsysfile}\"")
1193 AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE, ${LD_SWITCH_X_SITE})
1194 AC_DEFINE_UNQUOTED(C_SWITCH_X_SITE, ${C_SWITCH_X_SITE})
1195 AC_DEFINE_UNQUOTED(UNEXEC_SRC, ${UNEXEC_SRC})
1198 if [ "${HAVE_X_WINDOWS}" = "yes" ] ; then
1199 ] AC_DEFINE(HAVE_X_WINDOWS) [
1201 if [ "${HAVE_X11}" = "yes" ] ; then
1202 ] AC_DEFINE(HAVE_X11) [
1204 if [ "${HAVE_XFREE386}" = "yes" ] ; then
1205 ] AC_DEFINE(HAVE_XFREE386) [
1207 if [ "${HAVE_X_MENU}" = "yes" ] ; then
1208 ] AC_DEFINE(HAVE_X_MENU) [
1210 if [ "${GNU_MALLOC}" = "yes" ] ; then
1211 ] AC_DEFINE(GNU_MALLOC) [
1213 if [ "${REL_ALLOC}" = "yes" ] ; then
1214 ] AC_DEFINE(REL_ALLOC) [
1216 if [ "${LISP_FLOAT_TYPE}" = "yes" ] ; then
1217 ] AC_DEFINE(LISP_FLOAT_TYPE) [
1221 #### Report on what we decided to do.
1224 Configured for \`${canonical}'.
1226 Where should the build process find the source code? ${srcdir}
1227 What operating system and machine description files should Emacs use?
1228 \`${opsysfile}' and \`${machfile}'
1229 What compiler should emacs be built with? ${CC} ${CFLAGS}
1230 Should Emacs use the GNU version of malloc? ${GNU_MALLOC}${GNU_MALLOC_reason}
1231 Should Emacs use the relocating allocator for buffers? ${REL_ALLOC}
1232 What window system should Emacs use? ${window_system}${x_includes+
1233 Where do we find X Windows header files? }${x_includes}${x_libraries+
1234 Where do we find X Windows libraries? }${x_libraries}