]> code.delx.au - gnu-emacs/blobdiff - src/Makefile.in
(add_properties, remove_properties, set_properties):
[gnu-emacs] / src / Makefile.in
index 12c24fa1189d6787d723130e836670d5ce6dd2d3..a097849e6957abf0e4381cc30b0ac6c387502128 100644 (file)
@@ -1,55 +1,70 @@
-/* Makefile for GNU Emacs.
-   Copyright (C) 1985, 1987, 1988, 1993 Free Software Foundation, Inc.
+# Makefile for GNU Emacs.
+# Copyright (C) 1985, 87, 88, 93, 94, 95 Free Software Foundation, Inc.
 
-This file is part of GNU Emacs.
+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 2, or (at your option)
-any later version.
+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 2, or (at your option)
+any later version.
 
-GNU Emacs is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
+GNU Emacs is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+GNU General Public License for more details.
 
-You should have received a copy of the GNU General Public License
-along with GNU Emacs; see the file COPYING.  If not, write to
-the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
+You should have received a copy of the GNU General Public License
+along with GNU Emacs; see the file COPYING.  If not, write to
+the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
 
-/* BSD doesn't have it as a default. */
-MAKE = make
-
-/* Here are the things that we expect ../configure to edit. */
+# Here are the things that we expect ../configure to edit.
 srcdir=@srcdir@
 VPATH=@srcdir@
 CC=@CC@
 CPP=@CPP@
 CFLAGS=@CFLAGS@
-C_SWITCH_SYSTEM=
 LN_S=@LN_S@
-# These escaped doublequotes become part of the macro definition in emacs.c.
-# Thus, the definition is a C string constant.
-configuration=\"@configuration@\"
+# Substitute an assignment for the MAKE variable, because
+# BSD doesn't have it as a default.
+@SET_MAKE@
 
-/* On Xenix and the IBM RS6000, double-dot gets screwed up.  */
+# On Xenix and the IBM RS6000, double-dot gets screwed up.
 dot = .
-lispdir = ${srcdir}/$(dot)$(dot)/lisp/
+dotdot = ${dot}${dot}
+lispsource = ${srcdir}/$(dot)$(dot)/lisp/
 libsrc = $(dot)$(dot)/lib-src/
 etc = $(dot)$(dot)/etc/
 shortnamesdir = $(dot)$(dot)/shortnames/
 cppdir = $(dot)$(dot)/cpp/
 oldXMenudir = $(dot)$(dot)/oldXMenu/
-config_h = config.h
+lwlibdir = $(dot)$(dot)/lwlib/
+
+# Configuration files for .o files to depend on.
+M_FILE = ${srcdir}/@machfile@
+S_FILE = ${srcdir}/@opsysfile@
+config_h = config.h $(M_FILE) $(S_FILE)
+
+# ========================== start of cpp stuff ======================= */
+/* From here on, comments must be done in C syntax.  */
+
+CPPFLAGS=
+LDFLAGS=
+C_SWITCH_SYSTEM=
 
 /* just to be sure the sh is used */
 SHELL=/bin/sh
 
+#define THIS_IS_MAKEFILE
 #define NO_SHORTNAMES
-#define THIS_IS_YMAKEFILE
 #define NOT_C_CODE
 #include "config.h"
 
+/* We won't really call alloca;
+   don't let the file name alloca.c get messed up.  */
+#ifdef alloca
+#undef alloca
+#endif
+
 /* Use HAVE_X11 as an alias for X11 in this file
    to avoid problems with X11 as a subdirectory name
    in -I and other such options which pass through this file. */
@@ -66,14 +81,20 @@ SHELL=/bin/sh
 /* On some systems we may not be able to use the system make command. */
 #ifdef MAKE_COMMAND
 MAKE = MAKE_COMMAND
-#else
-MAKE=make
 #endif
 
 #ifdef C_COMPILER
 CC = C_COMPILER
 #endif
 
+/* GNU libc requires ORDINARY_LINK so that its own crt0 is used.
+   Linux is an exception because it uses a funny variant of GNU libc.  */
+#ifdef __GNU_LIBRARY__
+#ifndef LINUX
+#define ORDINARY_LINK
+#endif
+#endif
+
 /* Some machines don't find the standard C libraries in the usual place.  */
 #ifndef ORDINARY_LINK
 #ifndef LIB_STANDARD
@@ -149,6 +170,10 @@ CC = C_COMPILER
 #define LD_SWITCH_X_SITE
 #endif
 
+#ifndef LD_SWITCH_X_DEFAULT
+#define LD_SWITCH_X_DEFAULT
+#endif
+
 /* These can be passed in from config.h to define special load and
    compile switches needed by individual sites */
 #ifndef LD_SWITCH_SITE
@@ -173,7 +198,7 @@ CC = C_COMPILER
 #define START_FILES pre-crt0.o /lib/crt0.o
 #endif /* ! defined (COFF_ENCAPSULATE) */
 #else /* ! defined (NO_REMAP) */
-#define START_FILES crt0.o
+#define START_FILES ecrt0.o
 #endif /* ! defined (NO_REMAP) */
 #endif /* START_FILES */
 STARTFILES = START_FILES
@@ -215,14 +240,18 @@ LOCALCPP= localcpp
 SHORT= shortnames
 #endif
 
+#ifdef USE_X_TOOLKIT
+#define USE_@X_TOOLKIT_TYPE@
+TOOLKIT_DEFINES = -DUSE_@X_TOOLKIT_TYPE@
+#else
+TOOLKIT_DEFINES =
+#endif
+
 /* DO NOT use -R.  There is a special hack described in lastfile.c
    which is used instead.  Some initialized data areas are modified
    at initial startup, then labeled as part of the text area when
    Emacs is dumped for the first time, and never changed again. */
 
-/* If you want to debug, you can add C_DEBUG_SWITCH to this list.
-   If you want to optimize, you can add C_OPTIMIZE_SWITCH to the list.  */
-
 /* -Demacs is needed to make some files produce the correct version
    for use in Emacs.
 
@@ -231,7 +260,7 @@ SHORT= shortnames
 
 /* C_SWITCH_X_SITE must come before C_SWITCH_X_MACHINE and C_SWITCH_X_SYSTEM
    since it may have -I options that should override those two.  */
