]> code.delx.au - gnu-emacs/blobdiff - lib-src/Makefile.in
(shell-command-history): New variable.
[gnu-emacs] / lib-src / Makefile.in
index 85c7207159dd5776d242a71c41d624d588fcb889..2ea43a779899925d383b3ffeab0dd4b923148223 100644 (file)
@@ -15,9 +15,11 @@ SHELL = /bin/sh
 # ==================== Things `configure' might edit ====================
 
 CC=cc
-DEFS=-g
+CFLAGS=-g
+ALLOCA=
 C_SWITCH_SYSTEM=
 LOADLIBES=
+YACC=yacc
 version=version-not-set
 configname=configuration-name-not-set
 
@@ -41,12 +43,13 @@ bindir=${exec_prefix}/bin
 # data.  ${archlibdir} is usually below this.
 libdir=${exec_prefix}/lib
 
-# Where to find the source code - setting this to anything but
-# . doesn't work yet.  The source code for Emacs's C kernel is
-# expected to be in ${srcdir}/src, and the source code for Emacs's
-# utility programs is expected to be in ${srcdir}/lib-src.  This is
+# Where to find the source code.  This is
 # set by the configure script's `--srcdir' option.
-srcdir=.
+# However, the value of ${srcdir} in this makefile
+# is not identical to what was specified with --srcdir.
+# The variable here has `/lib-src' added at the end.
+srcdir=@srcdir@/lib-src
+VPATH=@srcdir@/lib-src
 
 # ==================== Emacs-specific directories ====================
 
@@ -80,7 +83,8 @@ INSTALL_DATA = ${INSTALL}
 # ============================= Targets ==============================
 
 # Things that a user might actually run, which should be installed in bindir.
-INSTALLABLES = etags ctags emacsclient b2m rcs-checkin
+INSTALLABLES = etags ctags emacsclient b2m
+INSTALLABLE_SCRIPTS = rcs-checkin
 
 # Things that Emacs runs internally, or during the build process,
 # which should not be installed in bindir.
@@ -91,7 +95,7 @@ UTILITIES= test-distrib make-path wakeup make-docfile digest-doc sorted-doc \
 # deleted by the distclean target.
 SCRIPTS= rcs2log vcdiff
 
-EXECUTABLES= ${UTILITIES} ${INSTALLABLES} ${SCRIPTS}
+EXECUTABLES= ${UTILITIES} ${INSTALLABLES} ${SCRIPTS} ${INSTALLABLE_SCRIPTS}
 
 SOURCES = COPYING ChangeLog Makefile.in README aixcc.lex emacs.csh \
        makedoc.com *.[chy] rcs2log vcdiff
@@ -100,9 +104,17 @@ SOURCES = COPYING ChangeLog Makefile.in README aixcc.lex emacs.csh \
 ### Some other files - those shared with other GNU utilities - need
 ### HAVE_CONFIG_H #defined before they know they can take advantage of
 ### the information in ../src/config.h.
-CFLAGS=${DEFS} ${C_SWITCH_SYSTEM} -Demacs -DHAVE_CONFIG_H -I../src
-
-all: ${EXECUTABLES}
+ALL_CFLAGS = ${C_SWITCH_SYSTEM} -Demacs -DHAVE_CONFIG_H \
+   -I${srcdir} -I${srcdir}/../src -I. -I../src ${CFLAGS}
+CPP_CFLAGS = ${C_SWITCH_SYSTEM} -Demacs -DHAVE_CONFIG_H \
+   -I${srcdir} -I${srcdir}/../src -I. -I../src ${CPPFLAGS} ${CFLAGS}
+# This is the default compilation command.
+# But we should never rely on it, because some make version
+# failed to find it for getopt.o.  Using an explicit command made it work.
+.c.o:
+       ${CC} -c ${CPP_CFLAGS} $<
+
+all: ${UTILITIES} ${INSTALLABLES}
 
 ### Install the internal utilities.  Until they are installed, we can
 ### just run them directly from lib-src.
@@ -110,12 +122,16 @@ ${archlibdir}: all
        @echo
        @echo "Installing utilities run internally by Emacs."
        ./make-path ${archlibdir}
