# HG changeset patch # User Eli Zaretskii # Date 1226763430 0 # Node ID 322d1a27ea4a9716d5c67ccd7917893ec6f72049 # Parent 8aeb40d333180e5868e2ea97c602ff7b8d52b92a Make bootstrap work again: (boot): New variable. (src): Pass $(boot) to sub-Make. Remove src/bootlisp. If src/bootlisp exists after running Make, run Make in `lisp' as well. (clean, mostlyclean): Remove bogus repeated clean in the top-level directory. (info, bootstrap-clean): New targets. (bootstrap): Depend only on bootstrap-clean. Commands modified to be equivalent to top-level Makefile.in. (bootfast, bootstrap-lisp-1, bootstrap-lisp, bootstrap-src) (bootstrap-clean-before, bootstrap-clean-after): Targets deleted. (clean, mostlyclean, distclean, maintainer-clean, extraclean): Don't recurse into lwlib and oldXMenu. diff -r 8aeb40d33318 -r 322d1a27ea4a msdos/mainmake.v2 --- a/msdos/mainmake.v2 Sat Nov 15 10:36:18 2008 +0000 +++ b/msdos/mainmake.v2 Sat Nov 15 15:37:10 2008 +0000 @@ -67,16 +67,36 @@ # Find out which version of Emacs this is. version := ${shell sed -n -e '/(defconst emacs-version/s/^[^"]*\("[^"]*"\).*/\1/p' lisp/version.el} -all: maybe_bootstrap lib-src src emacs lispref lispintro +# Do we need to bootstrap? +boot := +ifeq ($(wildcard src/b-emacs.exe),) +boot := b-emacs.exe +endif + +# Subdirectories to run Make. `lisp' is not included because the +# compiled lisp files are part of the distribution. (If we are +# bootstrapping, the src target will run Make in `lisp' as well.) +# leim is not included because it is part of the src target. +all: lib-src src emacs lispref lispintro lib-src: FRC cd lib-src $(MAKE) top_srcdir=${top_srcdir} version=${version} cd .. +# Pass to src/Makefile.in an additional BOOTSTRAPEMACS variable which +# is either set to b-emacs.exe (in case bootstrap-emacs has not been +# constructed yet) or the empty string (otherwise). +# src/Makefile.in uses it to implement conditional dependencies, so that +# files that need bootstrap-emacs to be built do not additionally need +# to be kept fresher than b-emacs.exe. Otherwise changing a single +# file src/foo.c forces dumping a new bootstrap-emacs, then re-byte-compiling +# all preloaded elisp files, and only then dump the actual src/emacs, which +# is not wrong, but is overkill in 99.99% of the cases. src: FRC cd src - $(MAKE) top_srcdir=${top_srcdir} BOOTSTRAPEMACS="" + rm -f bootlisp + $(MAKE) top_srcdir=${top_srcdir} BOOTSTRAPEMACS="${boot}" djecho -s '/-geometry/s,^.*,set environment HOME $(top_srcdir),' \ '/environment *TERM/s/^.*/set environment TERM internal/' \ '/x_error_quitter/s/^.*/set environment NAME root/' >gdb.sed @@ -88,8 +108,11 @@ update gdb.tmp gdb.ini rm -f gdb.tmp gdb.sed cd .. + if exist src\bootlisp redir $(MAKE) -C lisp top_srcdir=${top_srcdir} if exist leim\Makefile redir $(MAKE) -C leim top_srcdir=${top_srcdir} +info: emacs lispref lispintro + emacs lispref lispintro: FRC cd doc/$@ $(MAKE) top_srcdir=${top_srcdir} info @@ -139,9 +162,6 @@ cd src $(MAKE) $(MFLAGS) $@ cd .. - cd oldxmenu - -$(MAKE) $(MFLAGS) $@ - cd .. cd doc cd emacs -$(MAKE) $(MFLAGS) $@ @@ -159,16 +179,13 @@ cd leim if exist Makefile redir $(MAKE) $(MFLAGS) $@ cd .. - -$(MAKE) $(MFLAGS) $@ top_distclean=rm -f Makefile */Makefile src/_gdbinit distclean maintainer-clean: FRC cd src $(MAKE) $(MFLAGS) $@ - cd .. - cd oldxmenu - -$(MAKE) $(MFLAGS) $@ + if exist bootlisp rm -f bootlisp cd .. cd lib-src $(MAKE) $(MFLAGS) $@ @@ -199,9 +216,6 @@ cd src $(MAKE) $(MFLAGS) $@ cd .. - cd oldxmenu - -$(MAKE) $(MFLAGS) $@ - cd .. cd lib-src $(MAKE) $(MFLAGS) $@ cd .. @@ -228,40 +242,36 @@ ${top_distclean} -rm -f *~ #* -.PHONY: bootstrap bootstrap-lisp-1 bootstrap-src bootstrap-lisp bootstrap-clean -.PHONY: maybe_bootstrap bootfast - -maybe_bootstrap: - @if not exist lisp\abbrev.elc djecho \ - "Some *.elc files are missing. You should do a `make bootstrap'." - @if not exist lisp\abbrev.elc redir -e /dev/null -oe redir fail-this-make.exe - -bootstrap: bootstrap-clean-before bootstrap-lisp-1 bootstrap-src bootstrap-lisp bootstrap-clean-after all info - cd lisp; $(MAKE) $(MFLAGS) bootstrap-after; cd .. - -bootfast: bootstrap-clean-before bootstrap-src bootstrap-lisp bootstrap-clean-after all info - cd lisp; $(MAKE) $(MFLAGS) bootstrap-after; cd .. - -bootstrap-lisp-1: - cd lisp; $(MAKE) $(MFLAGS) bootstrap-clean; cd .. +.PHONY: bootstrap -bootstrap-lisp: - cd lisp; $(MAKE) $(MFLAGS) bootstrap EMACS=${top_srcdir}/src/b-emacs.exe lisp=${top_srcdir}/lisp; cd .. - -bootstrap-src: - cd src; $(MAKE) $(MFLAGS) bootstrap; cd .. +bootstrap-clean: FRC + cd src + $(MAKE) $(MFLAGS) $@ + cd .. + cd lib-src + $(MAKE) $(MFLAGS) maintainer-clean + cd .. + cd doc + cd emacs + -$(MAKE) $(MFLAGS) maintainer-clean + cd ../misc + -$(MAKE) $(MFLAGS) maintainer-clean + cd ../lispref + -$(MAKE) $(MFLAGS) maintainer-clean + cd ../lispintro + -$(MAKE) $(MFLAGS) maintainer-clean + cd .. + cd .. + cd leim + $(MAKE) $(MFLAGS) maintainer-clean + cd .. + cd lisp + $(MAKE) $(MFLAGS) bootstrap-clean + cd .. + ${top_bootclean} -### Used for `bootstrap' to avoid deleting existing dumped Emacs executables. -bootstrap-clean-before: FRC - cd src; $(MAKE) $(MFLAGS) mostlyclean; cd .. - cd lib-src; $(MAKE) $(MFLAGS) clean; cd .. - -cd doc/emacs; $(MAKE) $(MFLAGS) clean; cd .. - -cd misc; $(MAKE) $(MFLAGS) clean; cd .. - -cd lispref; $(MAKE) $(MFLAGS) clean; cd .. - -cd lispintro; $(MAKE) $(MFLAGS) clean; cd ..; cd .. - cd leim; if exist Makefile redir $(MAKE) $(MFLAGS) clean; cd .. - -bootstrap-clean-after: - cd src; $(MAKE) $(MFLAGS) mostlyclean; cd .. +bootstrap: bootstrap-clean FRC + config msdos + $(MAKE) $(MFLAGS) info all # arch-tag: 6fee5130-4c53-46c6-93d3-d0ea852298b9