]> code.delx.au - gnu-emacs/blobdiff - lib-src/Makefile.in
Initial revision
[gnu-emacs] / lib-src / Makefile.in
index 73c099d1f344142bac94014ce7c2b20a09eb633a..27bd6f2e6488ed554fe8acf6c5adb8fc36fd9a07 100644 (file)
@@ -1,12 +1,22 @@
-# DIST: This is the distribution Makefile for Emacs.  configure can
-# DIST: make most of the changes to this file you might want, so try
-# DIST: that first.
+# Makefile for lib-src subdirectory in GNU Emacs.
+# Copyright (C) 1985, 1987, 1988, 1993, 1994 Free Software Foundation, Inc.
 
-# add -DUSG for SysV movemail and timer
-# For Xenix, add the following for movemail:
-#  LOADLIBES= -lx
-# For Mips, the following is needed for who knows what.
-#  LOADLIBES = -lmld /usr/bsd43/usr/lib/libc.a
+# 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 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, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
 
 # Avoid trouble on systems where the `SHELL' variable might be
 # inherited from the environment.
@@ -17,12 +27,9 @@ SHELL = /bin/sh
 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@
+configuration=@configuration@
 
 # ==================== Where To Install Things ====================
 
@@ -45,8 +52,8 @@ 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.  This is set with the
-# --libdir option to `../configure'.
-libdir=@libdir@
+# --libexecdir option to `../configure'.
+libexecdir=@libexecdir@
 
 # Where to find the source code.  This is set by the configure
 # script's `--srcdir' option.  However, the value of ${srcdir} in
@@ -55,6 +62,9 @@ libdir=@libdir@
 srcdir=@srcdir@
 VPATH=@srcdir@
 
+# The top-level source directory, also set by configure.
+top_srcdir=@top_srcdir@
+
 # ==================== Emacs-specific directories ====================
 
 # These variables hold the values Emacs will actually use.  They are
@@ -67,76 +77,192 @@ VPATH=@srcdir@
 # to `../configure'.
 archlibdir=@archlibdir@
 
-# ==================== Utility Programs for the Build ====================
+# ==================== Utility Programs for the Build =================
 
 # ../configure figures out the correct values for these.
 INSTALL = @INSTALL@
 INSTALL_PROGRAM = @INSTALL_PROGRAM@
 INSTALL_DATA = @INSTALL_DATA@
 
-# ============================= Targets ==============================
+# ========================== Lists of Files ===========================
 
-# Things that a user might actually run, which should be installed in bindir.
+# Things that a user might actually run,
+# which should be installed in bindir.
 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 profile make-docfile digest-doc \
+#  which should not be installed in bindir.
+UTILITIES= wakeup profile digest-doc \
        sorted-doc movemail cvtmail fakemail yow emacsserver hexl timer
 
+DONT_INSTALL= test-distrib make-docfile
+
 # Like UTILITIES, but they're not system-dependent, and should not be
-# deleted by the distclean target.
+#  deleted by the distclean target.
 SCRIPTS= rcs2log vcdiff
 
 EXECUTABLES= ${UTILITIES} ${INSTALLABLES} ${SCRIPTS} ${INSTALLABLE_SCRIPTS}
 
-SOURCES = COPYING ChangeLog Makefile.in README aixcc.lex emacs.csh \
+SOURCES = COPYING ChangeLog Makefile.in README emacs.csh \
        makedoc.com *.[chy] rcs2log vcdiff
 