-       if [ `(cd ${archlibdir};/bin/pwd)` != `/bin/pwd` ]; then \
-         for file in ${EXECUTABLES} ; do \
+       if [ `(cd ${archlibdir} && /bin/pwd)` != `/bin/pwd` ]; then \
+         for file in ${UTILITIES} ${INSTALLABLES}; do \
+           cp $${file} ${archlibdir} ; \
+           chmod 755 ${archlibdir}/$${file} ; \
+         done ; \
+         cd ${srcdir}; for file in ${SCRIPTS} ${INSTALLABLE_SCRIPTS}; do \
            cp $${file} ${archlibdir} ; \
            chmod 755 ${archlibdir}/$${file} ; \
          done ; \
-        fi
+       fi
        @echo
        @echo "Changing the owner and group of Emacs's utility programs to \`bin'."
        @echo "(You may ignore errors here if you don't care about this.)"
@@ -126,30 +142,42 @@ ${archlibdir}: all
 
 # We don't need to install `wakeup' explicitly, because it will be copied when
 # this whole directory is copied.
+# We use .n, not .new as before, to avoid exceeding the 14-character limit.
 install: ${archlibdir}
        @echo
        @echo "Installing utilities for users to run."
-       for file in emacsclient etags ctags b2m ; do \
-         cp $${file} ${bindir}/$${file}.new ; \
-         chmod 755 ${bindir}/$${file}.new ; \
-        done
+       for file in ${INSTALLABLES} ; do \
+         cp $${file} ${bindir}/$${file}.n ; \
+         chmod 755 ${bindir}/$${file}.n ; \
+       done
+       for file in ${INSTALLABLE_SCRIPTS} ; do \
+         cp ${srcdir}/$${file} ${bindir}/$${file}.n ; \
+         chmod 755 ${bindir}/$${file}.n ; \
+       done
        @echo
        @echo "Changing the owner and group of utility programs to \`bin'."
        @echo "(You may ignore errors here if you don't care about this.)"
-       -for file in emacsclient etags ctags b2m ; do \
-         chgrp bin ${bindir}/$${file}.new ; \
-         chown bin ${bindir}/$${file}.new ; \
-         mv ${bindir}/$${file}.new ${bindir}/$${file} ; \
-        done
+       -for file in ${INSTALLABLES}  ${INSTALLABLE_SCRIPTS} ; do \
+         chgrp bin ${bindir}/$${file}.n ; \
+         chown bin ${bindir}/$${file}.n ; \
+         rm -f ${bindir}/$${file} ; \
+         mv ${bindir}/$${file}.n ${bindir}/$${file} ; \
+       done
+
+uninstall:
+       (cd ${bindir}; \
+        rm -f ${INSTALLABLES} ${INSTALLABLE_SCRIPTS})
+       (cd ${archlibdir}; \
+        rm -f ${UTILITIES} ${INSTALLABLES} ${SCRIPTS} ${INSTALLABLE_SCRIPTS})
 
 clean mostlyclean:
        -rm -f ${INSTALLABLES} ${UTILITIES} core *.o
 
-distclean:
-       -rm -f ${INSTALLABLES} ${UTILITIES} ../etc/DOC* core *.o
+distclean: clean
+       -rm -f ../etc/DOC* *.tab.c *.tab.h aixcc.c TAGS
 
 realclean: distclean
-       -rm TAGS aixcc.c
+       true
 
 extraclean: realclean
        -rm -f *~ \#*
@@ -171,94 +199,101 @@ TAGS: etags
 # have not been clobbered by whatever means were used to copy and
 # distribute Emacs.  If they were clobbered, all the .elc files were
 # clobbered too.
-test-distrib: test-distrib.c
-       $(CC) -o test-distrib test-distrib.c
-       ./test-distrib
+test-distrib: ${srcdir}/test-distrib.c
+       $(CC) -o test-distrib ${srcdir}/test-distrib.c
+       ./test-distrib ${srcdir}/testfile
 
-GETOPTOBJS = getopt.o getopt1.o
-GETOPTDEPS = $(GETOPTOBJS) getopt.h
-getopt.o: getopt.c getopt.h
-getopt1.o: getopt1.c getopt.h
+GETOPTOBJS = getopt.o getopt1.o $(ALLOCA)
+GETOPTDEPS = $(GETOPTOBJS) ${srcdir}/getopt.h
+getopt.o: ${srcdir}/getopt.c ${srcdir}/getopt.h
+       ${CC} -c ${CPP_CFLAGS} ${srcdir}/getopt.c
+getopt1.o: ${srcdir}/getopt1.c ${srcdir}/getopt.h
+       ${CC} -c ${CPP_CFLAGS} ${srcdir}/getopt1.c
 