-ALL_CFLAGS=-Demacs -DHAVE_CONFIG_H $(MYCPPFLAG) -I. -I${srcdir} C_SWITCH_MACHINE C_SWITCH_SYSTEM C_SWITCH_SITE C_SWITCH_X_SITE C_SWITCH_X_MACHINE C_SWITCH_X_SYSTEM ${CFLAGS}
+ALL_CFLAGS=-Demacs -DHAVE_CONFIG_H $(TOOLKIT_DEFINES) $(MYCPPFLAG) -I. -I${srcdir} C_SWITCH_MACHINE C_SWITCH_SYSTEM C_SWITCH_SITE C_SWITCH_X_SITE C_SWITCH_X_MACHINE C_SWITCH_X_SYSTEM ${CFLAGS}
 .c.o:
        $(CC) -c $(CPPFLAGS) $(ALL_CFLAGS) $<
 
@@ -265,26 +294,75 @@ XOBJ= xterm.o xfns.o xfaces.o xmenu.o xselect.o xrdb.o
    from X11.  If we have X10, just use the installed library;
    otherwise, use our own copy.  */
 #ifdef HAVE_X11
-OLDXMENU= libXMenu11.a
+#ifdef USE_X_TOOLKIT
+OLDXMENU=${lwlibdir}liblw.a
+LIBXMENU= $(OLDXMENU)
+#else /* not USE_X_TOOLKIT */
+OLDXMENU= ${oldXMenudir}libXMenu11.a
 LIBXMENU= $(OLDXMENU)
-#else /* ! defined (HAVE_X11) */
+#endif /* not USE_X_TOOLKIT */
+#else /* not HAVE_X11 */
 LIBXMENU= -lXMenu
-#endif /* ! defined (HAVE_X11) */
+#endif /* not HAVE_X11 */
 
-#else /* ! defined (HAVE_X_MENU) */
+#else /* not HAVE_X_MENU */
 
 /* Otherwise, omit xmenu.o from the list of X object files, and
    don't worry about the menu library at all.  */
 XOBJ= xterm.o xfns.o xfaces.o xselect.o xrdb.o
 LIBXMENU=
-#endif /* ! defined (HAVE_X_MENU) */
+#endif /* not HAVE_X_MENU */
+
+#ifdef USE_X_TOOLKIT
+#define @X_TOOLKIT_TYPE@
+#if defined (LUCID) || defined (ATHENA)
+LIBW= -lXaw
+#endif
+#ifdef MOTIF
+#ifdef LIB_MOTIF
+LIBW= LIB_MOTIF
+#else
+LIBW= -lXm
+#endif
+#endif
+#ifdef OPEN_LOOK
+LIBW= -lXol
+#endif
+
+#ifdef HAVE_X11XTR6
+#ifdef NEED_LIBW
+LIBXTR6 = -lSM -lICE -lw
+#else
+LIBXTR6 = -lSM -lICE
+#endif
+#endif
+
+#ifndef LIBXMU
+#define LIBXMU -lXmu
+#endif
+
+#ifdef LIBXT_STATIC
+/* We assume the config files have defined STATIC_OPTION
+   since that might depend on the operating system.
+   (Don't forget you need different definitions with and without __GNUC__.)  */
+LIBXT= STATIC_OPTION $(LIBW) LIBXMU -lXt $(LIBXTR6) -lXext STATIC_OPTION 
+#else /* not LIBXT_STATIC */
+LIBXT= $(LIBW) LIBXMU -lXt $(LIBXTR6) -lXext
+#endif /* not LIBXT_STATIC */
+
+#else /* not USE_X_TOOLKIT */
+LIBXT=
+#endif /* not USE_X_TOOLKIT */
 
 #ifdef HAVE_X11
-LIBX= $(LIBXMENU) LD_SWITCH_X_SITE LIB_X11_LIB LIBX11_MACHINE LIBX11_SYSTEM
-#else /* ! defined (HAVE_X11) */
+/* LD_SWITCH_X_DEFAULT comes after everything else that specifies
+   options for where to find X libraries, but before those libraries.  */
+X11_LDFLAGS = LD_SWITCH_X_SITE LD_SWITCH_X_DEFAULT
+LIBX= $(LIBXMENU) $(X11_LDFLAGS) $(LIBXT) LIB_X11_LIB LIBX11_MACHINE LIBX11_SYSTEM
+#else /* not HAVE_X11 */
 LIBX= $(LIBXMENU) LD_SWITCH_X_SITE -lX10 LIBX10_MACHINE LIBX10_SYSTEM
-#endif /* ! defined (HAVE_X11) */
-#endif /* ! defined (HAVE_X_WINDOWS) */
+#endif /* not HAVE_X11 */
+#endif /* not HAVE_X_WINDOWS */
 
 #ifndef ORDINARY_LINK
 /* Fix linking if compiled with GCC.  */
@@ -312,7 +390,7 @@ LIBX= $(LIBXMENU) LD_SWITCH_X_SITE -lX10 LIBX10_MACHINE LIBX10_SYSTEM
 #ifndef LIB_GCC
 /* Ask GCC where to find libgcc.a.  */
 #define LIB_GCC `$(CC) -print-libgcc-file-name`
-#endif /* LIB_GCC */
+#endif /* not LIB_GCC */
 
 GNULIB_VAR = LIB_GCC
 
@@ -331,13 +409,13 @@ GNULIB_VAR = LIB_GCC
 
 #ifndef LIB_GCC
 #define LIB_GCC /usr/local/lib/gcc-gnulib
-#endif /* LIB_GCC */
+#endif /* not LIB_GCC */
 GNULIB_VAR = `if [ -f LIB_GCC ] ; then echo LIB_GCC; else echo; fi`
 #endif /* __GNUC__ < 2 */
-#else /* ! defined (__GNUC__) */
+#else /* not __GNUC__ */
 GNULIB_VAR = 
 
