(ange-ftp-make-backup-files): Doc fix.
[emacs.git] / configure1.in
blobf394c9f45ee2575d682d96a2263737c8c7f7f712
1 dnl This is an autoconf script.
2 dnl To rebuild the `configure' script from this, execute the command
3 dnl     autoconf
4 dnl in the directory containing this script.  You must have autoconf
5 dnl version 1.4 or later.
6 dnl
7 dnl The following text appears in the resulting `configure' script,
8 dnl explaining how to rebuild it.
9 [#!/bin/sh
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
17 ###     autoconf
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.
40 ###
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.
44 ###
45 ### Usage: configure config_name
46 ###
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
58 ### not.
59 ###
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:^\./\./:\./:'`"
67 #### Usage messages.
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 
80                         source tree.
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.
91 arguments="$@"
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# '
97 inst_paths=''
99 ### Establish some default values.
100 prefix='/usr/local'
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
105 ### work portably.
106 index=0
107 while [ $index -lt $# ]; do
108   index=`expr $index + 1`
109   arg=`eval echo '$'$index`
110   case "${arg}" in
112     ## Anything starting with a hyphen we assume is an option.
113     -* )
115       ## Separate the switch name from the value it's being given.
116       case "${arg}" in
117         -*=*)
118           opt=`echo ${arg} | sed 's:^-*\([^=]*\)=.*$:\1:'`
119           val=`echo ${arg} | sed 's:^-*[^=]*=\(.*\)$:\1:'`
120           valomitted=no
121         ;;
122         -*)
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:'`
127           val="yes"
128           valomitted=yes
129         ;;
130       esac
132       ## Change `-' in the option name to `_'.
133       optname="${opt}"
134       opt="`echo ${opt} | tr - _`"
136       ## Process the option.
137       case "${opt}" in
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".
142           case "${val}" in
143             y | ye | yes )      val=yes ;;
144             n | no )            val=no  ;;
145             * )
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
149               exit 1
150             ;;
151           esac
152           eval "${opt}=\"${val}\""
153         ;;
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".
158           case "${val}" in
159             y | ye | yes )      val=yes ;;
160             n | no )            val=no  ;;
161             * )
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
165               exit 1
166             ;;
167           esac
168           eval "${opt}=\"${val}\""
169         ;;
171         ## Has the user specified a source directory?
172         "srcdir" )
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
180               exit 1
181             fi
182             index=`expr $index + 1`
183             val=`eval echo '$'$index`
184           fi
185           srcdir="${val}"
186         ;;
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.
192         "x_includes" )
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
200               exit 1
201             fi
202             index=`expr $index + 1`
203             val=`eval echo '$'$index`
204           fi
205           x_includes="${val}"
206           C_SWITCH_X_SITE="-I${x_includes}"
207         ;;
208         "x_libraries" )
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
216               exit 1
217             fi
218             index=`expr $index + 1`
219             val=`eval echo '$'$index`
220           fi
221           x_libraries="${val}"
222           LD_SWITCH_X_SITE="-L${x_libraries}"
223         ;;
225         ## Should this use the "development configuration"?
226         "run_in_place" )
227           rip_paths=''
228           inst_paths='#disabled# '
229         ;;
231         ## Has the user specifiec an installation prefix?
232         "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
240               exit 1
241             fi
242             index=`expr $index + 1`
243             val=`eval echo '$'$index`
244           fi
245           prefix="${val}"
246         ;;
248         ## Has the user specifiec an installation prefix?
249         "exec_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
257               exit 1
258             fi
259             index=`expr $index + 1`
260             val=`eval echo '$'$index`
261           fi
262           exec_prefix="${val}"
263         ;;
265         ## Has the user asked for some help?
266         "usage" | "help" )
267           echo "${short_usage}" | more
268           exit
269         ;;
271         ## We ignore all other options silently.
272       esac
273     ;;
275     ## Anything not starting with a hyphen we assume is a
276     ## configuration name.
277     *)
278       configuration=${arg}
279     ;;
281   esac
282 done
284 if [ "${configuration}" = "" ]; then
285   echo '- You did not tell me what kind of host system you want to configure.
286 - I will attempt to guess the kind of system this is.' 1>&2
287   guesssys=`echo ${progname} | sed 's/configure$/config.guess/'`
288   if configuration=`${guesssys}` ; then
289     echo "- Looks like this is a ${configuration}" 1>&2
290   else
291     echo '- Failed to guess the system type.  You need to tell me.' 1>&2
292     echo "${short_usage}" >&2
293     exit 1
294   fi
297 #### Decide where the source is.
298 case "${srcdir}" in
300   ## If it's not specified, see if  `.' or `..' might work.
301   "" )
302     confdir=`echo $0 | sed 's|//|/|' | sed 's|/[^/]*$||'`
303     if [ -f $confdir/src/lisp.h -a -f $confdir/lisp/version.el ]; then
304       srcdir="${confdir}"
305     else
306       if [ -f "./src/lisp.h" -a -f "./lisp/version.el" ]; then
307         srcdir='.'
308       else
309         if [ -f "../src/lisp.h" -a -f "../lisp/version.el" ]; then
310           srcdir='..'
311         else
312           (echo "\
313 ${progname}: Neither the current directory nor its parent seem to
314 contain the Emacs sources.  If you do not want to build Emacs in its
315 source tree, you should run \`${progname}' in the directory in which
316 you wish to build Emacs, using its \`--srcdir' option to say where the
317 sources may be found."
318             echo "${short_usage}") >&2
319           exit 1
320         fi
321       fi
322     fi
323   ;;
325   ## Otherwise, check if the directory they specified is okay.
326   * )
327     if [ ! -d "${srcdir}" -o ! -f "${srcdir}/src/lisp.h" -o ! -f "${srcdir}/lisp/version.el" ]; then
328       (echo "\
329 ${progname}: The directory specified with the \`--srcdir' option,
330 \`${srcdir}', doesn't seem to contain the Emacs sources.  You should
331 either run the \`${progname}' script at the top of the Emacs source
332 tree, or use the \`--srcdir' option to specify where the Emacs sources
333 are."
334        echo "${short_usage}") >&2
335       exit 1
336     fi
337   ;;
338 esac
340 #### Make srcdir absolute, if it isn't already.  It's important to
341 #### avoid running the path through pwd unnecessary, since pwd can
342 #### give you automounter prefixes, which can go away.
343 case "${srcdir}" in
344   /* ) ;;
345   . )
346     ## We may be able to use the $PWD environment variable to make this
347     ## absolute.  But sometimes PWD is inaccurate.
348     if [ "${PWD}" != "" ] && [ "`(cd ${PWD} ; pwd)`" = "`pwd`" ] ; then
349       srcdir="$PWD"
350     else
351       srcdir="`(cd ${srcdir}; pwd)`"
352     fi
353   ;;
354   *  ) srcdir="`(cd ${srcdir}; pwd)`" ;;
355 esac
357 #### Make sure that the source directory doesn't already have a
358 #### configured system in it.
359 if [ `pwd` != `(cd ${srcdir} && pwd)` ] \
360    && [ -f "${srcdir}/src/config.h" ] ; then
361   (echo "${progname}: the directory tree \`${srcdir}' is being used"
362    echo "   as a build directory right now; it has been configured in its own"
363    echo "   right.  You can't use srcdir in this situation.") >&2
364   exit 1
367 ### Make the necessary directories, if they don't exist.
368 if [ ! -d ./src ]; then
369   mkdir ./src
371 if [ ! -d ./lib-src ]; then
372   mkdir ./lib-src
374 if [ ! -d ./cpp ]; then
375   mkdir ./cpp
377 if [ ! -d ./oldXMenu ]; then
378   mkdir ./oldXMenu
380 if [ ! -d ./etc ]; then
381   mkdir ./etc
384 #### Given the configuration name, set machfile and opsysfile to the
385 #### names of the m/*.h and s/*.h files we should use.
387 ### Canonicalize the configuration name.
388 echo "Checking the configuration name."
389 if configuration=`${srcdir}/config.sub "${configuration}"` ; then : ; else
390   exit $?
393 ### If you add support for a new configuration, add code to this
394 ### switch statement to recognize your configuration name and select
395 ### the appropriate operating system and machine description files.
397 ### You would hope that you could choose an m/*.h file pretty much
398 ### based on the machine portion of the configuration name, and an s-
399 ### file based on the operating system portion.  However, it turns out
400 ### that each m/*.h file is pretty manufacturer-specific - for
401 ### example, apollo.h, hp9000s300.h, mega68k, news.h, and tad68k are
402 ### all 68000 machines; mips.h, pmax.h, and news-risc are all MIPS
403 ### machines.  So we basically have to have a special case for each
404 ### configuration name.
406 ### As far as handling version numbers on operating systems is
407 ### concerned, make sure things will fail in a fixable way.  If
408 ### /etc/MACHINES doesn't say anything about version numbers, be
409 ### prepared to handle anything reasonably.  If version numbers
410 ### matter, be sure /etc/MACHINES says something about it.
412 ### Eric Raymond says we should accept strings like "sysvr4" to mean
413 ### "System V Release 4"; he writes, "The old convention encouraged
414 ### confusion between `system' and `release' levels'."
416 machine='' opsys='' unported='false'
417 case "${configuration}" in
419   ## Alliant machines
420   ## Strictly speaking, we need the version of the alliant operating
421   ## system to choose the right machine file, but currently the
422   ## configuration name doesn't tell us enough to choose the right
423   ## one; we need to give alliants their own operating system name to
424   ## do this right.  When someone cares, they can help us.
425   fx80-alliant-* )
426     machine=alliant4 opsys=bsd4-2
427   ;;
428   i860-alliant-* )
429     machine=alliant-2800 opsys=bsd4-3
430   ;;
432   ## Altos 3068
433   m68*-altos-sysv* )
434     machine=altos opsys=usg5-2
435   ;;
436     
437   ## Amdahl UTS
438   580-amdahl-sysv* )
439     machine=amdahl opsys=usg5-2-2
440   ;;
442   ## Appallings - I mean, Apollos - running Domain
443   m68*-apollo* )
444     machine=apollo opsys=bsd4-2
445   ;;
447   ## AT&T 3b2, 3b5, 3b15, 3b20
448   we32k-att-sysv* )
449     machine=att3b opsys=usg5-2-2
450   ;;
452   ## AT&T 3b1 - The Mighty Unix PC!
453   m68*-att-sysv* )
454     machine=7300 opsys=usg5-2-2
455   ;;
457   ## Bull sps7
458   m68*-bull-sysv* )
459     machine=sps7 opsys=usg5-2
460   ;;
462   ## CCI 5/32, 6/32 -- see "Tahoe".
464   ## Celerity
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
467   ## in touch with us!
468   celerity-celerity-bsd* )
469     machine=celerity opsys=bsd4-2
470   ;;
472   ## Clipper
473   ## What operating systems does this chip run that Emacs has been
474   ## tested on?
475   clipper-* )
476     machine=clipper
477     ## We'll use the catch-all code at the bottom to guess the
478     ## operating system.
479   ;;
481   ## Convex
482   *-convex-bsd* )
483     machine=convex opsys=bsd4-3
484   ;;
486   ## Cubix QBx/386
487   i386-cubix-sysv* )
488     machine=intel386 opsys=usg5-3
489   ;;
491   ## Cydra 5
492   cydra*-cydrome-sysv* )
493     machine=cydra5 opsys=usg5-3
494   ;;
496   ## DECstations
497   mips-dec-ultrix[0-3].* | mips-dec-ultrix4.0 | mips-dec-bsd4.2 )
498     machine=pmax opsys=bsd4-2
499   ;;
500   mips-dec-ultrix* | mips-dec-bsd* )
501     machine=pmax opsys=bsd4-3
502   ;;
503   mips-dec-osf* )
504     machine=pmax opsys=osf1
505   ;;
507   ## Motorola Delta machines
508   m68*-motorola-sysv* )
509     machine=delta opsys=usg5-3
510   ;;
511   m88k-motorola-sysv* | m88k-motorola-m88kbcs* )
512     machine=delta88k opsys=usg5-3
513   ;;
515   ## Dual machines
516   m68*-dual-sysv* )
517     machine=dual opsys=usg5-2
518   ;;
519   m68*-dual-uniplus* )
520     machine=dual opsys=unipl5-2
521   ;;
523   ## Elxsi 6400
524   elxsi-elxsi-sysv* )
525     machine=elxsi opsys=usg5-2
526   ;;
528   ## Encore machines
529   ns16k-encore-bsd* )
530     machine=ns16000 opsys=umax
531   ;;
533   ## The GEC 93 - apparently, this port isn't really finished yet.
535   ## Gould Power Node and NP1
536   pn-gould-bsd4.2 )
537     machine=gould opsys=bsd4-2
538   ;;
539   pn-gould-bsd4.3 )
540     machine=gould opsys=bsd4-3
541   ;;
542   np1-gould-bsd* )
543     machine=gould-np1 opsys=bsd4-3
544   ;;
546   ## Honeywell XPS100
547   xps*-honeywell-sysv* )
548     machine=xps100 opsys=usg5-2
549   ;;
551   ## HP 9000 series 200 or 300
552   m68*-hp-bsd* )
553     machine=hp9000s300 opsys=bsd4-3
554   ;;
555   ## HP/UX 8 doesn't run on these machines, so use HP/UX 7.
556   m68*-hp-hpux* )
557     machine=hp9000s300 opsys=hpux
558   ;;
560   ## HP 9000 series 700 and 800, running HP/UX
561   hppa1.0-hp-hpux* )
562     machine=hp9000s800 opsys=hpux
563   ;;
564   hppa1.1-hp-hpux* )
565     machine=hp9000s800 opsys=hpux8
566   ;;
567   hppa*-hp-hpux* )
568     ## Cross-compilation?  Nah!
569     case "`uname -r`" in
570       *.08.* ) machine=hp9000s800 opsys=hpux ;;
571       *.09.* ) machine=hp9000s800 opsys=hpux8 ;;
572       *) machine=hp9000s800 opsys=hpux ;;
573     esac
574   ;;
576   ## Orion machines
577   orion-orion-bsd* )
578     machine=orion opsys=bsd4-2
579   ;;
580   clipper-orion-bsd* )
581     machine=orion105 opsys=bsd4-2
582   ;;
584   ## IBM machines
585   i386-ibm-aix1.1 )
586     machine=ibmps2-aix opsys=usg5-2-2
587   ;;
588   i386-ibm-aix1.[23] | i386-ibm-aix* )
589     machine=ibmps2-aix opsys=usg5-3
590   ;;
591   rs6000-ibm-aix3.1 )
592     machine=ibmrs6000 opsys=aix3-1
593   ;;
594   rs6000-ibm-aix3.2 | rs6000-ibm-aix* )
595     machine=ibmrs6000 opsys=aix3-2
596   ;;
597   romp-ibm-bsd4-3 )
598     machine=ibmrt opsys=bsd4-3
599   ;;    
600   romp-ibm-bsd4-2 )
601     machine=ibmrt opsys=bsd4-2
602   ;;
603   romp-ibm-aos4-3 )
604     machine=ibmrt opsys=bsd4-3
605   ;;    
606   romp-ibm-aos4-2 )
607     machine=ibmrt opsys=bsd4-2
608   ;;
609   romp-ibm-aos* )
610     machine=ibmrt opsys=bsd4-3
611   ;;
612   romp-ibm-bsd* )
613     machine=ibmrt opsys=bsd4-3
614   ;;
615   romp-ibm-aix* )
616     machine=ibmrt-aix opsys=usg5-2-2
617   ;;
619   ## Integrated Solutions `Optimum V'
620   m68*-isi-bsd4.2 )
621     machine=isi-ov opsys=bsd4-2
622   ;;
623   m68*-isi-bsd4.3 )
624     machine=isi-ov opsys=bsd4-3
625   ;;
627   ## Intel 386 machines where we do care about the manufacturer
628   i[34]86-intsys-sysv* )
629     machine=is386 opsys=usg5-2-2
630   ;;
631   ## Intel 386 machines where we don't care about the manufacturer
632   i[34]86-unknown-* )
633     machine=intel386
634     case "${configuration}" in
635       *-isc1.* | *-isc2.[01]* ) opsys=386-ix ;;
636       *-isc2.2 )                opsys=isc2-2 ;;
637       *-isc* )                  opsys=isc3-0 ;;
638       *-esix5* )                opsys=esix5r4 ;;
639       *-esix* )                 opsys=esix ;;
640       *-xenix* )                opsys=xenix ;;
641       *-linux* )                opsys=linux ;;
642       *-sco3.2v4* )             opsys=sco4 ;;
643       *-bsd386* )               opsys=bsd386 ;;
644       *-386bsd )                opsys=386bsd ;;
645       ## Otherwise, we'll fall through to the generic opsys code at the bottom.
646     esac
647   ;;
649   ## Intel 860
650   i860-*-sysvr4 )
651     machine=i860 opsys=usg5-4
652   ;;
654   ## Silicon Graphics machines
655   ## Iris 2500 and Iris 2500 Turbo (aka the Iris 3030)
656   m68*-sgi-iris3.5 )
657     machine=irist opsys=iris3-5
658   ;;
659   m68*-sgi-iris3.6 | m68*-sgi-iris*)
660     machine=irist opsys=iris3-6
661   ;;
662   ## Iris 4D
663   mips-sgi-irix3.* )
664     machine=iris4d opsys=irix3-3
665   ;;
666   mips-sgi-irix4.* | mips-sgi-irix* )
667     machine=iris4d opsys=irix4-0
668   ;;
670   ## Masscomp machines
671   m68*-masscomp-rtu )
672     machine=masscomp opsys=rtu
673   ;;
675   ## Megatest machines
676   m68*-megatest-bsd* )
677     machine=mega68 opsys=bsd4-2
678   ;;
680   ## Workstations sold by MIPS
681   ## This is not necessarily all workstations using the MIPS processor -
682   ## Irises are produced by SGI, and DECstations by DEC.
684   ## etc/MACHINES lists mips.h and mips4.h as possible machine files,
685   ## and usg5-2-2 and bsd4-3 as possible OS files.  The only guidance
686   ## it gives for choosing between the alternatives seems to be "Use
687   ## -machine=mips4 for RISCOS version 4; use -opsystem=bsd4-3 with
688   ## the BSD world."  I'll assume that these are instructions for
689   ## handling two odd situations, and that every other situation
690   ## should use mips.h and usg5-2-2, they being listed first.
691   mips-mips-usg* )
692     machine=mips4
693     ## Fall through to the general code at the bottom to decide on the OS.
694   ;;
695   mips-mips-riscos4* )
696     machine=mips4 opsys=bsd4-3
697   ;;
698   mips-mips-bsd* )
699     machine=mips opsys=bsd4-3
700   ;;
701   mips-mips-* )
702     machine=mips opsys=usg5-2-2
703   ;;
705   ## NeXT
706   m68*-next-mach* | m68*-next-bsd* )
707     machine=next opsys=mach2
708   ;;
710   ## The complete machine from National Semiconductor
711   ns32k-ns-genix* )
712     machine=ns32000 opsys=usg5-2
713   ;;
715   ## NCR machines
716   m68*-ncr-sysv2* | m68*-ncr-sysvr2* )
717     machine=tower32 opsys=usg5-2-2
718   ;;
719   m68*-ncr-sysv3* | m68*-ncr-sysvr3* )
720     machine=tower32v3 opsys=usg5-3
721   ;;
723   ## Nixdorf Targon 31
724   m68*-nixdorf-sysv* )
725     machine=targon31 opsys=usg5-2-2
726   ;;
728   ## Nu (TI or LMI)
729   m68*-nu-sysv* )
730     machine=nu opsys=usg5-2
731   ;;
733   ## Plexus
734   m68*-plexus-sysv* )
735     machine=plexus opsys=usg5-2
736   ;;
738   ## Prime EXL
739   i386-prime-sysv* )
740     machine=i386 opsys=usg5-3
741   ;;
743   ## Pyramid machines
744   ## I don't really have any idea what sort of processor the Pyramid has,
745   ## so I'm assuming it is its own architecture.
746   pyramid-pyramid-bsd* )
747     machine=pyramid opsys=bsd4-2
748   ;;
750   ## Sequent Balance
751   ns32k-sequent-bsd4.2 )
752     machine=sequent opsys=bsd4-2
753   ;;
754   ns32k-sequent-bsd4.3 )
755     machine=sequent opsys=bsd4-3
756   ;;
757   ## Sequent Symmetry
758   i386-sequent-bsd* )
759     machine=symmetry opsys=bsd4-3
760   ;;
762   ## SONY machines
763   m68*-sony-bsd4.2 )
764     machine=news opsys=bsd4-2
765   ;;
766   m68*-sony-bsd4.3 )
767     machine=news opsys=bsd4-3
768   ;;
769   mips-sony-bsd* )
770     machine=news-risc opsys=bsd4-3
771   ;;
773   ## Stride
774   m68*-stride-sysv* )
775     machine=stride opsys=usg5-2
776   ;;
778   ## Suns
779   *-sun-sunos* | *-sun-bsd* | *-sun-solaris* )
780     case "${configuration}" in
781       m68*-sunos1* )    machine=sun1 ;;
782       m68*-sunos2* )    machine=sun2 ;;
783       m68* )            machine=sun3 ;;
784       i[34]86* )        machine=sun386 ;;
785       sparc* )          machine=sparc ;;
786       * )               unported=true ;;
787     esac
788     case "${configuration}" in
789       *-sunos4.0*         ) opsys=sunos4-0 ;;
790       *-sunos4.1.3*       ) opsys=sunos4-1-3 ;;
791       *-sunos4* | *-sunos ) opsys=sunos4-1 ;;
792       *-sunos5* | *-solaris* ) opsys=sol2 ;;
793       *                   ) opsys=bsd4-2   ;;
794     esac
795   ;;
797   ## Tadpole 68k
798   m68*-tadpole-sysv* )
799     machine=tad68k opsys=usg5-3
800   ;;
802   ## Tahoe machines
803   tahoe-tahoe-bsd4.2 )
804     machine=tahoe opsys=bsd4-2
805   ;;
806   tahoe-tahoe-bsd4.3 )
807     machine=tahoe opsys=bsd4-3
808   ;;
810   ## Tandem Integrity S2
811   mips-tandem-sysv* )
812     machine=tandem-s2 opsys=usg5-3
813   ;;
815   ## Tektronix XD88
816   m88k-tektronix-sysv3 )
817   machine=tekXD88 opsys=usg5-3
818   ;;
820   ## Tektronix 16000 box (6130?)
821   ns16k-tektronix-bsd* )
822     machine=ns16000 opsys=bsd4-2
823   ;;
824   ## Tektronix 4300
825   ## src/m/tek4300.h hints that this is a m68k machine.
826   m68*-tektronix-bsd* )
827     machine=tex4300 opsys=bsd4-3
828   ;;
830   ## Titan P2 or P3
831   ## We seem to have lost the machine-description file titan.h!
832   titan-titan-sysv* )
833     machine=titan opsys=usg5-3
834   ;;
835   
836   ## Ustation E30 (SS5E)
837   m68*-unisys-uniplus* )
838     machine=ustation opsystem=unipl5-2
839   ;;
841   ## Vaxen.
842   vax-dec-* )
843     machine=vax
844     case "${configuration}" in
845       *-bsd4.1 )                                        opsys=bsd4-1 ;;
846       *-bsd4.2 | *-ultrix[0-3].* | *-ultrix4.0 )        opsys=bsd4-2 ;;
847       *-bsd4.3 | *-ultrix* )                            opsys=bsd4-3 ;;
848       *-bsd386 )                                        opsys=bsd386 ;;
849       *-sysv[01]* | *-sysvr[01]* )                      opsys=usg5-0 ;;
850       *-sysv2* | *-sysvr2* )                            opsys=usg5-2 ;;
851       *-vms* )                                          opsys=vms ;;
852       * )                                               unported=true
853     esac
854   ;;
856   ## Whitechapel MG1
857   ns16k-whitechapel-* )
858     machine=mg1
859     ## We don't know what sort of OS runs on these; we'll let the
860     ## operating system guessing code below try.
861   ;;
863   ## Wicat
864   m68*-wicat-sysv* )
865     machine=wicat opsys=usg5-2
866   ;;
868   * )
869     unported=true
870   ;;
871 esac
873 ### If the code above didn't choose an operating system, just choose
874 ### an operating system based on the configuration name.  You really
875 ### only want to use this when you have no idea what the right
876 ### operating system is; if you know what operating systems a machine
877 ### runs, it's cleaner to make it explicit in the case statement
878 ### above.
879 if [ x"${opsys}" = x ]; then
880   case "${configuration}" in
881     *-bsd4.[01] )       opsys=bsd4-1 ;;
882     *-bsd4.2 )          opsys=bsd4-2 ;;
883     *-bsd4.3 )          opsys=bsd4-3 ;;
884     *-sysv0 | *-sysvr0 )                opsys=usg5-0 ;;
885     *-sysv2 | *-sysvr2 )                opsys=usg5-2 ;;
886     *-sysv2.2 | *-sysvr2.2 )            opsys=usg5-2-2 ;;
887     *-sysv3 | *-sysvr3 )                opsys=usg5-3 ;;
888     *-sysv4 | *-sysvr4 )                opsys=usg5-4 ;;
889     *-sysv4.2 | *-sysvr4.2 )            opsys=usg5-4-2 ;;
890     * )
891       unported=true
892     ;;
893   esac
896 if $unported ; then
897   (echo "${progname}: Emacs hasn't been ported to \`${configuration}' systems."
898    echo "${progname}: Check \`etc/MACHINES' for recognized configuration names."
899   ) >&2
900   exit 1
903 machfile="m/${machine}.h"
904 opsysfile="s/${opsys}.h"
907 AC_PREPARE(lisp)
908 AC_CONFIG_HEADER(src/config.h)
911 #### Choose a compiler.
912 case ${with_gcc} in
913   "yes" ) CC="gcc" GCC=1 ;;
914   "no"  ) CC="cc"        ;;
915   * )
916     ] AC_PROG_CC [
917 esac
919 CFLAGS='-g'
920 if test -n "${GCC}"; then
921   CFLAGS='-g -O'
924 #### Some other nice autoconf tests.  If you add a test here which
925 #### should make an entry in src/config.h, don't forget to add an
926 #### #undef clause to src/config.h.in for autoconf to modify.
928 dnl checks for programs
929 AC_LN_S
930 AC_PROG_CPP
931 AC_PROG_INSTALL
933 dnl checks for UNIX variants that set `DEFS'
935 dnl checks for header files
936 AC_HAVE_HEADERS(sys/timeb.h sys/time.h)
937 AC_STDC_HEADERS
938 AC_TIME_WITH_SYS_TIME
940 dnl checks for typedefs
941 AC_RETSIGTYPE
943 dnl checks for functions
944 AC_ALLOCA
945 AC_HAVE_FUNCS(gettimeofday gethostname dup2 rename)
947 dnl checks for structure members
948 AC_STRUCT_TM
949 AC_TIMEZONE
951 dnl checks for compiler characteristics
952 AC_CONST
954 dnl checks for operating system services
956 dnl other checks for UNIX variants
960 #### Choose a window system.
961 echo "Checking window system."
963 window_system=''
964 case "${with_x}" in
965   yes )
966     window_system=${window_system}x11
967   ;;
968   no )
969     window_system=${window_system}none
970 esac
971 case "${with_x11}" in
972   yes )
973     window_system=${window_system}x11
974   ;;
975 esac
976 case "${with_x10}" in
977   yes )
978     window_system=${window_system}x10
979   ;;
980 esac
982 case "${window_system}" in
983   "none" | "x11" | "x10" ) ;;
984   "" )
985     echo "  No window system specifed.  Looking for X11."
986     window_system=none
987     if [ -r /usr/lib/libX11.a \
988          -o -d /usr/include/X11 \
989          -o -d /usr/X386/include \
990          -o -d ${x_includes}/X11 ]; then
991       window_system=x11
992     fi
993   ;;
994   * )
995     echo "Don't specify the window system more than once." >&2
996     exit 1
997   ;;
998 esac
1000 case "${window_system}" in
1001   x11 )
1002     HAVE_X_WINDOWS=yes
1003     HAVE_X11=yes
1004     echo "  Using X11."
1005   ;;
1006   x10 )
1007     HAVE_X_WINDOWS=yes
1008     HAVE_X11=no
1009     echo "  Using X10."
1010   ;;
1011   none )
1012     HAVE_X_WINDOWS=no
1013     HAVE_X11=no
1014     echo "  Using no window system."
1015   ;;
1016 esac
1018 ### If we're using X11, we should use the X menu package.
1019 HAVE_X_MENU=no
1020 case ${HAVE_X11} in
1021   yes )
1022     HAVE_X_MENU=yes
1023   ;;
1024 esac
1026 ### Check for XFree386.  It needs special hacks.
1027 lib_havexbsd=no
1029 AC_HAVE_LIBRARY( Xbsd , have_libxbsd=yes , have_libxbsd=no )
1031 if [ -n "${x_libraries}" ] && [ -f ${x_libraries}/libXbsd.a ]; then
1032   have_libxbsd=yes
1035 case ${window_system} in
1036   x11 )
1037     if [ -d /usr/X386/include ] && [ "${have_libxbsd}" = "yes" ]; then
1038       HAVE_XFREE386=yes
1039       if [ "${C_SWITCH_X_SITE}" = "" ]; then
1040         C_SWITCH_X_SITE="-I/usr/X386/include"
1041       fi
1042     fi
1043   ;;
1044 esac
1046 #### Extract some information from the operating system and machine files.
1048 echo "Examining the machine- and system-dependent files to find out"
1049 echo " - which libraries the lib-src programs will want, and"
1050 echo " - whether the GNU malloc routines are usable."
1052 ### It's not important that this name contain the PID; you can't run
1053 ### two configures in the same directory and have anything work
1054 ### anyway.
1055 tempcname="conftest.c"
1057 echo '
1058 #include "'${srcdir}'/src/'${opsysfile}'"
1059 #include "'${srcdir}'/src/'${machfile}'"
1060 #ifndef LIBS_MACHINE
1061 #define LIBS_MACHINE
1062 #endif
1063 #ifndef LIBS_SYSTEM
1064 #define LIBS_SYSTEM
1065 #endif
1066 #ifndef C_SWITCH_SYSTEM
1067 #define C_SWITCH_SYSTEM
1068 #endif
1069 @configure@ libsrc_libs=LIBS_MACHINE LIBS_SYSTEM
1070 @configure@ c_switch_system=C_SWITCH_SYSTEM
1072 #ifdef UNEXEC
1073 @configure@ unexec=UNEXEC
1074 #else
1075 @configure@ unexec=unexec.o
1076 #endif
1078 #ifdef SYSTEM_MALLOC
1079 @configure@ system_malloc=yes
1080 #else
1081 @configure@ system_malloc=no
1082 #endif
1083 ' > ${tempcname}
1084 # The value of CPP is a quoted variable reference, so we need to do this
1085 # to get its actual value...
1086 foo=`eval "echo $CPP"`
1087 eval `${foo} ${tempcname} \
1088        | grep '@configure@' \
1089        | sed -e 's/^@configure@ \([^=]*=\)\(.*\)$/\1"\2"/'`
1090 rm ${tempcname}
1092 ### Compute the unexec source name from the object name.
1093 UNEXEC_SRC="`echo ${unexec} | sed 's/\.o/.c/'`"
1095 # Do the opsystem or machine files prohibit the use of the GNU malloc?
1096 # Assume not, until told otherwise.
1097 GNU_MALLOC=yes
1098 if [ "${system_malloc}" = "yes" ]; then
1099   GNU_MALLOC=no
1100   GNU_MALLOC_reason="
1101   (The GNU allocators don't work with this system configuration.)"
1104 if [ x"${REL_ALLOC}" = x ]; then
1105   REL_ALLOC=${GNU_MALLOC}
1108 LISP_FLOAT_TYPE=yes
1111 #### Find out which version of Emacs this is.
1112 version=`grep 'defconst[         ]*emacs-version' ${srcdir}/lisp/version.el \
1113          | sed -e 's/^.*"\([0-9][0-9]*\.[0-9][0-9]*\)\..*$/\1/'`
1114 if [ x"${version}" = x ]; then
1115   echo "${progname}: can't find current emacs version in
1116         \`${srcdir}/lisp/version.el'." >&2
1117   exit 1
1121 #### Specify what sort of things we'll be editing into Makefile and config.h.
1123 AC_SUBST(configuration)
1124 AC_SUBST(version)
1125 AC_SUBST(srcdir)
1126 AC_SUBST(c_switch_system)
1127 AC_SUBST(libsrc_libs)
1128 AC_SUBST(rip_paths)
1129 AC_SUBST(inst_paths)
1130 AC_SUBST(LD_SWITCH_X_SITE)
1131 AC_SUBST(C_SWITCH_X_SITE)
1132 AC_SUBST(CFLAGS)
1133 AC_SUBST(prefix)
1134 AC_SUBST(exec_prefix)
1136 AC_DEFINE_UNQUOTED(config_machfile,  "\"${machfile}\"")
1137 AC_DEFINE_UNQUOTED(config_opsysfile, "\"${opsysfile}\"")
1138 AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE, ${LD_SWITCH_X_SITE})
1139 AC_DEFINE_UNQUOTED(C_SWITCH_X_SITE,  ${C_SWITCH_X_SITE})
1140 AC_DEFINE_UNQUOTED(UNEXEC_SRC,       ${UNEXEC_SRC})
1143 if [ "${HAVE_X_WINDOWS}" = "yes" ] ; then
1144   ] AC_DEFINE(HAVE_X_WINDOWS) [
1146 if [ "${HAVE_X11}" = "yes" ] ; then
1147   ] AC_DEFINE(HAVE_X11) [
1149 if [ "${HAVE_XFREE386}" = "yes" ] ; then
1150   ] AC_DEFINE(HAVE_XFREE386) [
1152 if [ "${HAVE_X_MENU}" = "yes" ] ; then
1153   ] AC_DEFINE(HAVE_X_MENU) [
1155 if [ "${GNU_MALLOC}" = "yes" ] ; then
1156   ] AC_DEFINE(GNU_MALLOC) [
1158 if [ "${REL_ALLOC}" = "yes" ] ; then
1159   ] AC_DEFINE(REL_ALLOC) [
1161 if [ "${LISP_FLOAT_TYPE}" = "yes" ] ; then
1162   ] AC_DEFINE(LISP_FLOAT_TYPE) [
1166 #### Report on what we decided to do.
1167 echo "
1169 Configured for \`${configuration}'.
1171   Where should the build process find the source code?    ${srcdir}
1172   What operating system and machine description files should Emacs use?
1173         \`${opsysfile}' and \`${machfile}'
1174   What compiler should emacs be built with?               ${CC} ${CFLAGS}
1175   Should Emacs use the GNU version of malloc?             ${GNU_MALLOC}${GNU_MALLOC_reason}
1176   Should Emacs use the relocating allocator for buffers?  ${REL_ALLOC}
1177   What window system should Emacs use?                    ${window_system}${x_includes+
1178   Where do we find X Windows header files?                }${x_includes}${x_libraries+
1179   Where do we find X Windows libraries?                   }${x_libraries}
1183 AC_OUTPUT(Makefile)