-etags: etags.c $(GETOPTDEPS)
-       $(CC) ${CFLAGS} -DETAGS etags.c $(GETOPTOBJS) $(LOADLIBES) -o etags
+etags: ${srcdir}/etags.c $(GETOPTDEPS) ../src/config.h
+       $(CC) ${CPP_CFLAGS} -DETAGS ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o etags
 
-ctags: etags.c $(GETOPTDEPS)
-       $(CC) ${CFLAGS} -DCTAGS etags.c $(GETOPTOBJS) $(LOADLIBES) -o ctags
+# We depend on etags to assure that parallel makes don't write two
+# etags.o files on top of each other.
+ctags: ${srcdir}/etags.c $(GETOPTDEPS) etags
+       $(CC) ${CPP_CFLAGS} -DCTAGS ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o ctags
 
-wakeup: wakeup.c
-       $(CC) ${CFLAGS} wakeup.c $(LOADLIBES) -o wakeup
+wakeup: ${srcdir}/wakeup.c
+       $(CC) ${CPP_CFLAGS} ${srcdir}/wakeup.c $(LOADLIBES) -o wakeup
 
-make-docfile: make-docfile.c
-       $(CC) ${CFLAGS} make-docfile.c $(LOADLIBES) -o make-docfile
+make-docfile: ${srcdir}/make-docfile.c
+       $(CC) ${CPP_CFLAGS} ${srcdir}/make-docfile.c $(LOADLIBES) -o make-docfile
 
-digest-doc: digest-doc.c
-       $(CC) ${CFLAGS} digest-doc.c $(LOADLIBES) -o digest-doc 
+digest-doc: ${srcdir}/digest-doc.c
+       $(CC) ${CPP_CFLAGS} ${srcdir}/digest-doc.c $(LOADLIBES) -o digest-doc 
 
-sorted-doc: sorted-doc.c
-       $(CC) ${CFLAGS} sorted-doc.c $(LOADLIBES) -o sorted-doc
+sorted-doc: ${srcdir}/sorted-doc.c ${ALLOCA}
+       $(CC) ${CPP_CFLAGS} ${srcdir}/sorted-doc.c ${ALLOCA} $(LOADLIBES) -o sorted-doc
 
-b2m: b2m.c ../src/config.h
-       $(CC) ${CFLAGS} b2m.c $(LOADLIBES) -o b2m 
+b2m: ${srcdir}/b2m.c ../src/config.h
+       $(CC) -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/b2m.c $(LOADLIBES) -o b2m 
 
-movemail: movemail.c ../src/config.h
-       $(CC) ${CFLAGS} movemail.c $(LOADLIBES) -o movemail
+movemail: ${srcdir}/movemail.c ../src/config.h
+       $(CC) -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/movemail.c $(LOADLIBES) -o movemail
 
-cvtmail: cvtmail.c
-       $(CC) ${CFLAGS} cvtmail.c $(LOADLIBES) -o cvtmail
+cvtmail: ${srcdir}/cvtmail.c
+       $(CC) ${CPP_CFLAGS} ${srcdir}/cvtmail.c $(LOADLIBES) -o cvtmail
 
-fakemail: fakemail.c ../src/config.h
-       $(CC) ${CFLAGS} fakemail.c $(LOADLIBES) -o fakemail
+fakemail: ${srcdir}/fakemail.c ../src/config.h
+       $(CC) -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/fakemail.c $(LOADLIBES) -o fakemail
 
-yow: yow.c ../src/paths.h
-       $(CC) ${CFLAGS} yow.c $(LOADLIBES) -o yow
+yow: ${srcdir}/yow.c ../src/paths.h
+       $(CC) ${CPP_CFLAGS} ${srcdir}/yow.c $(LOADLIBES) -o yow
 
-env: env.c ../src/config.h
-       $(CC) -DEMACS ${CFLAGS} env.c $(LOADLIBES) -o env
+env: ${srcdir}/env.c ../src/config.h
+       $(CC) -DEMACS -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/env.c $(LOADLIBES) -o env
 
-emacsserver: emacsserver.c ../src/config.h
-       $(CC) ${CFLAGS} emacsserver.c $(LOADLIBES) -o emacsserver
+emacsserver: ${srcdir}/emacsserver.c ../src/config.h
+       $(CC) -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/emacsserver.c $(LOADLIBES) -o emacsserver
 