-#endif /* ! defined (__GNUC__) */
+#endif /* not __GNUC__ */
 #endif /* not ORDINARY_LINK */
 
 /* Specify address for ld to start loading at,
@@ -354,17 +432,19 @@ LD=$(CC) -nostdlib
 #else /* not ORDINARY_LINK */
 #ifdef LINKER
 LD=LINKER
-#else /* ! defined (LINKER) */
+#else /* not LINKER */
 LD=ld
-#endif /* ! defined (LINKER) */
-#endif /* ! defined (COFF_ENCAPSULATE) */
+#endif /* not LINKER */
+#endif /* not COFF_ENCAPSULATE */
 #endif /* not ORDINARY_LINK */
 
-LDFLAGS = LD_SWITCH_SYSTEM LD_SWITCH_MACHINE LD_SWITCH_SITE
+ALL_LDFLAGS = LD_SWITCH_SYSTEM LD_SWITCH_MACHINE LD_SWITCH_SITE $(LDFLAGS)
 
-/* A macro which other sections of ymakefile can redefine to munge the
+/* A macro which other sections of Makefile can redefine to munge the
    flags before they're passed to LD.  This is helpful if you have
-   redefined LD to something odd, like "gcc".  */
+   redefined LD to something odd, like "gcc".
+   (The YMF prefix is a holdover from the old name "ymakefile".)
+  */
 #ifndef YMF_PASS_LDFLAGS
 #define YMF_PASS_LDFLAGS(flags) flags
 #endif
@@ -391,10 +471,27 @@ LDFLAGS = LD_SWITCH_SYSTEM LD_SWITCH_MACHINE LD_SWITCH_SITE
 #define GETLOADAVG_OBJ getloadavg.o
 #endif
 
+#ifdef HAVE_MKTIME
+#define MKTIME_OBJ
+#else
+#define MKTIME_OBJ mktime.o
+#endif
+
+#ifdef MSDOS
+#ifdef HAVE_X_WINDOWS
+#define MSDOS_OBJ dosfns.o msdos.o
+#else
+#define MSDOS_OBJ dosfns.o msdos.o xfaces.o xmenu.o
+#endif
+#else
+#define MSDOS_OBJ
+#endif
+
+
 /* lastfile must follow all files
    whose initialized data areas should be dumped as pure by dump-emacs. */
 obj=    dispnew.o frame.o scroll.o xdisp.o window.o \
-       term.o cm.o $(XOBJ) \
+       cm.o term.o $(XOBJ) \
        emacs.o keyboard.o macros.o keymap.o sysdep.o \
        buffer.o filelock.o insdel.o marker.o INTERVAL_OBJ \
        minibuf.o fileio.o dired.o filemode.o \
@@ -403,7 +500,15 @@ obj=    dispnew.o frame.o scroll.o xdisp.o window.o \
        eval.o floatfns.o fns.o print.o lread.o \
        abbrev.o syntax.o UNEXEC mocklisp.o bytecode.o \
        process.o callproc.o \
-       doprnt.o GETLOADAVG_OBJ
+       region-cache.o \
+       doprnt.o strftime.o MKTIME_OBJ GETLOADAVG_OBJ MSDOS_OBJ
+
+/* Object files used on some machine or other.
+   These go in the DOC file on all machines
+   in case they are needed there.  */
+SOME_MACHINE_OBJECTS = sunfns.o dosfns.o msdos.o intervals.o textprop.o \
+  xterm.o xfns.o xfaces.o xmenu.o xselect.o xrdb.o
+
 
 #ifdef TERMINFO
 /* Used to be -ltermcap here.  If your machine needs that,
@@ -443,29 +548,66 @@ allocaobj = alloca.o
 allocaobj =
 #endif
 
+#ifdef USE_X_TOOLKIT
+widgetobj= widget.o
+#else /* not USE_X_TOOLKIT */
+widgetobj=
+#endif /* not USE_X_TOOLKIT */
+
 
 /* define otherobj as list of object files that make-docfile
    should not be told about.  */
-otherobj= $(termcapobj) lastfile.o $(mallocobj) $(allocaobj)
+otherobj= $(termcapobj) lastfile.o $(mallocobj) $(allocaobj) $(widgetobj)
+
+#ifdef HAVE_FACES
+#define FACE_SUPPORT ${lispsource}faces.elc ${lispsource}facemenu.elc
+#else
+#define FACE_SUPPORT
+#endif
 
 #ifdef LISP_FLOAT_TYPE
-#define FLOAT_SUPPORT ${lispdir}float-sup.elc
+#define FLOAT_SUPPORT ${lispsource}float-sup.elc
 #else
 #define FLOAT_SUPPORT
 #endif
 
 #ifdef MULTI_FRAME
-#define FRAME_SUPPORT ${lispdir}frame.elc ${lispdir}mouse.elc ${lispdir}select.elc ${lispdir}scroll-bar.elc
+#define FRAME_SUPPORT ${lispsource}frame.elc
 #else
 #define FRAME_SUPPORT
 #endif
 
+#ifdef HAVE_MOUSE
+#define MOUSE_SUPPORT ${lispsource}menu-bar.elc ${lispsource}mouse.elc \
+  ${lispsource}select.elc ${lispsource}scroll-bar.elc
+#else
+#define MOUSE_SUPPORT
+#endif
+
+#ifdef HAVE_X_WINDOWS
+#define X_WINDOWS_SUPPORT
+#else
+#define X_WINDOWS_SUPPORT
+#endif
+
 #ifdef VMS
-#define VMS_SUPPORT ${lispdir}vmsproc.elc ${lispdir}vms-patch
+#define VMS_SUPPORT ${lispsource}vmsproc.elc ${lispsource}vms-patch.elc
 #else
 #define VMS_SUPPORT
 #endif
 
