Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files. =================================================================== RCS file: /ftp/cvs/cvsroot/src/Makefile,v rcsdiff: /ftp/cvs/cvsroot/src/Makefile,v: warning: Unknown phrases like `commitid ...;' are present. retrieving revision 1.118.2.2 retrieving revision 1.125 diff -u -p -r1.118.2.2 -r1.125 --- src/Makefile 2000/08/24 02:19:59 1.118.2.2 +++ src/Makefile 2001/06/10 13:15:29 1.125 @@ -1,4 +1,4 @@ -# $NetBSD: Makefile,v 1.118.2.2 2000/08/24 02:19:59 fredb Exp $ +# $NetBSD: Makefile,v 1.125 2001/06/10 13:15:29 mrg Exp $ # This is the top-level makefile for building NetBSD. For an outline of # how to build a snapshot or release, as well as other release engineering @@ -25,8 +25,13 @@ # anything in /usr/share. # NBUILDJOBS is the number of jobs to start in parallel during a # 'make build'. It defaults to 1. -# UPDATE will avoid a `make cleandir' at the start of `make build', -# as well as having the effects listed in /usr/share/mk/bsd.README. +# UPDATE, if defined, will avoid a `make cleandir' at the start of +# `make build', as well as having the effects listed in +# /usr/share/mk/bsd.README. +# NOCLEANDIR, if defined, will avoid a `make cleandir' at the start +# of the `make build'. +# NOINCLUDES will avoid the `make includes' usually done by `make build'. + # # Targets: # build: builds a full release of netbsd in DESTDIR. If BUILD_DONE is @@ -35,6 +40,23 @@ # into RELEASEDIR, in release(7) format. (See etc/Makefile for # more information on this.) # snapshot: a synonym for release. +# +# Sub targets of `make build,' in order: +# buildstartmsg: displays the start time of the build. +# beforeinstall: creates the distribution directories. +# do-force-domestic: check's that FORCE_DOMESTIC isn't set (deprecated.) +# do-share-mk: installs /usr/share/mk files. +# do-cleandir: clean's the tree. +# do-make-obj: create's object directories if required. +# do-check-egcs: check's that we have a modern enough compiler (deprecated.) +# do-make-includes: install include files. +# do-lib-csu: build & install startup object files. +# do-lib: build & install system libraries. +# do-gnu-lib: build & install gnu system libraries. +# do-dependall: builds & install the entire system. +# do-domestic: build & install the domestic tree (deprecated.) +# do-whatisdb: build & install the `whatis.db' man database. +# buildendmsg: displays the end time of the build. .include @@ -79,14 +101,26 @@ regression-tests: @(cd ${.CURDIR}/regress && ${MAKE} ${_M} regress) .endif -buildmsg: +buildstartmsg: @echo -n "Build started at: " @date +buildendmsg: + @echo -n "Build finished at: " + @date + +# If sharesrc is around, use its share/mk files to bootstrap until the +# mk files are installed (first step of make build). If installing to +# DESTDIR, don't bother, since the build will fail later on anyway. + beforeinstall: .ifndef NODISTRIBDIRS .ifndef DESTDIR +.if exists(share/mk) + (cd ${.CURDIR}/etc && ${MAKE} -m ${.CURDIR}/share/mk DESTDIR=/ distrib-dirs) +.else (cd ${.CURDIR}/etc && ${MAKE} DESTDIR=/ distrib-dirs) +.endif .else (cd ${.CURDIR}/etc && ${MAKE} distrib-dirs) .endif @@ -107,22 +141,48 @@ whatis.db: build: @echo "Build installed into ${DESTDIR}" .else -build: buildmsg beforeinstall +build: + @${MAKE} ${_M} buildstartmsg + @${MAKE} ${_M} beforeinstall + @${MAKE} ${_M} do-force-domestic + @${MAKE} ${_M} do-share-mk + @${MAKE} ${_M} do-cleandir + @${MAKE} ${_M} do-make-obj + @${MAKE} ${_M} do-check-egcs + @${MAKE} ${_M} do-make-includes + @${MAKE} ${_M} do-lib-csu + @${MAKE} ${_M} do-lib + @${MAKE} ${_M} do-gnu-lib + @${MAKE} ${_M} do-dependall + @${MAKE} ${_M} do-domestic + @${MAKE} ${_M} do-whatisdb + @${MAKE} ${_M} buildendmsg +.endif + +do-force-domestic: .if defined(FORCE_DOMESTIC) @echo '*** CAPUTE!' @echo ' The FORCE_DOMESTIC flag is not compatible with "make build".' @echo ' Please correct the problem and try again.' @false .endif + +do-share-mk: .if ${MKSHARE} != "no" (cd ${.CURDIR}/share/mk && ${MAKE} install) .endif + +do-cleandir: .if !defined(UPDATE) && !defined(NOCLEANDIR) ${MAKE} ${_J} ${_M} cleandir .endif + +do-make-obj: .if ${MKOBJDIRS} != "no" - ${MAKE} ${_M} obj + ${MAKE} ${_J} ${_M} obj .endif + +do-check-egcs: .if empty(HAVE_EGCS) .if defined(DESTDIR) @echo "*** CAPUTE!" @@ -135,26 +195,37 @@ build: buildmsg beforeinstall ${MAKE} ${_M} MKMAN=no install && ${MAKE} ${_M} cleandir) .endif .endif + +do-make-includes: .if !defined(NOINCLUDES) ${MAKE} ${_M} includes .endif + +do-lib-csu: (cd ${.CURDIR}/lib/csu && \ ${MAKE} ${_M} ${_J} MKSHARE=no dependall && \ ${MAKE} ${_M} MKSHARE=no install) + +do-lib: (cd ${.CURDIR}/lib && \ ${MAKE} ${_M} ${_J} MKSHARE=no dependall && \ ${MAKE} ${_M} MKSHARE=no install) + +do-gnu-lib: (cd ${.CURDIR}/gnu/lib && \ ${MAKE} ${_M} ${_J} MKSHARE=no dependall && \ ${MAKE} ${_M} MKSHARE=no install) + +do-dependall: ${MAKE} ${_M} ${_J} dependall && ${MAKE} ${_M} _BUILD= install + +do-domestic: .if defined(DOMESTIC) && !defined(EXPORTABLE_SYSTEM) (cd ${.CURDIR}/${DOMESTIC} && ${MAKE} ${_M} ${_J} _SLAVE_BUILD= build) .endif + +do-whatisdb: ${MAKE} ${_M} whatis.db - @echo -n "Build finished at: " - @date -.endif release snapshot: build (cd ${.CURDIR}/etc && ${MAKE} ${_M} INSTALL_DONE=1 release)