dnl To rebuild the `configure' script from this, execute the command
dnl autoconf
dnl in the directory containing this script. You must have autoconf
-dnl version 1.4 or later.
+dnl version 1.7 or later.
dnl
dnl The following text appears in the resulting `configure' script,
dnl explaining how to rebuild it.
[#!/bin/sh
#### Configuration script for GNU Emacs
-#### Copyright (C) 1992 Free Software Foundation, Inc.
+#### Copyright (C) 1992, 1994 Free Software Foundation, Inc.
### Don't edit this script!
### This script was automatically generated by the `autoconf' program
### from the file `./configure.in'.
### To rebuild it, execute the command
### autoconf
-### in the this directory. You must have autoconf version 1.4 or later.
+### in the this directory. You must have autoconf version 1.7 or later.
### This file is part of GNU Emacs.
### GNU Emacs is free software; you can redistribute it and/or modify
### it under the terms of the GNU General Public License as published by
-### the Free Software Foundation; either version 1, or (at your option)
+### the Free Software Foundation; either version 2, or (at your option)
### any later version.
### GNU Emacs is distributed in the hope that it will be useful,
lockdir='${statedir}/emacs/lock'
archlibdir='${libdir}/emacs/${version}/${configuration}'
+# On Sun systems, people sometimes set up the variable CPP
+# with a value that is a directory, not an executable at all.
+# Detect that case, and ignore that value.
+if [ "x$CPP" != x ] && [ -d "$CPP" ];
+then
+ CPP=
+fi
+
# We cannot use this variable in the case statement below, because many
# /bin/sh's have broken semantics for "case". Unfortunately, you must
# actually edit the clause itself.
CONFIGURATION specifies the machine and operating system to build for.
--with-x Support the X Window System.
--with-x=no Don't support X.
---x-includes=DIR Search for X header files in DIR.
---x-libraries=DIR Search for X libraries in DIR.
+--with-x-toolkit Use an X toolkit.
+--with-x-toolkit=no Don't use an X toolkit.
--with-gcc Use GCC to compile Emacs.
--with-gcc=no Don't use GCC to compile Emacs.
+--x-includes=DIR Search for X header files in DIR.
+--x-libraries=DIR Search for X libraries in DIR.
--run-in-place Use libraries and data files directly out of the
source tree.
--single-tree=DIR Has the effect of creating a directory tree at DIR
### Record all the arguments, so we can save them in config.status.
arguments="$@"
+### Shell Magic: Quote the quoted arguments in ARGUMENTS. At a later date,
+### in order to get the arguments back in $@, we have to do an
+### `eval set x "$quoted_arguments"; shift'.
+quoted_arguments=
+for i in "$@"; do
+ quoted_arguments="$quoted_arguments '$i'"
+done
+
### Don't use shift -- that destroys the argument list, which autoconf needs
### to produce config.status. It turns out that "set - ${arguments}" doesn't
### work portably.
-index=0
-while [ $index -lt $# ]; do
- index=`expr $index + 1`
- arg=`eval echo '$'$index`
+### However, it also turns out that many shells cannot expand ${10} at all.
+### So using an index variable doesn't work either. It is possible to use
+### some shell magic to make 'set x "$arguments"; shift' work portably.
+while [ $# != 0 ]; do
+ arg="$1"; shift
case "${arg}" in
## Anything starting with a hyphen we assume is an option.
eval "${opt}=\"${val}\""
;;
+ ## Has the user specified which toolkit they want to support?
+ "with_x_toolkit" )
+ ## Make sure the value given was either "yes" or "no".
+ case "${val}" in
+ y | ye | yes ) val=athena ;;
+ n | no ) val=no ;;
+ l | lu | luc | luci | lucid ) val=lucid ;;
+ a | at | ath | athe | athena ) val=athena ;;
+ m | mo | mot | moti | motif ) val=motif ;;
+ o | op | ope | open | open- | open-l | open-lo \
+ | open-loo | open-look ) val=open-look ;;
+ * )
+ (echo "${progname}: the \`--${optname}' option is supposed to have a value
+which is \`yes', \`no', \`lucid', \`athena', \`motif' or \`open-look'."
+ echo "${short_usage}") >&2
+ exit 1
+ ;;
+ esac
+ eval "${opt}=\"${val}\""
+ ;;
+
## Has the user specified whether or not they want GCC?
"with_gcc" | "with_gnu_cc" )
## Make sure the value given was either "yes" or "no".
## If the value was omitted, get it from the next argument.
if [ "${valomitted}" = "yes" ]; then
## Get the next argument from the argument list, if there is one.
- if [ $index = $# ]; then
+ if [ $# = 0 ]; then
(echo "${progname}: You must give a value for the \`--${optname}' option, as in
\`--${optname}=FOO'."
echo "${short_usage}") >&2
exit 1
fi
- index=`expr $index + 1`
- val=`eval echo '$'$index`
+ val="$1"; shift
fi
srcdir="${val}"
;;
## If the value was omitted, get it from the next argument.
if [ "${valomitted}" = "yes" ]; then
## Get the next argument from the argument list, if there is one.
- if [ $index = $# ]; then
+ if [ $# = 0 ]; then
(echo "${progname}: You must give a value for the \`--${optname}' option, as in
\`--${optname}=/usr/local/X11/include'."
echo "${short_usage}") >&2
exit 1
fi
- index=`expr $index + 1`
- val=`eval echo '$'$index`
+ val="$1"; shift
fi
x_includes="${val}"
;;
## If the value was omitted, get it from the next argument.
if [ "${valomitted}" = "yes" ]; then
## Get the next argument from the argument list, if there is one.
- if [ $index = $# ]; then
+ if [ $# = 0 ]; then
(echo "${progname}: You must give a value for the \`--${optname}' option, as in
\`--${optname}=/usr/local/X11/lib'."
echo "${short_usage}") >&2
exit 1
fi
- index=`expr $index + 1`
- val=`eval echo '$'$index`
+ val="$1"; shift
fi
x_libraries="${val}"
;;
run_in_place=1
;;
+ ## Should this use the "single tree" configuration?
+ "single_tree" )
+ run_in_place=
+ single_tree=1
+ ;;
+
## Has the user specified one of the path options?
prefix | exec_prefix | bindir | libdir | etcdir | datadir | \
archlibdir | statedir | mandir | infodir | lispdir | lockdir | \
lisppath | locallisppath )
## If the value was omitted, get it from the next argument.
if [ "${valomitted}" = "yes" ]; then
- if [ $index = $# ]; then
+ if [ $# = 0 ]; then
(echo \
"$progname: You must give a value for the \`--${optname}' option,";
echo \
echo "$short_usage") >&2
exit 1
fi
- index=`expr $index + 1`
- val=`eval echo '$'$index`
+ val="$1"; shift
fi
- eval "${optname}=\"${val}\""
- eval "${optname}_specified=1"
+ eval "${opt}=\"${val}\""
+ eval "${opt}_specified=1"
;;
## Verbose flag, tested by autoconf macros.
esac
done
+### Get the arguments back. See the diatribe on Shell Magic above.
+eval set x "$quoted_arguments"; shift
+
if [ "${configuration}" = "" ]; then
echo '- You did not tell me what kind of host system you want to configure.
- I will attempt to guess the kind of system this is.' 1>&2
echo " use GNU make. If you do not have GNU make, then you must"
echo " now do \`make distclean' in ${srcdir},"
echo " and then run ${progname} again.") >&2
- # We need a multi-line sed script, which cannot go in a makefile.
- vpath_sed='-f vpath.sed'
-else
- # Do the normal substitution for VPATH. This will not crash non-GNU make.
- vpath_sed=]'AC_QUOTE_SQUOTE(AC_QUOTE_SQUOTE('-e '\''s|^\(VPATH *=\).*$$|\1 ='\''"${srcdir}/${subdir}|"'))'[
+ extrasub='/^VPATH[ ]*=/c\
+vpath %.c $(srcdir)\
+vpath %.h $(srcdir)\
+vpath %.y $(srcdir)\
+vpath %.l $(srcdir)\
+vpath %.s $(srcdir)\
+vpath %.in $(srcdir)'
fi
-] AC_SUBST(vpath_sed) [
### Make the necessary directories, if they don't exist.
-for dir in ./src ./lib-src ./cpp ./oldXMenu ./etc ; do
+for dir in ./src ./lib-src ./cpp ./oldXMenu ./lwlib ./etc ; do
if [ ! -d ${dir} ]; then
mkdir ${dir}
fi
;;
## Motorola Delta machines
- m68*-motorola-sysv* )
+ m68k-motorola-sysv* | m68000-motorola-sysv* )
machine=delta opsys=usg5-3
+ if [ -z "`type gnucc | grep 'not found'`" ]
+ then CC=gnucc
+ else
+ if [ -z "`type gcc | grep 'not found'`" ]
+ then CC=gcc
+ else CC=cc
+ fi
+ fi
;;
m88k-motorola-sysv4* )
machine=delta88k opsys=usg5-4
machine=gould-np1 opsys=bsd4-3
;;
+ ## Harris Night Hawk machines running CX/UX (a 5000 looks just like a 4000
+ ## as far as Emacs is concerned).
+ m88k-harris-cxux* )
+ # Build needs to be different on 7.0 and later releases
+ case "`uname -r`" in
+ [56].[0-9] ) machine=nh4000 opsys=cxux ;;
+ [7].[0-9] ) machine=nh4000 opsys=cxux7 ;;
+ esac
+ ;;
+ ## Harris ecx or gcx running CX/UX (Series 1200, Series 3000)
+ m68k-harris-cxux* )
+ machine=nh3000 opsys=cxux
+ ;;
+
## Honeywell XPS100
xps*-honeywell-sysv* )
machine=xps100 opsys=usg5-2
machine=symmetry opsys=bsd4-3
;;
+ ## Unspecified sysv on an ncr machine defaults to svr4.
+ i[34]86-ncr-sysv* )
+ machine=intel386 opsys=usg5-4
+ ;;
+
## Intel 860
- i860-*-sysvr4* )
+ i860-*-sysv4* )
machine=i860 opsys=usg5-4
;;
;;
mips-mips-riscos4* )
machine=mips4 opsys=bsd4-3
+ NON_GNU_CC="cc -systype bsd43"
+ NON_GNU_CPP="cc -systype bsd43 -E"
;;
mips-mips-bsd* )
machine=mips opsys=bsd4-3
;;
## NeXT
- m68*-next-mach* | m68*-next-bsd* )
+ m68*-next-* )
machine=next opsys=mach2
;;
*-sunos4.0* ) opsys=sunos4-0 ;;
*-sunos4.1.3* ) opsys=sunos4-1-3 ;;
*-sunos4* | *-sunos ) opsys=sunos4-1 ;;
- *-sunos5* | *-solaris* ) opsys=sol2 ;;
+ *-sunos5.3* | *-solaris2.3* )
+ opsys=sol2-3
+ NON_GNU_CPP=/usr/ccs/lib/cpp
+ ;;
+ *-sunos5* | *-solaris* )
+ opsys=sol2
+ NON_GNU_CPP=/usr/ccs/lib/cpp
+ ;;
* ) opsys=bsd4-2 ;;
esac
;;
*-bsd386* ) opsys=bsd386 ;;
*-386bsd* ) opsys=386bsd ;;
*-netbsd* ) opsys=netbsd ;;
+ *-nextstep* ) opsys=mach2 ;;
## Otherwise, we'll fall through to the generic opsys code at the bottom.
esac
;;
[
#### Choose a compiler.
+if [ "x$CC" = x ]
+then cc_specified=1
+fi
+
case ${with_gcc} in
"yes" ) CC="gcc" GCC=1 ;;
- "no" ) CC="cc" ;;
+ "no" )
+ if [ "x$CC" = x ]
+ then true;
+ else CC=cc;
+ fi
+ ;;
* )
] AC_PROG_CC [
esac
+#### Some systems specify a CPP to use unless we are using GCC.
+#### Now that we know whether we are using GCC, we can decide whether
+#### to use that one.
+if [ "x$NON_GNU_CPP" = x ] || [ x$GCC = x1 ] || [ "x$CPP" = x ]
+then true
+else
+ CPP="$NON_GNU_CPP"
+fi
+
+#### Some systems specify a CC to use unless we are using GCC.
+#### Now that we know whether we are using GCC, we can decide whether
+#### to use that one.
+if [ "x$NON_GNU_CC" = x ] || [ x$GCC = x1 ] || [ x$cc_specified = x1 ]
+then true
+else
+ CC="$NON_GNU_CC"
+fi
+
#### Some other nice autoconf tests. If you add a test here which
#### should make an entry in src/config.h, don't forget to add an
#### #undef clause to src/config.h.in for autoconf to modify.
dnl checks for UNIX variants that set `DEFS'
dnl checks for header files
-AC_HAVE_HEADERS(sys/timeb.h sys/time.h)
+AC_HAVE_HEADERS(sys/timeb.h sys/time.h unistd.h)
AC_STDC_HEADERS
AC_TIME_WITH_SYS_TIME
+dnl In Autoconf 1.8 use AC_SYS_SIGLIST_DECLARED instead of this.
+AC_COMPILE_CHECK(sys_siglist declaration in signal.h or unistd.h,
+ [#include <signal.h>
+/* NetBSD declares sys_siglist in <unistd.h>. */
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif], [char *msg = *(sys_siglist + 1);],
+ AC_DEFINE(SYS_SIGLIST_DECLARED))
dnl checks for typedefs
AC_RETSIGTYPE
dnl other checks for UNIX variants
[
-
#### Choose a window system.
echo "Checking window system."
;;
esac
-case "${window_system}" in
- "" | "x11" )
- ### If the user hasn't specified where we should find X, try
- ### letting autoconf figure that out.
- if [ -z "${x_includes}" ] && [ -z "${x_libraries}" ]; then
- ]
- AC_FIND_X
- [
- fi
- if [ -n "${x_includes}" ] || [ -n "${x_libraries}" ]; then
- window_system=x11
- fi
- ;;
-esac
-
[ -z "${window_system}" ] && window_system=none
[ -n "${x_libraries}" ] && LD_SWITCH_X_SITE="-L${x_libraries}"
+[ -n "${x_libraries}" ] && LD_SWITCH_X_SITE_AUX="-R${x_libraries}"
[ -n "${x_includes}" ] && C_SWITCH_X_SITE="-I${x_includes}"
# Avoid forcing the search of /usr/include before fixed include files.
HAVE_X_WINDOWS=yes
HAVE_X11=yes
echo " Using X11."
+ case "${with_x_toolkit}" in
+ athena | lucid )
+ USE_X_TOOLKIT=LUCID
+ echo " Using Xt toolkit."
+ ;;
+ motif )
+ USE_X_TOOLKIT=MOTIF
+ echo " Using Motif toolkit."
+ ;;
+ open-look )
+ USE_X_TOOLKIT=OPEN_LOOK
+ echo " Using Open-Look toolkit."
+ ;;
+ * )
+ USE_X_TOOLKIT=no
+ echo " Using Xlib directly."
+ ;;
+ esac
;;
x10 )
HAVE_X_WINDOWS=yes
HAVE_X11=no
+ USE_X_TOOLKIT=no
echo " Using X10."
;;
none )
echo " Using no window system."
;;
esac
+X_TOOLKIT_TYPE=$USE_X_TOOLKIT
### If we're using X11, we should use the X menu package.
HAVE_X_MENU=no
#ifndef C_SWITCH_SYSTEM
#define C_SWITCH_SYSTEM
#endif
+#ifndef C_SWITCH_MACHINE
+#define C_SWITCH_MACHINE
+#endif
configure___ libsrc_libs=LIBS_MACHINE LIBS_SYSTEM
configure___ c_switch_system=C_SWITCH_SYSTEM
+configure___ c_switch_machine=C_SWITCH_MACHINE
#ifndef LIB_X11_LIB
#define LIB_X11_LIB -lX11
#### Add the libraries to LIBS and check for some functions.
]
-DEFS="$c_switch_system $DEFS"
+DEFS="$c_switch_system $c_switch_machine $DEFS"
LIBS="$libsrc_libs"
dnl If found, this defines HAVE_LIBDNET, which m/pmax.h checks,
if test "${HAVE_X11}" = "yes"; then
DEFS="$C_SWITCH_X_SITE $DEFS"
LIBS="$LD_SWITCH_X_SITE $LIBX $LIBS"
- AC_HAVE_FUNCS(XrmSetDatabase XScreenResourceString XScreenNumberOfScreen)
+ AC_HAVE_FUNCS(XrmSetDatabase XScreenResourceString XScreenNumberOfScreen XSetWMProtocols)
fi
AC_ALLOCA
# logb and frexp are found in -lm on most systems.
AC_HAVE_LIBRARY(-lm)
-AC_HAVE_FUNCS(gettimeofday gethostname dup2 rename closedir mkdir rmdir random bcopy logb frexp ftime res_init)
+AC_HAVE_FUNCS(gettimeofday gethostname dup2 rename closedir mkdir rmdir \
+random bcopy bcmp logb frexp fmod drem ftime res_init setsid strerror)
ok_so_far=true
AC_FUNC_CHECK(socket, , ok_so_far=)
[
#### Find out which version of Emacs this is.
version=`grep 'defconst[ ]*emacs-version' ${srcdir}/lisp/version.el \
- | sed -e 's/^.*"\([0-9][0-9]*\.[0-9][0-9]*\)\..*$/\1/'`
+ | sed -e 's/^.*"\([0-9][0-9]*\.[0-9][0-9]*\)[."].*$/\1/'`
if [ x"${version}" = x ]; then
echo "${progname}: can't find current emacs version in
\`${srcdir}/lisp/version.el'." >&2
AC_SUBST(lockdir)
AC_SUBST(archlibdir)
AC_SUBST(c_switch_system)
+AC_SUBST(c_switch_machine)
AC_SUBST(libsrc_libs)
AC_SUBST(LD_SWITCH_X_SITE)
+AC_SUBST(LD_SWITCH_X_SITE_AUX)
AC_SUBST(C_SWITCH_X_SITE)
AC_SUBST(CFLAGS)
+AC_SUBST(X_TOOLKIT_TYPE)
AC_DEFINE_UNQUOTED(config_machfile, "\"${machfile}\"")
AC_DEFINE_UNQUOTED(config_opsysfile, "\"${opsysfile}\"")
AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE, ${LD_SWITCH_X_SITE})
+AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE_AUX, ${LD_SWITCH_X_SITE_AUX})
AC_DEFINE_UNQUOTED(C_SWITCH_X_SITE, ${C_SWITCH_X_SITE})
AC_DEFINE_UNQUOTED(UNEXEC_SRC, ${UNEXEC_SRC})
if [ "${HAVE_X_WINDOWS}" = "yes" ] ; then
] AC_DEFINE(HAVE_X_WINDOWS) [
fi
+if [ "${USE_X_TOOLKIT}" != "no" ] ; then
+ ] AC_DEFINE(USE_X_TOOLKIT) [
+fi
if [ "${HAVE_X11}" = "yes" ] ; then
] AC_DEFINE(HAVE_X11) [
fi
if [ "$run_in_place" = "1" ]; then
lispdir='${srcdir}/lisp'
- locallisppath='${srcdir}/site-lisp:${datadir}/emacs/site-lisp'
+ locallisppath='${srcdir}/site-lisp'
etcdir='${srcdir}/etc'
lockdir='${srcdir}/lock'
archlibdir='${srcdir}/lib-src'
test -n "${exec_prefix}" &&
exec_prefix=`echo "${exec_prefix}" | sed 's,\([^/]\)/*$,\1,'`
]
-AC_OUTPUT(Makefile lib-src/Makefile oldXMenu/Makefile src/Makefile.in)
-[
+AC_OUTPUT(Makefile lib-src/Makefile oldXMenu/Makefile lwlib/Makefile src/Makefile.in, [
# Build src/Makefile from ${srcdir}/src/Makefile.in. This must be done
-# after src/config.h is built, since we rely on that file. Only do the
-# build if "config.status" is present, since it's non-presence indicates
-# an error occured.
-status=$?
-if [ ! -f ./config.status ]; then
- exit $status
-fi
-topsrcdir=${srcdir}
-makefile_command='echo "creating src/Makefile";
- topsrcdir='"${topsrcdir}"';
-( cd ./src;
- cp ${topsrcdir}/src/Makefile.in junk.c;
- eval `echo ${CPP} -I${topsrcdir}/src ${CPPFLAGS} junk.c \>junk.cpp`;
- < junk.cpp '\
-' sed -e '\''s/^#.*//'\'' '\
-' -e '\''s/^[ \f\t][ \f\t]*$//'\'' '\
-' -e '\''s/^ / /'\'' '\
-' | sed -n -e '\''/^..*$/p'\'' '\
-' > Makefile.new;
- mv -f Makefile.new Makefile;
- chmod 444 Makefile;
- rm -f junk.c junk.cpp;
-)'
-eval `echo $makefile_command`
-# AC-OUTPUT has created `config.status' already. We need to add the above
-# commands to re-create `src/Makefile', and we need to insert them before
-# the final "exit 0" which appears at the end of `config.status'.
-<config.status sed -e 's/^exit 0$//' >config.new
-echo $makefile_command >>config.new
-echo exit 0 >>config.new
-mv -f config.new config.status
-chmod +x config.status
-exit 0
-]
-
+# after src/config.h is built, since we rely on that file.
+
+changequote(,)dnl The horror, the horror.
+# Now get this: Some word that is part of the ${srcdir} directory name
+# or the ${configuration} value might, just might, happen to be an
+# identifier like `sun4' or `i386' or something, and be predefined by
+# the C preprocessor to some helpful value like 1, or maybe the empty
+# string. Needless to say consequent macro substitutions are less
+# than conducive to the makefile finding the correct directory.
+undefs="`echo $top_srcdir $configuration |
+sed -e 's/[^a-zA-Z0-9_]/ /g' -e 's/ */ -U/g' \
+ -e 's/ -U$//' -e 's/^[^ ]/-U/' \
+ -e 's/-U[0-9][^ ]*//g' \
+`"
+changequote([,])dnl
+
+echo creating src/Makefile
+( cd src
+ rm -f junk.c
+ sed -e 's@^# \(Generated.*\)$@/* \1 */@' \
+ -e 's@/\*\*/#\(.*\)$@/* \1 */@' \
+ < Makefile.in > junk.c
+ $CPP $undefs -I. -I$top_srcdir/src $CPPFLAGS junk.c |
+ sed -e 's/^ / /' -e '/^#/d' -e '/^[ ]*$/d' > Makefile.new
+ rm -f junk.c
+ chmod 444 Makefile.new;
+ mv -f Makefile.new Makefile;
+)])