+#ifdef MSDOS
+#define MSDOS_SUPPORT ${lispsource}ls-lisp.elc ${lispsource}disp-tab.elc ${lispsource}dos-fns.elc
+#else
+#define MSDOS_SUPPORT
+#endif
+
+#ifdef WINDOWSNT
+#define WINNT_SUPPORT ${lispsource}ls-lisp.elc ${lispsource}winnt.elc
+#else
+#define WINNT_SUPPORT
+#endif
+
 /* List of Lisp files loaded into the dumped Emacs.  It's arranged
    like this because it's easier to generate it semi-mechanically from
    loadup.el this way.
@@ -474,37 +616,90 @@ otherobj= $(termcapobj) lastfile.o $(mallocobj) $(allocaobj)
    be present, like site-load.el and site-init.el; this makefile
    expects them all to be either present or buildable.
 
-   It should not include version.el.  That file is often changed by
-   the build process itself, but most of the files which want to
-   depend on lisp.h don't care about those changes.  */
+   Always update shortlisp as well as this variable.  */
+
 lisp= \
-       ${lispdir}abbrev.elc \
-       ${lispdir}buff-menu.elc \
-       ${lispdir}byte-run.elc \
-       ${lispdir}c-mode.elc \
-       ${lispdir}files.elc \
-       ${lispdir}fill.elc \
+       ${lispsource}abbrev.elc \
+       ${lispsource}buff-menu.elc \
+       ${lispsource}byte-run.elc \
+       ${lispsource}files.elc \
+       ${lispsource}fill.elc \
+       ${lispsource}format.elc \
+       FACE_SUPPORT \
+       MOUSE_SUPPORT \
        FLOAT_SUPPORT \
        FRAME_SUPPORT \
-       ${lispdir}help.elc \
-       ${lispdir}indent.elc \
-       ${lispdir}isearch.elc \
-       ${lispdir}lisp-mode.elc \
-       ${lispdir}lisp.elc \
-       ${lispdir}loaddefs.el \
-       ${lispdir}map-ynp.elc \
-       ${lispdir}page.elc \
-       ${lispdir}paragraphs.elc \
-       ${lispdir}paths.el \
-       ${lispdir}register.elc \
-       ${lispdir}replace.elc \
-       ${lispdir}simple.elc \
-       ${lispdir}startup.elc \
-       ${lispdir}subr.elc \
-       ${lispdir}text-mode.elc \
-       ${lispdir}vc-hooks.elc \
+       X_WINDOWS_SUPPORT \
+       ${lispsource}help.elc \
+       ${lispsource}indent.elc \
+       ${lispsource}isearch.elc \
+       ${lispsource}lisp-mode.elc \
+       ${lispsource}lisp.elc \
+       ${lispsource}loadup.el \
+       ${lispsource}loaddefs.el \
+       ${lispsource}map-ynp.elc \
+       ${lispsource}page.elc \
+       ${lispsource}paragraphs.elc \
+       ${lispsource}paths.el \
+       ${lispsource}register.elc \
+       ${lispsource}replace.elc \
+       ${lispsource}simple.elc \
+       ${lispsource}startup.elc \
+       ${lispsource}subr.elc \
+       ${lispsource}text-mode.elc \
+       ${lispsource}vc-hooks.elc \
+       ${lispsource}ediff-hook.elc \
        VMS_SUPPORT \
-       ${lispdir}window.elc
+       MSDOS_SUPPORT \
+       WINNT_SUPPORT \
+       ${lispsource}window.elc \
+       ${lispsource}version.el
+
+/* These are relative file names for the Lisp files
+   that are loaded unconditionally.  This is used in make-docfile.
+   It need not contain the files that are loaded conditionally
+   because SOME_MACHINE_LISP has those.  */
+shortlisp= \
+       ../lisp/abbrev.elc \
+       ../lisp/buff-menu.elc \
+       ../lisp/byte-run.elc \
+       ../lisp/files.elc \
+       ../lisp/fill.elc \
+       ../lisp/format.elc \
+       ../lisp/help.elc \
+       ../lisp/indent.elc \
+       ../lisp/isearch.elc \
+       ../lisp/lisp-mode.elc \
+       ../lisp/lisp.elc \
+       ../lisp/loadup.el \
+       ../lisp/loaddefs.el \
+       ../lisp/map-ynp.elc \
+       ../lisp/page.elc \
+       ../lisp/paragraphs.elc \
+       ../lisp/paths.el \
+       ../lisp/register.elc \
+       ../lisp/replace.elc \
+       ../lisp/simple.elc \
+       ../lisp/startup.elc \
+       ../lisp/subr.elc \
+       ../lisp/text-mode.elc \
+       ../lisp/vc-hooks.elc \
+       ../lisp/ediff-hook.elc \
+       ../lisp/window.elc \
+       ../lisp/version.el
+
+/* Lisp files that may or may not be used.
+   We must unconditionally put them in the DOC file. 
+   We use ../lisp/ to start the file names
+   to reduce the size of the argument list for make-docfile
+   for the sake of systems which can't handle large ones.  */
+SOME_MACHINE_LISP =  ${dotdot}/lisp/faces.elc ${dotdot}/lisp/facemenu.elc \
+  ${dotdot}/lisp/float-sup.elc ${dotdot}/lisp/frame.elc \
+  ${dotdot}/lisp/menu-bar.elc ${dotdot}/lisp/mouse.elc \
+  ${dotdot}/lisp/select.elc ${dotdot}/lisp/scroll-bar.elc \
+  ${dotdot}/lisp/vmsproc.elc ${dotdot}/lisp/vms-patch.elc \
+  ${dotdot}/lisp/ls-lisp.elc ${dotdot}/lisp/dos-fns.elc \
+  ${dotdot}/lisp/winnt.elc
 
 /* Construct full set of libraries to be linked.
    Note that SunOS needs -lm to come before -lc; otherwise, you get
@@ -532,28 +727,32 @@ all: emacs OTHER_FILES
 
 emacs: temacs ${etc}DOC ${lisp}
 #ifdef CANNOT_DUMP
+       rm -f emacs
        ln temacs emacs
 #else
 #ifdef HAVE_SHM
-       -if [ -w ${srcdir}/../lisp ]; then \
-         w=`pwd`; cd ${srcdir}; $${w}/temacs -nl -batch -l ../lisp/inc-vers; \
-       else true; fi
        ./temacs -nl -batch -l loadup dump
 #else /* ! defined (HAVE_SHM) */