-### We need to #define emacs to get the right versions of some files.
-### 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.
-ALL_CFLAGS = ${C_SWITCH_SYSTEM} ${C_SWITCH_MACHINE} -Demacs -DHAVE_CONFIG_H \
+# Additional -D flags for movemail (add to MOVE_FLAGS if desired):
+# MAIL_USE_POP         Support mail retrieval from a POP mailbox.
+# MAIL_USE_MMDF                Support MMDF mailboxes.
+# MAIL_USE_FLOCK       Use flock for file locking (see the comments
+#                      about locking in movemail.c)
+# MAIL_UNLINK_SPOOL    Unlink the user's spool mailbox after reading
+#                      it (instead of just emptying it).
+# KERBEROS             Support Kerberized POP.
+# KRB5                 Support Kerberos Version 5 pop instead of
+#                      Version 4 (define this in addition to
+#                      KERBEROS).
+# HESIOD               Support Hesiod lookups of user mailboxes.
+# MAILHOST             A string, the host name of the default POP
+#                      mail host for the site.
+MOVE_FLAGS=
+
+# Additional libraries for movemail:
+# For KERBEROS
+# MOVE_LIBS= -lkrb -ldes -lcom_err
+# For KERBEROS + KRB5
+# MOVE_LIBS= -lkrb5 -lcrypto -lisode -lcom_err
+# Add "-lhesiod" if HESIOD is defined.
+MOVE_LIBS=
+
+# ========================== start of cpp stuff =======================
+/* From here on, comments must be done in C syntax.  */
+
+#define NO_SHORTNAMES
+#define THIS_IS_MAKEFILE
+#define NOT_C_CODE
+#include "../src/config.h"
+
+/* We won't really call alloca;
+   don't let the file name alloca.c get messed up.  */
+#ifdef alloca
+#undef alloca
+#endif
+
+/* Some machines don't find the standard C libraries in the usual place.  */
+#ifndef ORDINARY_LINK
+#ifndef LIB_STANDARD_LIBSRC
+#define LIB_STANDARD_LIBSRC -lc
+#endif
+#else
+#ifndef LIB_STANDARD_LIBSRC
+#define LIB_STANDARD_LIBSRC
+#endif
+#endif
+
+/* Some s/*.h files define this to request special libraries.  */
+#ifndef LIBS_SYSTEM
+#define LIBS_SYSTEM
+#endif
+
+/* Some m/*.h files define this to request special libraries.  */
+#ifndef LIBS_MACHINE
+#define LIBS_MACHINE
+#endif
+
+#ifndef C_SWITCH_SYSTEM
+#define C_SWITCH_SYSTEM
+#endif
+
+#ifndef C_SWITCH_MACHINE
+#define C_SWITCH_MACHINE
+#endif
+
+#undef MOVEMAIL_NEEDS_BLESSING
+#ifndef MAIL_USE_FLOCK
+#ifndef MAIL_USE_LOCKF
+#define MOVEMAIL_NEEDS_BLESSING
+#endif
+#endif
+
+#ifdef MOVEMAIL_NEEDS_BLESSING
+#define BLESSMAIL blessmail
+#else
+#define BLESSMAIL
+#endif
+
+LOADLIBES=LIBS_SYSTEM LIBS_MACHINE LIB_STANDARD_LIBSRC
+
+/* We need to #define emacs to get the right versions of some files.
+   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.  */
+ALL_CFLAGS = C_SWITCH_SYSTEM C_SWITCH_MACHINE -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 \
+LINK_CFLAGS = C_SWITCH_SYSTEM C_SWITCH_MACHINE -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 \
+CPP_CFLAGS = C_SWITCH_SYSTEM C_SWITCH_MACHINE -DHAVE_CONFIG_H \
+   -I. -I../src -I${srcdir} -I${srcdir}/../src ${CPPFLAGS} ${CFLAGS}
+/* This was all of CPP_CFLAGS except -Demacs.
+   Now that -Demacs has been deleted from CPP_CFLAGS,
+   this is actually the same as CPP_CFLAGS, but let's not delete it yet.  */
+BASE_CFLAGS = C_SWITCH_SYSTEM C_SWITCH_MACHINE -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.
+\f
+/* 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}
+all: ${DONT_INSTALL} ${UTILITIES} ${INSTALLABLES}
+
+#ifdef MOVEMAIL_NEEDS_BLESSING
+blessmail:
+       ../src/emacs -batch -l ../lisp/blessmail.el
+       chmod +x blessmail
+#endif
+
+maybe-blessmail: BLESSMAIL
+#ifdef MOVEMAIL_NEEDS_BLESSING
+/* Don't charge ahead and do it!  Let the installer decide.
+         ./blessmail ${archlibdir}/movemail  */
+       @if [ `wc -l <blessmail` != 2 ] ; then \
+         dir=`sed -n -e 's/echo mail directory = \(.*\)/\1/p' blessmail`; \
+         echo Assuming $$dir is really the mail spool directory, you should; \
+         echo run  lib-src/blessmail ${archlibdir}/movemail; \
+         echo as root, to give  movemail  appropriate permissions.; \
+         echo Do that after running  make install.; \
+       fi
+#endif
 
