X-Git-Url: http://git.hcoop.net/bpt/emacs.git/blobdiff_plain/ff0cdfb99b9a69f0cbb642748b5a97ac108351d3..37860cafd5acdc2348675f2e9bc1a0934a55f30d:/msdos/mainmake.v2 diff --git a/msdos/mainmake.v2 b/msdos/mainmake.v2 index 5497e45b1b..5486cf43ff 100644 --- a/msdos/mainmake.v2 +++ b/msdos/mainmake.v2 @@ -1,7 +1,7 @@ # Top-level Makefile for Emacs under MS-DOS/DJGPP v2.0 or higher. -*-makefile-*- # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +# 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. # This file is part of GNU Emacs. @@ -67,33 +67,64 @@ top_srcdir := $(subst \,/,$(shell cd)) # 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 man lispref lispintro +# Q: Do we need to bootstrap? +# A: Only if we find admin/admin.el, i.e. we are building out of CVS, +# and src/b-emacs.exe does not exist. This avoids building a +# bootstrap-emacs and recompiling Lisp files when building a +# pretest/release tarball. +boot := +ifneq ($(wildcard admin/admin.el),) +ifeq ($(wildcard src/b-emacs.exe),) +boot := b-emacs.exe +endif +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 misc 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} + $(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 + >gdb.sed sed -f gdb.sed _gdbinit >gdb.tmp djecho -a gdb.tmp -s 'set environment USER root' \ + 'set environment NAME root' \ + 'set environment USERNAME root' \ 'set environment EMACSPATH $(top_srcdir)/bin' \ 'set environment SHELL $(subst \,/,$(COMSPEC))' \ 'set environment PATH $(subst \,/,$(PATH))' update gdb.tmp gdb.ini rm -f gdb.tmp gdb.sed cd .. + if exist src\bootlisp redir $(MAKE) -C lisp top_srcdir=${top_srcdir} + rm -f src/bootlisp if exist leim\Makefile redir $(MAKE) -C leim top_srcdir=${top_srcdir} -man lispref lispintro: FRC - cd $@ +info: emacs misc lispref lispintro + +emacs misc lispref lispintro: FRC + cd doc/$@ $(MAKE) top_srcdir=${top_srcdir} info - cd .. + cd ../.. install: all if not exist bin\nul md bin @@ -103,8 +134,6 @@ install: all if exist fns.el update fns.el ../bin/fns.el cd .. cd src - stubify emacs - stubedit emacs.exe minstack=512k mv -f emacs.exe ../bin/ cd .. djecho -s "(if (fboundp 'normal-top-level-add-subdirs-to-load-path)" \ @@ -141,10 +170,11 @@ clean mostlyclean: cd src $(MAKE) $(MFLAGS) $@ cd .. - cd oldxmenu + cd doc + cd emacs -$(MAKE) $(MFLAGS) $@ cd .. - cd man + cd misc -$(MAKE) $(MFLAGS) $@ cd .. cd lispref @@ -153,24 +183,26 @@ clean mostlyclean: cd lispintro -$(MAKE) $(MFLAGS) $@ cd .. + cd .. 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) $@ cd .. - cd man + cd doc + cd emacs + -$(MAKE) $(MFLAGS) $@ + cd .. + cd misc -$(MAKE) $(MFLAGS) $@ cd .. cd lispref @@ -179,6 +211,7 @@ distclean maintainer-clean: FRC cd lispintro -$(MAKE) $(MFLAGS) $@ cd .. + cd .. cd leim if exist Makefile redir $(MAKE) $(MFLAGS) $@ cd .. @@ -191,13 +224,14 @@ extraclean: cd src $(MAKE) $(MFLAGS) $@ cd .. - cd oldxmenu - -$(MAKE) $(MFLAGS) $@ - cd .. cd lib-src $(MAKE) $(MFLAGS) $@ cd .. - cd man + cd doc + cd emacs + -$(MAKE) $(MFLAGS) $@ + cd .. + cd misc -$(MAKE) $(MFLAGS) $@ cd .. cd lispref @@ -206,6 +240,7 @@ extraclean: cd lispintro -$(MAKE) $(MFLAGS) $@ cd .. + cd .. cd leim if exist Makefile redir $(MAKE) $(MFLAGS) $@ cd .. @@ -215,39 +250,36 @@ extraclean: ${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 +.PHONY: bootstrap -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 .. - -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 .. - -### 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 man; $(MAKE) $(MFLAGS) clean; cd .. - -cd lispref; $(MAKE) $(MFLAGS) clean; cd .. - -cd lispintro; $(MAKE) $(MFLAGS) clean; cd .. - cd leim; if exist Makefile redir $(MAKE) $(MFLAGS) clean; 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} -bootstrap-clean-after: - cd src; $(MAKE) $(MFLAGS) mostlyclean; cd .. +bootstrap: bootstrap-clean FRC + command.com /e:2048 /c config msdos + $(MAKE) $(MFLAGS) info all # arch-tag: 6fee5130-4c53-46c6-93d3-d0ea852298b9