-       -if [ -w ${srcdir}/../lisp ]; then \
-         w=`pwd`; cd ${srcdir}; $${w}/temacs -batch -l ../lisp/inc-vers; \
-       else true; fi
        ./temacs -batch -l loadup dump
 #endif /* ! defined (HAVE_SHM) */
 #endif /* ! defined (CANNOT_DUMP) */
 
-${etc}DOC: ${libsrc}make-docfile ${obj} ${lisp} OBJECTS_SYSTEM OBJECTS_MACHINE
-       rm -f ${etc}DOC
-       ${libsrc}make-docfile -d ${srcdir} ${obj} OBJECTS_SYSTEM OBJECTS_MACHINE ${lisp} \
-         ${lispdir}version.el > ${etc}DOC
+/* We run make-docfile twice because the command line may get too long
+   on some systems.  */
+/* ${SOME_MACHINE_OBJECTS} comes before ${obj} because some files may
+   or may not be included in ${obj}, but they are always included in
+   ${SOME_MACHINE_OBJECTS}.  Since a file is processed when it is mentioned
+   for the first time, this prevents any variation between configurations
+   in the contents of the DOC file.
+   Likewise for ${SOME_MACHINE_LISP}.  */
+${etc}DOC: ${libsrc}make-docfile ${obj} ${lisp}
+       -rm -f ${etc}DOC
+       ${libsrc}make-docfile -d ${srcdir} ${SOME_MACHINE_OBJECTS} ${obj} > ${etc}DOC
+       cd 
+       ${libsrc}make-docfile -a ${etc}DOC -d ${srcdir} ${SOME_MACHINE_LISP} ${shortlisp}
 
 ${libsrc}make-docfile:
-       cd ${libsrc}; ${MAKE} ${MFLAGS} make-docfile ../arch-lib
+       cd ${libsrc}; ${MAKE} ${MFLAGS} make-docfile
 
 /* Some systems define this to cause parallel Make-ing.  */
 #ifndef MAKE_PARALLEL
@@ -561,12 +760,15 @@ ${libsrc}make-docfile:
 #endif
 
 temacs: MAKE_PARALLEL $(LOCALCPP) $(SHORT) $(STARTFILES) $(OLDXMENU) ${obj} ${otherobj} OBJECTS_SYSTEM OBJECTS_MACHINE prefix-args
-       $(LD) YMF_PASS_LDFLAGS (${STARTFLAGS} ${LDFLAGS}) \
+       $(LD) YMF_PASS_LDFLAGS (${STARTFLAGS} ${ALL_LDFLAGS}) \
     -o temacs ${STARTFILES} ${obj} ${otherobj}  \
     OBJECTS_SYSTEM OBJECTS_MACHINE ${LIBES}
 
+/* We don't use ALL_LDFLAGS because LD_SWITCH_SYSTEM and LD_SWITCH_MACHINE
+   often contain options that have to do with using Emacs's crt0,
+   which are only good with temacs.  */
 prefix-args: prefix-args.c $(config_h)
-       $(CC) $(ALL_CFLAGS) ${srcdir}/prefix-args.c -o prefix-args
+       $(CC) $(ALL_CFLAGS) $(LDFLAGS) ${srcdir}/prefix-args.c -o prefix-args
 
 /* These are needed for C compilation, on the systems that need them */
 #ifdef NEED_CPP
@@ -597,12 +799,38 @@ shortnames:
 #define OLDXMENU_OPTIONS
 #endif
 
+/* Don't lose if this was not defined.  */
+#ifndef LWLIB_OPTIONS
+#define LWLIB_OPTIONS
+#endif
+
 #ifdef HAVE_X_WINDOWS
-#ifdef HAVE_X_MENU
 #ifdef HAVE_X11
+#ifdef USE_X_TOOLKIT
+$(OLDXMENU): really-lwlib
+
+/* Encode the values of these two macros in Make variables,
+   so we can use $(...) to substitute their values within "...".  */
+C_SWITCH_MACHINE_1 = C_SWITCH_MACHINE
+C_SWITCH_SYSTEM_1 = C_SWITCH_SYSTEM
+C_SWITCH_SITE_1 = C_SWITCH_SITE
+C_SWITCH_X_SITE_1 = C_SWITCH_X_SITE
+C_SWITCH_X_MACHINE_1 = C_SWITCH_X_MACHINE
+C_SWITCH_X_SYSTEM_1 = C_SWITCH_X_SYSTEM
+really-lwlib:
+       cd ${lwlibdir}; ${MAKE} ${MFLAGS} LWLIB_OPTIONS \
+    CC='${CC}' CFLAGS='${CFLAGS}' MAKE='${MAKE}' \
+    "C_SWITCH_X_SITE=$(C_SWITCH_X_SITE_1)" \
+    "C_SWITCH_X_MACHINE=$(C_SWITCH_X_MACHINE_1)" \
+    "C_SWITCH_X_SYSTEM=$(C_SWITCH_X_SYSTEM_1)" \
+    "C_SWITCH_SITE=$(C_SWITCH_SITE_1)" \
+    "C_SWITCH_MACHINE=$(C_SWITCH_MACHINE_1)" \
+    "C_SWITCH_SYSTEM=$(C_SWITCH_SYSTEM_1)"
+       @true  /* make -t should not create really-lwlib.  */
+.PHONY: really-lwlib
+#else /* not USE_X_TOOLKIT */
+#ifdef HAVE_X_MENU
 $(OLDXMENU): really-oldXMenu
-       -rm -f $(OLDXMENU) /* We might have a link to an old version.  */
-       ${LN_S} ${oldXMenudir}libXMenu11.a $(OLDXMENU)
 
 /* Encode the values of these two macros in Make variables,
    so we can use $(...) to substitute their values within "...".  */
@@ -622,17 +850,19 @@ really-oldXMenu:
     "C_SWITCH_MACHINE=$(C_SWITCH_MACHINE_1)" \
     "C_SWITCH_SYSTEM=$(C_SWITCH_SYSTEM_1)"
        @true  /* make -t should not create really-oldXMenu.  */
