changeset 99577:322d1a27ea4a

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.
author Eli Zaretskii <eliz@gnu.org>
date Sat, 15 Nov 2008 15:37:10 +0000
parents 8aeb40d33318
children 666b833738d0
files msdos/mainmake.v2
diffstat 1 files changed, 55 insertions(+), 45 deletions(-) [+]
line wrap: on
line diff
--- 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