-emacsclient: emacsclient.c ../src/config.h
-       $(CC) ${CFLAGS} emacsclient.c $(LOADLIBES) -o emacsclient
+emacsclient: ${srcdir}/emacsclient.c ../src/config.h
+       $(CC) -I${srcdir}/../src ${CPP_CFLAGS} ${srcdir}/emacsclient.c $(LOADLIBES) -o emacsclient
 
-hexl: hexl.c
-       $(CC) ${CFLAGS} hexl.c $(LOADLIBES) -o hexl
+hexl: ${srcdir}/hexl.c
+       $(CC) ${CPP_CFLAGS} ${srcdir}/hexl.c $(LOADLIBES) -o hexl
 
-getdate.o: getdate.y ../src/config.h
-       ${YACC} ${YFLAGS} getdate.y
-       $(CC) $(CFLAGS) -c y.tab.c
+TIMEROBJS=getdate.o timer.o $(ALLOCA)
+getdate.o: ${srcdir}/getdate.y ../src/config.h
+       ${YACC} ${YFLAGS} ${srcdir}/getdate.y
+       $(CC) -I${srcdir}/../src $(CPP_CFLAGS) -c y.tab.c
        mv y.tab.o getdate.o
-timer: getdate.o timer.o
-       $(CC) $(CFLAGS) getdate.o timer.o -o timer
+timer.o: ${srcdir}/timer.c ../src/config.h
+       $(CC) -c -I${srcdir}/../src $(CPP_CFLAGS) ${srcdir}/timer.c
+timer: ${TIMEROBJS}
+       $(CC) -I${srcdir}/../src $(ALL_CFLAGS) ${TIMEROBJS} $(LOADLIBES) -o timer
 
-make-path: make-path.c
-       $(CC) $(CFLAGS) make-path.c -o make-path
+make-path: ${srcdir}/make-path.c
+       $(CC) $(CPP_CFLAGS) ${srcdir}/make-path.c -o make-path
 
 # These are NOT included in INSTALLABLES or UTILITIES.
 # See ../src/ymakefile.
-emacstool: emacstool.c
-       $(CC) emacstool.c -o emacstool ${CFLAGS} \
+emacstool: ${srcdir}/emacstool.c
+       $(CC) ${srcdir}/emacstool.c -o emacstool ${CPP_CFLAGS} \
          -lsuntool -lsunwindow -lpixrect $(LOADLIBES)
 
 # For SUN Japanese Language Environment
-nemacstool: emacstool.c
-       $(CC) -o nemacstool -DJLE ${CFLAGS} emacstool.c \
+nemacstool: ${srcdir}/emacstool.c
+       $(CC) -o nemacstool -DJLE ${CPP_CFLAGS} ${srcdir}/emacstool.c \
          -lsuntool -lmle -lsunwindow -lpixrect $(LOADLIBES)
 
-xvetool: emacstool.c
-       $(CC) -o xvetool -DXVIEW ${CFLAGS} emacstool.c \
+xvetool: ${srcdir}/emacstool.c
+       $(CC) -o xvetool -DXVIEW ${CPP_CFLAGS} ${srcdir}/emacstool.c \
          -lxview -lX -I$(OPENWINHOME)/include -L$(OPENWINHOME)/lib \
          $(LOADLIBES)
 
-xveterm: emacstool.c
-       $(CC) -o xveterm -DXVIEW -DTTERM ${CFLAGS} emacstool.c \
+xveterm: ${srcdir}/emacstool.c
+       $(CC) -o xveterm -DXVIEW -DTTERM ${CPP_CFLAGS} ${srcdir}/emacstool.c \
          -lxview -lolgx -lX  -I$(OPENWINHOME)/include -L$(OPENWINHOME)/lib \
          $(LOADLIBES)
 
-aixcc: aixcc.c
-       $(CC) $(CFLAGS) -o aixcc aixcc.c
+aixcc: ${srcdir}/aixcc.c
+       $(CC) $(CPP_CFLAGS) -o aixcc ${srcdir}/aixcc.c
 
-aixcc.c: aixcc.lex
-       lex aixcc.lex
+aixcc.c: ${srcdir}/aixcc.lex
+       lex ${srcdir}/aixcc.lex
        mv lex.yy.c aixcc.c