-#endif /* ! defined (HAVE_X11) */
-#endif /* ! defined (HAVE_X_MENU) */
-#endif /* ! defined (HAVE_X_WINDOWS) */
-
-paths.h: paths.h.in
-       @echo "The file paths.h needs to be set up from paths.h.in."
+.PHONY: really-oldXMenu
+#endif /* HAVE_X_MENU */
+#endif /* not USE_X_TOOLKIT */
+#endif /* HAVE_X11 */
+#endif /* HAVE_X_WINDOWS */
+
+paths.h: paths.in
+       @echo "The file paths.h needs to be set up from paths.in."
        @echo "Consult the file \`INSTALL' for instructions for building Emacs."
        exit 1
 
-config.h: config.h.in
-       @echo "The file config.h needs to be set up from config.h.in."
+config.h: config.in
+       @echo "The file config.h needs to be set up from config.in."
        @echo "Consult the file \`INSTALL' for instructions for building Emacs."
        exit 1
 
@@ -652,9 +882,10 @@ alloca.o : alloca.c
        $(ALL_CFLAGS) ${srcdir}/alloca.c
 #else
 #ifndef HAVE_ALLOCA
-alloca.o : alloca.s config.h
+alloca.o : alloca.s $(config_h)
 /* $(CPP) is cc -E, which may get confused by filenames
    that do not end in .c.  So copy file to a safe name.  */
+       -rm -f allocatem.c
        cp ${srcdir}/alloca.s allocatem.c
 /* Remove any ^L, blank lines, and preprocessor comments,
    since some assemblers barf on them.  Use a different basename for the
@@ -667,7 +898,7 @@ alloca.o : alloca.s config.h
 /* Xenix, in particular, needs to run assembler via cc.  */
        $(CC) -c allocax.s
        mv allocax.o alloca.o
-       rm allocax.s allocatem.c
+       -rm -f allocax.s allocatem.c
 #endif /* HAVE_ALLOCA */
 #endif /* ! defined (C_ALLOCA) */
 
@@ -676,117 +907,133 @@ alloca.o : alloca.s config.h
    it is so often changed in ways that do not require any recompilation
    and so rarely changed in ways that do require any.  */
 
-abbrev.o : abbrev.c buffer.h commands.h $(config_h) 
-buffer.o : buffer.c syntax.h buffer.h commands.h window.h \
+abbrev.o: abbrev.c buffer.h commands.h $(config_h) 
+buffer.o: buffer.c buffer.h region-cache.h commands.h window.h \
    INTERVAL_SRC blockinput.h $(config_h) 
-callint.o : callint.c window.h commands.h buffer.h mocklisp.h \
+callint.o: callint.c window.h commands.h buffer.h mocklisp.h \
    keyboard.h $(config_h)
-callproc.o : callproc.c paths.h buffer.h commands.h $(config_h) process.h
-casefiddle.o : casefiddle.c syntax.h commands.h buffer.h $(config_h) 
-casetab.o : casetab.c buffer.h $(config_h)
-cm.o : cm.c cm.h termhooks.h $(config_h)
-cmds.o : cmds.c syntax.h buffer.h commands.h $(config_h) 
-pre-crt0.o : pre-crt0.c
-crt0.o : crt0.c $(config_h)
-       CRT0_COMPILE ${srcdir}/crt0.c
-dired.o : dired.c commands.h buffer.h $(config_h) regex.h
-dispnew.o : dispnew.c commands.h frame.h window.h buffer.h dispextern.h \
-   termchar.h termopts.h termhooks.h cm.h disptab.h systty.h systime.h $(config_h)
-doc.o : doc.c $(config_h) paths.h buffer.h keyboard.h
-doprnt.o : doprnt.c
-editfns.o : editfns.c window.h buffer.h systime.h INTERVAL_SRC $(config_h) 
-emacs.o : emacs.c commands.h systty.h syssignal.h process.h INTERVAL_SRC $(config_h) 
-       $(CC) -c -DCONFIGURATION="$(configuration)" $(CPPFLAGS) $(ALL_CFLAGS) $<
-fileio.o : fileio.c window.h buffer.h systime.h INTERVAL_SRC $(config_h) 
-filelock.o : filelock.c buffer.h paths.h $(config_h)
-filemode.o : filemode.c  $(config_h)
-getloadavg.o : getloadavg.c $(config_h)
-indent.o : indent.c frame.h window.h indent.h buffer.h $(config_h) termchar.h \
-   termopts.h disptab.h
-insdel.o : insdel.c window.h buffer.h INTERVAL_SRC blockinput.h $(config_h)
-keyboard.o : keyboard.c termchar.h termhooks.h termopts.h buffer.h \
+callproc.o: callproc.c paths.h buffer.h commands.h $(config_h) \
+       process.h systty.h syssignal.h
+casefiddle.o: casefiddle.c syntax.h commands.h buffer.h $(config_h) 
+casetab.o: casetab.c buffer.h $(config_h)
+cm.o: cm.c cm.h termhooks.h $(config_h)
+cmds.o: cmds.c syntax.h buffer.h commands.h window.h $(config_h) 
+pre-crt0.o: pre-crt0.c
+ecrt0.o: ecrt0.c $(config_h)
+       CRT0_COMPILE ${srcdir}/ecrt0.c
+dired.o: dired.c commands.h buffer.h $(config_h) regex.h
+dispnew.o: dispnew.c commands.h frame.h window.h buffer.h dispextern.h \
+   termchar.h termopts.h termhooks.h cm.h disptab.h systty.h systime.h \
+   xterm.h $(config_h)
+doc.o: doc.c $(config_h) paths.h buffer.h keyboard.h
+doprnt.o: doprnt.c $(config_h)
+dosfns.o: buffer.h termchar.h termhooks.h frame.h msdos.h dosfns.h $(config_h)
+editfns.o: editfns.c window.h buffer.h systime.h INTERVAL_SRC $(config_h) 
+emacs.o: emacs.c commands.h systty.h syssignal.h process.h INTERVAL_SRC $(config_h) 
+fileio.o: fileio.c window.h buffer.h systime.h INTERVAL_SRC $(config_h) 
+filelock.o: filelock.c buffer.h paths.h $(config_h)
+filemode.o: filemode.c  $(config_h)
+getloadavg.o: getloadavg.c $(config_h)
+indent.o: indent.c frame.h window.h indent.h buffer.h $(config_h) termchar.h \
+   termopts.h disptab.h region-cache.h
+insdel.o: insdel.c window.h buffer.h INTERVAL_SRC blockinput.h $(config_h)
+keyboard.o: keyboard.c termchar.h termhooks.h termopts.h buffer.h \
    commands.h frame.h window.h macros.h disptab.h keyboard.h syssignal.h \
