X-Git-Url: https://git.hcoop.net/bpt/emacs.git/blobdiff_plain/c6b81ef2ee869853b21445af2d75a9568385f593..ff773a4e166e0b84f4a34135321d6bd35e07943e:/lib-src/Makefile.in diff --git a/lib-src/Makefile.in b/lib-src/Makefile.in index 73a80f281c..ff3cb30e58 100644 --- a/lib-src/Makefile.in +++ b/lib-src/Makefile.in @@ -12,41 +12,48 @@ # inherited from the environment. SHELL = /bin/sh -# ==================== Things `configure' might edit ==================== - -CC=cc -CONFIG_CFLAGS=-g -C_SWITCH_SYSTEM= -LOADLIBES= -version=version-not-set -configname=configuration-name-not-set +# ==================== Things `configure' will edit ==================== + +CC=@CC@ +CFLAGS=@CFLAGS@ +ALLOCA=@ALLOCA@ +C_SWITCH_SYSTEM=@c_switch_system@ +C_SWITCH_MACHINE=@c_switch_machine@ +LOADLIBES=@libsrc_libs@ +YACC=@YACC@ +version=@version@ +configname=@configuration@ # ==================== Where To Install Things ==================== # The default location for installation. Everything is placed in # subdirectories of this directory. The default values for many of # the variables below are expressed in terms of this one, so you may -# not need to change them. -prefix=/usr/local +# not need to change them. This is set with the --prefix option to +# `../configure'. +prefix=@prefix@ -# Like `prefix', but used for architecture-specific files. -exec_prefix=${prefix} +# Like `prefix', but used for architecture-specific files. This is +# set with the --exec-prefix option to `../configure'. +exec_prefix=@exec_prefix@ # Where to install Emacs and other binaries that people will want to -# run directly (like etags). -bindir=${exec_prefix}/bin +# run directly (like etags). This is set with the --bindir option +# to `../configure'. +bindir=@bindir@ # Where to install and expect executable files to be run by Emacs # rather than directly by users, and other architecture-dependent -# data. ${archlibdir} is usually below this. -libdir=${exec_prefix}/lib +# data. ${archlibdir} is usually below this. This is set with the +# --libdir option to `../configure'. +libdir=@libdir@ -# 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 -# set by the configure script's `--srcdir' option. -srcdir=. +# Where to find the source code. This is set by the configure +# script's `--srcdir' option. However, the value of ${srcdir} in +# this makefile is not identical to what was specified with --srcdir, +# since the variable here has `/lib-src' added at the end. +srcdir=@srcdir@ +VPATH=@srcdir@ # ==================== Emacs-specific directories ==================== @@ -56,42 +63,33 @@ srcdir=. # Where to put executables to be run by Emacs rather than the user. # This path usually includes the Emacs version and configuration name, # so that multiple configurations for multiple versions of Emacs may -# be installed at once. -archlibdir=${libdir}/emacs/${version}/${configname} - -# ====================== Developer's configuration ======================= - -# The following assignments make sense if you're running Emacs on a single -# machine, one version at a time, and you want changes to the lisp and etc -# directories in the source tree to show up immediately in your working -# environment. It saves a great deal of disk space by not duplicating the -# lisp and etc directories. -# -# archlibdir=${srcdir}/bin +# be installed at once. This can be set with the --archlibdir option +# to `../configure'. +archlibdir=@archlibdir@ # ==================== Utility Programs for the Build ==================== -# Allow the user to specify the install program. -INSTALL = install -INSTALLFLAGS = -c -INSTALL_PROGRAM = ${INSTALL} -INSTALL_DATA = ${INSTALL} +# ../configure figures out the correct values for these. +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ # ============================= 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. -UTILITIES= test-distrib make-path wakeup make-docfile digest-doc sorted-doc \ - movemail cvtmail fakemail yow env emacsserver hexl timer +UTILITIES= test-distrib make-path wakeup profile make-docfile digest-doc \ + sorted-doc movemail cvtmail fakemail yow env emacsserver hexl timer # Like UTILITIES, but they're not system-dependent, and should not be # 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 +98,19 @@ 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=${CONFIG_CFLAGS} ${C_SWITCH_SYSTEM} -Demacs -DHAVE_CONFIG_H -I../src - -all: ${EXECUTABLES} +ALL_CFLAGS = ${C_SWITCH_SYSTEM} ${C_SWITCH_MACHINE} -Demacs -DHAVE_CONFIG_H \ + -I. -I../src -I${srcdir} -I${srcdir}/../src ${LDFLAGS} ${CPPFLAGS} ${CFLAGS} +LINK_CFLAGS = ${C_SWITCH_SYSTEM} ${C_SWITCH_MACHINE} -Demacs -DHAVE_CONFIG_H \ + -I. -I../src -I${srcdir} -I${srcdir}/../src ${LDFLAGS} ${CFLAGS} +CPP_CFLAGS = ${C_SWITCH_SYSTEM} ${C_SWITCH_MACHINE} -Demacs -DHAVE_CONFIG_H \ + -I. -I../src -I${srcdir} -I${srcdir}/../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,46 +118,44 @@ ${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 \ - cp $${file} ${archlibdir} ; \ - chmod 755 ${archlibdir}/$${file} ; \ + if [ `(cd ${archlibdir} && /bin/pwd)` != `/bin/pwd` ]; then \ + for file in ${UTILITIES}; do \ + (cd ..; $(INSTALL_PROGRAM) lib-src/$$file ${archlibdir}/$$file) ; \ done ; \ - 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.)" - -for file in ${EXECUTABLES} ; do \ - chgrp bin ${archlibdir}/$${file} ; \ - chown bin ${archlibdir}/$${file} ; \ - done + for file in ${SCRIPTS}; do \ + (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$$file ${archlibdir}/$$file); \ + done ; \ + fi # We don't need to install `wakeup' explicitly, because it will be copied when # this whole directory is copied. 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 - @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} ; do \ + (cd ..; $(INSTALL_PROGRAM) lib-src/$${file} ${bindir}/$${file}) ; \ + done + for file in ${INSTALLABLE_SCRIPTS} ; do \ + (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$${file} ${bindir}/$${file}) ; \ + done -clean mostlyclean: - -rm -f ${INSTALLABLES} ${UTILITIES} core *.o +uninstall: + (cd ${bindir}; \ + rm -f ${INSTALLABLES} ${INSTALLABLE_SCRIPTS}) + (cd ${archlibdir}; \ + rm -f ${UTILITIES} ${INSTALLABLES} ${SCRIPTS} ${INSTALLABLE_SCRIPTS}) -distclean: - -rm -f ${INSTALLABLES} ${UTILITIES} ../etc/DOC* core *.o +mostlyclean: + -rm -f core *.o + +clean: mostlyclean + -rm -f ${INSTALLABLES} ${UTILITIES} + +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 +177,104 @@ 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 $(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 -GETOPTOBJS = getopt.o getopt1.o -GETOPTDEPS = $(GETOPTOBJS) getopt.h -getopt.o: getopt.c getopt.h -getopt1.o: getopt1.c getopt.h +etags: ${srcdir}/etags.c $(GETOPTDEPS) ../src/config.h + $(CC) ${ALL_CFLAGS} -DETAGS ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o etags -etags: etags.c $(GETOPTDEPS) - $(CC) ${CFLAGS} -DETAGS etags.c $(GETOPTOBJS) $(LOADLIBES) -o etags +# 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) ${ALL_CFLAGS} -DCTAGS ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o ctags -ctags: etags.c $(GETOPTDEPS) - $(CC) ${CFLAGS} -DCTAGS etags.c $(GETOPTOBJS) $(LOADLIBES) -o ctags +wakeup: ${srcdir}/wakeup.c + $(CC) ${ALL_CFLAGS} ${srcdir}/wakeup.c $(LOADLIBES) -o wakeup -wakeup: wakeup.c - $(CC) ${CFLAGS} wakeup.c $(LOADLIBES) -o wakeup +profile: ${srcdir}/profile.c + $(CC) ${ALL_CFLAGS} ${srcdir}/profile.c $(LOADLIBES) -o profile -make-docfile: make-docfile.c - $(CC) ${CFLAGS} make-docfile.c $(LOADLIBES) -o make-docfile +make-docfile: ${srcdir}/make-docfile.c + $(CC) ${ALL_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) ${ALL_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) ${ALL_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) ${ALL_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) ${ALL_CFLAGS} ${srcdir}/movemail.c $(LOADLIBES) -o movemail -cvtmail: cvtmail.c - $(CC) ${CFLAGS} cvtmail.c $(LOADLIBES) -o cvtmail +cvtmail: ${srcdir}/cvtmail.c + $(CC) ${ALL_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) ${ALL_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) ${ALL_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 ${ALL_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) ${ALL_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) ${ALL_CFLAGS} ${srcdir}/emacsclient.c $(LOADLIBES) -o emacsclient -hexl: hexl.c - $(CC) ${CFLAGS} hexl.c $(LOADLIBES) -o hexl +hexl: ${srcdir}/hexl.c + $(CC) ${ALL_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) $(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 $(CPP_CFLAGS) ${srcdir}/timer.c +timer: ${TIMEROBJS} + $(CC) $(LINK_CFLAGS) ${TIMEROBJS} $(LOADLIBES) -o timer -make-path: make-path.c - $(CC) $(CFLAGS) make-path.c -o make-path +make-path: ${srcdir}/make-path.c ../src/config.h + $(CC) $(ALL_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 ${ALL_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 ${ALL_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 ${ALL_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 ${ALL_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) $(ALL_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