# ==================== 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
# 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 ====================
# ============================= 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.
# 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
### 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.
@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.)"
# 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 *~ \#*
# 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