-   systty.h systime.h dispextern.h intervals.h blockinput.h $(config_h) 
-keymap.o : keymap.c buffer.h commands.h keyboard.h termhooks.h blockinput.h \
-   $(config_h) 
-lastfile.o : lastfile.c  $(config_h)
-macros.o : macros.c window.h buffer.h commands.h macros.h $(config_h)
-malloc.o : malloc.c $(config_h)
-gmalloc.o : gmalloc.c $(config_h)
-ralloc.o : ralloc.c $(config_h)
-vm-limit.o : vm-limit.c mem-limits.h $(config_h) 
-marker.o : marker.c buffer.h $(config_h) 
-minibuf.o : minibuf.c syntax.h dispextern.h frame.h window.h \
+   systty.h systime.h dispextern.h intervals.h blockinput.h xterm.h $(config_h)
+keymap.o: keymap.c buffer.h commands.h keyboard.h termhooks.h blockinput.h \
+   puresize.h $(config_h) 
+lastfile.o: lastfile.c  $(config_h)
+macros.o: macros.c window.h buffer.h commands.h macros.h keyboard.h $(config_h)
+malloc.o: malloc.c $(config_h)
+msdos.o: msdos.c msdos.h dosfns.h systime.h termhooks.h dispextern.h \
+   termopts.h frame.h window.h $(config_h)
+mktime.o: mktime.c $(config_h)
+gmalloc.o: gmalloc.c $(config_h)
+ralloc.o: ralloc.c $(config_h)
+vm-limit.o: vm-limit.c mem-limits.h $(config_h) 
+marker.o: marker.c buffer.h $(config_h) 
+minibuf.o: minibuf.c syntax.h dispextern.h frame.h window.h \
    buffer.h commands.h $(config_h) 
-mocklisp.o : mocklisp.c buffer.h $(config_h)
-process.o : process.c process.h buffer.h window.h termhooks.h termopts.h \
+mocklisp.o: mocklisp.c buffer.h $(config_h)
+process.o: process.c process.h buffer.h window.h termhooks.h termopts.h \
    commands.h syssignal.h systime.h systty.h syswait.h frame.h $(config_h) 
-regex.o : regex.c syntax.h buffer.h $(config_h) regex.h 
-frame.o : frame.c xterm.h window.h frame.h termhooks.h commands.h keyboard.h \
+regex.o: regex.c syntax.h buffer.h $(config_h) regex.h 
+region-cache.o: region-cache.c buffer.h region-cache.h
+frame.o: frame.c xterm.h window.h frame.h termhooks.h commands.h keyboard.h \
    buffer.h $(config_h)
-scroll.o : scroll.c termchar.h $(config_h) dispextern.h frame.h
-search.o : search.c regex.h commands.h buffer.h syntax.h blockinput.h $(config_h) 
-syntax.o : syntax.c syntax.h buffer.h commands.h $(config_h) 
-sysdep.o : sysdep.c $(config_h) dispextern.h termhooks.h termchar.h termopts.h \
+scroll.o: scroll.c termchar.h dispextern.h frame.h $(config_h)
+search.o: search.c regex.h commands.h buffer.h region-cache.h syntax.h \
+   blockinput.h $(config_h) 
+strftime.o: strftime.c $(config_h)
+       $(CC) -c $(CPPFLAGS) $(ALL_CFLAGS) -Dstrftime=emacs_strftime $<
+syntax.o: syntax.c syntax.h buffer.h commands.h $(config_h) 
+sysdep.o: sysdep.c $(config_h) dispextern.h termhooks.h termchar.h termopts.h \
    frame.h syssignal.h systty.h systime.h syswait.h blockinput.h window.h
-term.o : term.c termchar.h termhooks.h termopts.h $(config_h) cm.h frame.h \
-   disptab.h
-termcap.o : termcap.c $(config_h)
-terminfo.o : terminfo.c $(config_h)
-tparam.o : tparam.c $(config_h)
-undo.o : undo.c buffer.h commands.h $(config_h) 
-UNEXEC : UNEXEC_SRC $(config_h)
-window.o : window.c indent.h commands.h frame.h window.h buffer.h termchar.h \
+term.o: term.c termchar.h termhooks.h termopts.h $(config_h) cm.h frame.h \
+   disptab.h keyboard.h
+termcap.o: termcap.c $(config_h)
+terminfo.o: terminfo.c $(config_h)
+tparam.o: tparam.c $(config_h)
+undo.o: undo.c buffer.h commands.h $(config_h) 
+/* This hack is to discard any space that cpp might put at the beginning
+   of UNEXEC when substituting it in.  */
+UNEXEC_ALIAS=UNEXEC
+$(UNEXEC_ALIAS): UNEXEC_SRC $(config_h)
+widget.o: widget.c xterm.h frame.h dispextern.h widgetprv.h $(config_h)
+window.o: window.c indent.h commands.h frame.h window.h buffer.h termchar.h \
    termhooks.h disptab.h keyboard.h $(config_h)
-xdisp.o : xdisp.c macros.h commands.h indent.h buffer.h dispextern.h \
+xdisp.o: xdisp.c macros.h commands.h indent.h buffer.h dispextern.h \
    termchar.h frame.h window.h disptab.h termhooks.h $(config_h) 
-xfaces.o : xfaces.c dispextern.h frame.h xterm.h buffer.h blockinput.h \
+xfaces.o: xfaces.c dispextern.h frame.h xterm.h buffer.h blockinput.h \
    window.h $(config_h) 
