Mercurial > emacs
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