-### Install the internal utilities.  Until they are installed, we can
-### just run them directly from lib-src.
+/* Install the internal utilities.  Until they are installed, we can
+   just run them directly from lib-src.  */
 ${archlibdir}: all
        @echo
        @echo "Installing utilities run internally by Emacs."
-       ./make-path ${archlibdir}
+       $(top_srcdir)/mkinstalldirs ${archlibdir}
        if [ `(cd ${archlibdir} && /bin/pwd)` != `/bin/pwd` ]; then \
          for file in ${UTILITIES}; do \
-           (cd ..; $(INSTALL_PROGRAM) lib-src/$$file ${archlibdir}/$$file) ; \
+           $(INSTALL_PROGRAM) $$file ${archlibdir}/$$file ; \
          done ; \
+        fi
+        if [ `(cd ${archlibdir} && /bin/pwd)` \
+             != `(cd ${srcdir} && /bin/pwd)` ]; then \
          for file in ${SCRIPTS}; do \
-           (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$$file ${archlibdir}/$$file); \
+           $(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.
+/* 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 ${INSTALLABLES} ; do \
-         (cd ..; $(INSTALL_PROGRAM) lib-src/$${file} ${bindir}/$${file}) ; \
+         $(INSTALL_PROGRAM) $${file} ${bindir}/$${file} ; \
+         chmod a+rx ${bindir}/$${file}; \
        done
        for file in ${INSTALLABLE_SCRIPTS} ; do \
-         (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$${file} ${bindir}/$${file}) ; \
+         $(INSTALL_PROGRAM) ${srcdir}/$${file} ${bindir}/$${file} ; \
+         chmod a+rx ${bindir}/$${file}; \
        done
 
 uninstall:
@@ -149,15 +275,17 @@ mostlyclean:
        -rm -f core *.o
 
 clean: mostlyclean
-       -rm -f ${INSTALLABLES} ${UTILITIES}
+       -rm -f ${INSTALLABLES} ${UTILITIES} ${DONT_INSTALL}
+       -rm -f ../etc/DOC* *.tab.c *.tab.h
 
 distclean: clean
-       -rm -f ../etc/DOC* *.tab.c *.tab.h aixcc.c TAGS
+       -rm -f TAGS
+       -rm -f Makefile Makefile.c blessmail
 
-realclean: distclean
+maintainer-clean: distclean
        true
 
-extraclean: realclean
+extraclean: maintainer-clean
        -rm -f *~ \#*
 
 unlock:
@@ -166,19 +294,20 @@ unlock:
 relock:
        chmod u-w $(SOURCES)
 
-# Test the contents of the directory.
+/* Test the contents of the directory.  */
 check:
        @echo "We don't have any tests for GNU Emacs yet."
 
+tags: TAGS
 TAGS: etags
        etags *.[ch]
 
-# This verifies that the non-ASCII characters in the file `testfile'
-# 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.
+/* This verifies that the non-ASCII characters in the file `testfile'
+   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: ${srcdir}/test-distrib.c
-       $(CC) -o test-distrib ${srcdir}/test-distrib.c
+       $(CC) ${ALL_CFLAGS} -o test-distrib ${srcdir}/test-distrib.c
        ./test-distrib ${srcdir}/testfile
 
 GETOPTOBJS = getopt.o getopt1.o $(ALLOCA)
@@ -187,14 +316,27 @@ 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
+alloca.o: ${srcdir}/alloca.c
+       ${CC} -c ${BASE_CFLAGS} ${srcdir}/alloca.c
+
+#ifdef REGEXP_IN_LIBC
+REGEXPOBJ =
+REGEXPDEPS =
+#else
+REGEXPOBJ = regex.o
+REGEXPDEPS = $(REGEXPOBJ) ../src/regex.h
+#endif
 
-etags: ${srcdir}/etags.c $(GETOPTDEPS) ../src/config.h
-       $(CC) ${ALL_CFLAGS} -DVERSION=${version} ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o etags
+regex.o: ../src/regex.c ../src/regex.h ../src/config.h
+       ${CC} -c ${BASE_CFLAGS} -DCONFIG_BROKETS -DINHIBIT_STRING_HEADER ${srcdir}/../src/regex.c
 
-# 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 -DVERSION=${version} ${srcdir}/etags.c $(GETOPTOBJS) $(LOADLIBES) -o ctags
+etags: ${srcdir}/etags.c $(GETOPTDEPS) $(REGEXPDEPS) ../src/config.h
+       $(CC) ${ALL_CFLAGS} -DVERSION="\"${version}\"" -DETAGS_REGEXPS ${srcdir}/etags.c $(GETOPTOBJS) $(REGEXPOBJ) $(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: etags
+       $(CC) ${ALL_CFLAGS} -DCTAGS -DVERSION="\"${version}\"" -DETAGS_REGEXPS ${srcdir}/etags.c $(GETOPTOBJS) $(REGEXPOBJ) $(LOADLIBES) -o ctags
 
 wakeup: ${srcdir}/wakeup.c
        $(CC) ${ALL_CFLAGS} ${srcdir}/wakeup.c $(LOADLIBES) -o wakeup
@@ -214,8 +356,14 @@ sorted-doc: ${srcdir}/sorted-doc.c ${ALLOCA}
 b2m: ${srcdir}/b2m.c ../src/config.h
        $(CC) ${ALL_CFLAGS} ${srcdir}/b2m.c $(LOADLIBES) -o b2m 
 
-movemail: ${srcdir}/movemail.c ../src/config.h
-       $(CC) ${ALL_CFLAGS} ${srcdir}/movemail.c $(LOADLIBES) -o movemail
+movemail: movemail.o pop.o
+       $(CC) ${LINK_CFLAGS} ${MOVE_FLAGS} movemail.o pop.o $(LOADLIBES) $(MOVE_LIBS) -o movemail
+
+movemail.o: ${srcdir}/movemail.c ../src/config.h
+       $(CC) -c ${CPP_CFLAGS} -Demacs ${MOVE_FLAGS} ${srcdir}/movemail.c
+
+pop.o: ${srcdir}/pop.c
+       $(CC) -c ${CPP_CFLAGS} ${MOVE_FLAGS} ${srcdir}/pop.c
 
 cvtmail: ${srcdir}/cvtmail.c
        $(CC) ${ALL_CFLAGS} ${srcdir}/cvtmail.c $(LOADLIBES) -o cvtmail
@@ -236,25 +384,24 @@ hexl: ${srcdir}/hexl.c
        $(CC) ${ALL_CFLAGS} ${srcdir}/hexl.c $(LOADLIBES) -o hexl
 
 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
+$(srcdir)/getdate.c: ${srcdir}/getdate.y
+       cd $(srcdir); ${YACC} ${YFLAGS} getdate.y
+       cd $(srcdir); mv y.tab.c getdate.c
+getdate.o: ${srcdir}/getdate.c ../src/config.h
+       $(CC) $(CPP_CFLAGS) -Demacs -c ${srcdir}/getdate.c
+
 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: ${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.
+/* These are NOT included in INSTALLABLES or UTILITIES.
+   See ../src/Makefile.in.  */
 emacstool: ${srcdir}/emacstool.c
        $(CC) ${srcdir}/emacstool.c -o emacstool ${ALL_CFLAGS} \
          -lsuntool -lsunwindow -lpixrect $(LOADLIBES)
 
-# For SUN Japanese Language Environment
+/* For SUN Japanese Language Environment.  */
 nemacstool: ${srcdir}/emacstool.c
        $(CC) -o nemacstool -DJLE ${ALL_CFLAGS} ${srcdir}/emacstool.c \
          -lsuntool -lmle -lsunwindow -lpixrect $(LOADLIBES)
@@ -268,10 +415,3 @@ 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: ${srcdir}/aixcc.c
-       $(CC) $(ALL_CFLAGS) -o aixcc ${srcdir}/aixcc.c
-
-aixcc.c: ${srcdir}/aixcc.lex
-       lex ${srcdir}/aixcc.lex
-       mv lex.yy.c aixcc.c