-xfns.o : xfns.c buffer.h frame.h window.h keyboard.h xterm.h \
-   blockinput.h $(config_h)
-xmenu.o : xmenu.c xterm.h window.h frame.h keyboard.h blockinput.h $(config_h)
-xterm.o : xterm.c xterm.h termhooks.h termopts.h termchar.h window.h \
-  dispextern.h frame.h disptab.h blockinput.h systime.h \
-  gnu.h sink.h sinkmask.h $(config_h)
-xselect.o : xselect.c dispextern.h frame.h xterm.h blockinput.h $(config_h) 
-xrdb.o : xrdb.c $(config_h)
-hftctl.o : hftctl.c $(config_h)
+xfns.o: xfns.c buffer.h frame.h window.h keyboard.h xterm.h \
+   blockinput.h paths.h $(config_h)
+xmenu.o: xmenu.c xterm.h window.h dispextern.h frame.h keyboard.h \
+   blockinput.h puresize.h msdos.h $(config_h)
+xterm.o: xterm.c xterm.h termhooks.h termopts.h termchar.h window.h \
+  dispextern.h frame.h disptab.h blockinput.h systime.h syssignal.h \
+  keyboard.h gnu.h sink.h sinkmask.h $(config_h)
+xselect.o: xselect.c dispextern.h frame.h xterm.h blockinput.h $(config_h) 
+xrdb.o: xrdb.c $(config_h)
+hftctl.o: hftctl.c $(config_h)
 
 /* The files of Lisp proper */
 
-alloc.o : alloc.c frame.h window.h buffer.h  puresize.h syssignal.h
-alloc.o : blockinput.h $(config_h) INTERVAL_SRC
-bytecode.o : bytecode.c buffer.h $(config_h)
-data.o : data.c buffer.h puresize.h syssignal.h $(config_h)
-eval.o : eval.c commands.h keyboard.h blockinput.h $(config_h)
-floatfns.o : floatfns.c $(config_h)
-fns.o : fns.c commands.h $(config_h) frame.h buffer.h keyboard.h INTERVAL_SRC
-print.o : print.c process.h frame.h window.h buffer.h $(config_h)
-lread.o : lread.c commands.h keyboard.h buffer.h paths.h $(config_h) \
+alloc.o: alloc.c frame.h window.h buffer.h  puresize.h syssignal.h keyboard.h \
+ blockinput.h $(config_h) INTERVAL_SRC
+bytecode.o: bytecode.c buffer.h syntax.h $(config_h)
+data.o: data.c buffer.h puresize.h syssignal.h keyboard.h $(config_h)
+eval.o: eval.c commands.h keyboard.h blockinput.h $(config_h)
+floatfns.o: floatfns.c $(config_h)
+fns.o: fns.c commands.h $(config_h) frame.h buffer.h keyboard.h INTERVAL_SRC
+print.o: print.c process.h frame.h window.h buffer.h keyboard.h $(config_h)
+lread.o: lread.c commands.h keyboard.h buffer.h paths.h $(config_h) \
  termhooks.h
 
 /* Text properties support */
-textprop.o : textprop.c buffer.h intervals.h $(config_h)
-intervals.o : intervals.c buffer.h intervals.h puresize.h $(config_h)
+textprop.o: textprop.c buffer.h intervals.h $(config_h)
+intervals.o: intervals.c buffer.h intervals.h keyboard.h puresize.h $(config_h)
 
 /* System-specific programs to be made.
    OTHER_FILES, OBJECTS_SYSTEM and OBJECTS_MACHINE
    select which of these should be compiled.  */
 
-sunfns.o  : sunfns.c buffer.h $(config_h)
+sunfns.o: sunfns.c buffer.h $(config_h)
 
 ${libsrc}emacstool: ${libsrc}emacstool.c
        cd ${libsrc}; ${MAKE} ${MFLAGS} emacstool
 mostlyclean:
-       rm -f temacs prefix-args xmakefile* core \#* *.o libXMenu11.a
+       rm -f temacs prefix-args core \#* *.o libXMenu11.a liblw.a
        rm -f ../etc/DOC
 clean: mostlyclean
        rm -f emacs-* emacs
 /**/# This is used in making a distribution.
 /**/# Do not use it on development directories!
 distclean: clean
-       rm -f paths.h config.h Makefile Makefile.in ../etc/DOC-*
-realclean: distclean
+       rm -f paths.h config.h Makefile Makefile.c ../etc/DOC-*
+maintainer-clean: distclean
+       @echo "This command is intended for maintainers to use;"
+       @echo "it deletes files that may require special tools to rebuild."
        rm -f TAGS
 versionclean:
        -rm -f emacs emacs-* ../etc/DOC*
@@ -795,16 +1042,24 @@ extraclean: distclean
 
 /* The rule for the [sm] files has to be written a little funny to
    avoid looking like a C comment to CPP. */
-SOURCES = *.[ch] [sm]/?* COPYING ymakefile \
-       config.h.in README COPYING ChangeLog vms.pp-trans
+SOURCES = *.[ch] [sm]/?* COPYING Makefile.in \
+       config.in paths.in README COPYING ChangeLog vms.pp-trans
 unlock:
        chmod u+w $(SOURCES)
 
 relock:
        chmod -w $(SOURCES)
        chmod +w paths.h
-tagsfiles = [a-z]*.h [a-z]*.c ../lisp/[a-z]*.el ../lisp/term/[a-z]*.el
-TAGS: $(tagsfiles)
-       etags $(tagsfiles)
-tags: TAGS
+
+/* Arrange to make a tags table in ../lisp, and another in this dir
+   which includes ../lisp/TAGS by reference.  */
+ctagsfiles = [a-zA-Z]*.[hc]
+lisptagsfiles = ../lisp/[a-zA-Z]*.el
+TAGS: $(ctagsfiles)
+       export DIR; DIR=`pwd`; cd ${srcdir}; \
+       $$DIR/../lib-src/etags --include=../lisp/TAGS \
+       --regex='/[     ]*DEFVAR_[A-Z_  (]+"\([^"]+\)"/' $(ctagsfiles)
+${lispsource}TAGS: ${lispsource}$(lisptagsfiles)
+       cd ${lispsource}; $(MAKE) TAGS
+tags: TAGS ${lispsource}TAGS
 .PHONY: tags