all:
+#lisp=$(MAKEDIR:\=/)
+lisp=.
+
# You can specify a different executable on the make command line,
# e.g. "make EMACS=../src/emacs ...".
-EMACS = ..\src\$(BLD)\emacs
+EMACS = ..\bin\emacs.exe
# Command line flags for Emacs. This must include --multibyte,
# otherwise some files will not compile.
-EMACSOPT = --no-init-file --no-site-file --multibyte -batch
+EMACSOPT = -batch --no-init-file --no-site-file --multibyte
+
+lisptagsfiles1 = $(lisp)/*.el
+lisptagsfiles2 = $(lisp)/*/*.el
+ETAGS = ..\lib-src\$(BLD)\etags
-# Files which should not be compiled. All file names must be relative
-# to the `lisp' directory.
+# Files which should not be compiled.
# - emacs-lisp/cl-specs.el: only contains `def-edebug-spec's so there's
# no point compiling it, although it doesn't hurt.
-DONTCOMPILE = bindings.el mail/blessmail.el play/bruce.el cus-load.el \
- cus-start.el forms-d2.el forms-pass.el \
- international/latin-1.el international/latin-2.el \
- international/latin-3.el international/latin-4.el \
- international/latin-5.el \
- loaddefs.el loadup.el international/mule-conf.el patcomp.el \
- paths.el mail/sc.el subdirs.el version.el \
- generic-x.el international/latin-8.el international/latin-9.el \
- emacs-lisp/cl-specs.el finder-inf.el term/internal.el
+DONTCOMPILE = \
+ $(lisp)/bindings.el \
+ $(lisp)/cus-load.el \
+ $(lisp)/cus-start.el \
+ $(lisp)/emacs-lisp/cl-specs.el \
+ $(lisp)/eshell/esh-maint.el \
+ $(lisp)/eshell/esh-group.el \
+ $(lisp)/finder-inf.el \
+ $(lisp)/forms-d2.el \
+ $(lisp)/forms-pass.el \
+ $(lisp)/generic-x.el \
+ $(lisp)/international/latin-1.el \
+ $(lisp)/international/latin-2.el \
+ $(lisp)/international/latin-3.el \
+ $(lisp)/international/latin-4.el \
+ $(lisp)/international/latin-5.el \
+ $(lisp)/international/latin-8.el \
+ $(lisp)/international/latin-9.el \
+ $(lisp)/international/mule-conf.el \
+ $(lisp)/loaddefs.el \
+ $(lisp)/loadup.el \
+ $(lisp)/mail/blessmail.el \
+ $(lisp)/mail/sc.el \
+ $(lisp)/patcomp.el \
+ $(lisp)/paths.el \
+ $(lisp)/play/bruce.el \
+ $(lisp)/subdirs.el \
+ $(lisp)/term/internal.el \
+ $(lisp)/version.el
+
+# Files to compile before others during a bootstrap. This is done
+# to speed up the bootstrap process.
+
+COMPILE_FIRST = \
+ $(lisp)/emacs-lisp/byte-opt.el \
+ $(lisp)/emacs-lisp/bytecomp.el \
+ $(lisp)/subr.el
# The actual Emacs command run in the targets below.
emacs = $(EMACS) $(EMACSOPT)
+# Common command to find subdirectories
+
+# setwins=subdirs=`find $$wd -type d -print`; \
+# for file in $$subdirs; do \
+# case $$file in */Old | */RCS | */CVS | */CVS/* | */=* ) ;; \
+# *) wins="$$wins $$file" ;; \
+# esac; \
+# done
+
+# Have to define the list of subdirs manually
+WINS=\
+ calendar \
+ emacs-lisp \
+ emulation \
+ eshell \
+ gnus \
+ international \
+ language \
+ mail \
+ net \
+ play \
+ progmodes \
+ term \
+ textmodes
+
+doit:
+
+cus-load.el:
+ touch $@
+custom-deps: cus-load.el doit
+ @echo Directories: $(WINS)
+ $(emacs) -l cus-dep --eval "(setq find-file-hooks nil)" -f custom-make-dependencies $(lisp) $(WINS)
+
+finder-inf.el:
+ echo (provide 'finder-inf)>> $@
+
+finder-data: finder-inf.el doit
+ @echo Directories: $(WINS)
+ $(emacs) -l finder -f finder-compile-keywords-make-dist $(lisp) $(WINS)
+
+loaddefs.el:
+ echo ;;; loaddefs.el --- automatically extracted autoloads> $@
+ echo ;;; Code:>> $@
+ echo \f>> $@
+ echo ;;; Local Variables:>> $@
+ echo ;;; version-control: never>> $@
+ echo ;;; no-byte-compile: t>> $@
+ echo ;;; no-update-autoloads: t>> $@
+ echo ;;; End:>> $@
+ echo ;;; loaddefs.el ends here>> $@
+
+autoloads: loaddefs.el doit
+ @echo Directories: $(WINS)
+ $(emacs) -l autoload --eval "(setq find-file-hooks nil generated-autoload-file \"$(lisp)/loaddefs.el\")" -f batch-update-autoloads $(lisp) $(WINS)
+
+subdirs.el:
+ $(MAKE) $(MFLAGS) -f makefile.nt update-subdirs
+update-subdirs: doit
+ @set QWINS=
+ @for %d in ($(WINS)) do if not (%d)==(term) set QWINS=%QWINS% "%d"
+ echo ;; In load-path, after this directory should come> subdirs.el
+ echo ;; certain of its subdirectories. Here we specify them.>> subdirs.el
+ echo (normal-top-level-add-to-load-path '(%QWINS%))>> subdirs.el
+
+updates: update-subdirs autoloads finder-data custom-deps
+
+TAGS: $(lisptagsfiles1) $(lisptagsfiles2)
+ $(ETAGS) $(lisptagsfiles1) $(lisptagsfiles2)
+
+TAGS-LISP: $(lispsource)$(lisptagsfiles1) $(lispsource)$(lisptagsfiles2)
+ $(ETAGS) -o TAGS-LISP $(lispsource)$(lisptagsfiles1) $(lispsource)$(lisptagsfiles2)
+
.el.elc:
-$(emacs) -f batch-byte-compile $<
$(DONTCOMPILE:.el=.elc):
-$(DEL) $@
+# Compile all Lisp files, except those from DONTCOMPILE. This
+# compiles files unconditionally. All .elc files are made writable
+# before compilation in case we checked out read-only (CVS option -r).
+# Files MUST be compiled one by one. If we compile several files in a
+# row we can't make sure that the compilation environment is clean.
+# We also set the load-path of the Emacs used for compilation to the
+# current directory and its subdirectories, to make sure require's and
+# load's in the files being compiled find the right files.
+
+compile-files: subdirs.el doit
+ -for %f in ($(lisp) $(WINS)) do for %g in (%f\*.elc) do @attrib -r %g
+ for %f in ($(COMPILE_FIRST)) do $(emacs) -f batch-byte-compile %f
+ for %f in ($(lisp) $(WINS)) do for %g in (%f/*.el) do $(emacs) -f batch-byte-compile %f/%g
+
+# Backup compiled Lisp files in elc.tar.gz. If that file already
+# exists, make a backup of it.
+
+backup-compiled-files:
+ -mv $(lisp)/elc.tar.gz $(lisp)/elc.tar.gz~
+ -tar czf $(lisp)/elc.tar.gz $(lisp)/*.elc $(lisp)/*/*.elc
+
+# Compile Lisp files, but save old compiled files first.
+
+compile: backup-compiled-files compile-files
+
# Recompile all Lisp files which are newer than their .elc files.
# Note that this doesn't create .elc files. It only recompiles if an
# .elc is present.
-recompile:
+recompile: doit
$(emacs) -f batch-byte-recompile-directory .
+# Prepare a bootstrap in the lisp subdirectory. Build loaddefs.el,
+# because it's not sure it's up-to-date, and if it's not, that might
+# lead to errors during the bootstrap because something fails to
+# autoload as expected. Remove compiled Lisp files so that
+# bootstrap-emacs will be built from sources only.
+
+bootstrap-clean:
+ if exist $(EMACS) $(MAKE) $(MFLAGS) -f makefile.nt autoloads
+ -for %f in ($(lisp) $(WINS)) do for %g in (%f\*.elc) do @$(DEL) %g
+
+# Generate/update files for the bootstrap process.
+
+bootstrap: autoloads compile-files custom-deps
+
#
# Assuming INSTALL_DIR is defined, copy the elisp files to it
# Windows 95 makes this harder than it should be.
#
install:
- - mkdir $(INSTALL_DIR)\lisp
- - $(DEL) .\same-dir.tst
- - $(DEL) $(INSTALL_DIR)\lisp\same-dir.tst
- echo SameDirTest > $(INSTALL_DIR)\lisp\same-dir.tst
+ - mkdir $(INSTALL_DIR)\lisp
+ - $(DEL) .\same-dir.tst
+ - $(DEL) $(INSTALL_DIR)\lisp\same-dir.tst
+ echo SameDirTest > $(INSTALL_DIR)\lisp\same-dir.tst
!ifdef COPY_LISP_SOURCE
- if not exist .\same-dir.tst $(CP_DIR) . $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP_DIR) . $(INSTALL_DIR)\lisp
!else
- if not exist .\same-dir.tst $(CP_DIR) *.elc $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) cus-load.el $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) forms*.el $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) patcomp.el $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) subdirs.el $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) version.el $(INSTALL_DIR)\lisp
- if not exist .\same-dir.tst $(CP) mail\blessmail.el $(INSTALL_DIR)\lisp\mail
- if not exist .\same-dir.tst $(CP) mail\sc.el $(INSTALL_DIR)\lisp\mail
- if not exist .\same-dir.tst $(CP) play\bruce.el $(INSTALL_DIR)\lisp\play
- if not exist .\same-dir.tst $(CP) international\latin-*.el $(INSTALL_DIR)\lisp\international
- if not exist .\same-dir.tst $(CP) international\mule-conf.el $(INSTALL_DIR)\lisp\international
- - $(DEL) $(INSTALL_DIR)\lisp\same-dir.tst
+ if not exist .\same-dir.tst $(CP_DIR) *.elc $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) cus-load.el $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) forms*.el $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) patcomp.el $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) subdirs.el $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) version.el $(INSTALL_DIR)\lisp
+ if not exist .\same-dir.tst $(CP) mail\blessmail.el $(INSTALL_DIR)\lisp\mail
+ if not exist .\same-dir.tst $(CP) mail\sc.el $(INSTALL_DIR)\lisp\mail
+ if not exist .\same-dir.tst $(CP) play\bruce.el $(INSTALL_DIR)\lisp\play
+ if not exist .\same-dir.tst $(CP) international\latin-*.el $(INSTALL_DIR)\lisp\international
+ if not exist .\same-dir.tst $(CP) international\mule-conf.el $(INSTALL_DIR)\lisp\international
+ - $(DEL) $(INSTALL_DIR)\lisp\same-dir.tst
!endif
#
# Maintenance
#
-clean:; - $(DEL) *~ term\*~
- - $(DEL) *.orig *.rej *.crlf
- - $(DEL) emacs-lisp\*.orig emacs-lisp\*.rej emacs-lisp\*.crlf
- - $(DEL) emulation\*.orig emulation\*.rej emulation\*.crlf
- - $(DEL) gnus\*.orig gnus\*.rej gnus\*.crlf
- - $(DEL) international\*.orig international\*.rej international\*.crlf
- - $(DEL) language\*.orig language\*.rej language\*.crlf
- - $(DEL) mail\*.orig mail\*.rej mail\*.crlf
- - $(DEL) play\*.orig play\*.rej play\*.crlf
- - $(DEL) progmodes\*.orig progmodes\*.rej progmodes\*.crlf
- - $(DEL) term\*.orig term\*.rej term\*.crlf
- - $(DEL) textmodes\*.orig textmodes\*.rej textmodes\*.crlf
- - $(DEL_TREE) deleted
+clean:
+ - $(DEL) *~ term\*~
+ - $(DEL) *.orig *.rej *.crlf
+ - $(DEL) emacs-lisp\*.orig emacs-lisp\*.rej emacs-lisp\*.crlf
+ - $(DEL) emulation\*.orig emulation\*.rej emulation\*.crlf
+ - $(DEL) gnus\*.orig gnus\*.rej gnus\*.crlf
+ - $(DEL) international\*.orig international\*.rej international\*.crlf
+ - $(DEL) language\*.orig language\*.rej language\*.crlf
+ - $(DEL) mail\*.orig mail\*.rej mail\*.crlf
+ - $(DEL) play\*.orig play\*.rej play\*.crlf
+ - $(DEL) progmodes\*.orig progmodes\*.rej progmodes\*.crlf
+ - $(DEL) term\*.orig term\*.rej term\*.crlf
+ - $(DEL) textmodes\*.orig textmodes\*.rej textmodes\*.crlf
+ - $(DEL_TREE) deleted