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.59 retrieving revision 1.144 diff -u -p -r1.59 -r1.144 --- src/Makefile 1998/07/24 16:51:33 1.59 +++ src/Makefile 2001/10/29 19:48:35 1.144 @@ -1,93 +1,189 @@ -# $NetBSD: Makefile,v 1.59 1998/07/24 16:51:33 tv Exp $ +# $NetBSD: Makefile,v 1.144 2001/10/29 19:48:35 tv Exp $ -.include # for configuration variables. - -HAVE_GCC28!= ${CXX} --version | egrep "^(2\.8|egcs)" ; echo - -# NOTE THAT etc *DOES NOT* BELONG IN THE LIST BELOW +# 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 +# information, see http://www.netbsd.org/developers/releng/index.html +# +# Not everything you can set or do is documented in this makefile. In +# particular, you should review the files in /usr/share/mk (especially +# bsd.README) for general information on building programs and writing +# Makefiles within this structure, and see the comments in src/etc/Makefile +# for further information on installation and release set options. +# +# Variables listed below can be set on the make command line (highest +# priority), in /etc/mk.conf (middle priority), or in the environment +# (lowest priority). +# +# Variables: +# DESTDIR is the target directory for installation of the compiled +# software. It defaults to /. Note that programs are built against +# libraries installed in DESTDIR. +# MKMAN, if set to `no', will prevent building of manual pages. +# MKOBJDIRS, if not set to `no', will build object directories at +# an appropriate point in a build. +# MKSHARE, if set to `no', will prevent building and installing +# anything in /usr/share. +# NBUILDJOBS is the number of jobs to start in parallel during a +# `make build'. It defaults to 1. +# 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 +# set, this is an empty target. +# release: +# Does a `make build,' and then tars up the DESTDIR files +# into RELEASEDIR, in release(7) format. (See etc/Makefile for +# more information on this.) +# regression-tests: +# Runs the regression tests in "regress" on this host. +# +# Targets invoked by `make build,' in order: +# obj: creates object directories. +# cleandir: cleans the tree. +# do-make-tools: builds host toolchain. +# do-distrib-dirs: creates the distribution directories. +# includes: installs include files. +# do-lib-csu: builds and installs prerequisites from lib/csu. +# do-lib: builds and installs prerequisites from lib. +# do-gnu-lib: builds and installs prerequisites from gnu/lib. +# do-build: builds and installs the entire system. + +.include "${.CURDIR}/share/mk/bsd.own.mk" + +# Sanity check: make sure that "make build" is not invoked simultaneously +# with a standard recursive target. + +.if make(build) || make(release) || make(snapshot) +.for targ in ${TARGETS:Nobj:Ncleandir} +.if make(${targ}) && !target(.BEGIN) +.BEGIN: + @echo 'BUILD ABORTED: "make build" and "make ${targ}" are mutually exclusive.' + @false +.endif +.endfor +.endif + +.if defined(NBUILDJOBS) +_J= -j${NBUILDJOBS} +.endif + +.if ${USETOOLS} == "yes" +_SUBDIR+= tools +.endif +_SUBDIR+= lib include gnu bin games libexec sbin usr.bin \ + usr.sbin share sys etc distrib regress + +# Weed out directories that don't exist. + +.for dir in ${_SUBDIR} +.if exists(${dir}/Makefile) +SUBDIR+= ${dir} +.endif +.endfor -SUBDIR+= lib include bin libexec sbin usr.bin usr.sbin share sys +.if exists(regress) +regression-tests: + @echo Running regression tests... + @cd ${.CURDIR}/regress && ${MAKE} ${_M} regress +.endif -.if exists(games) -SUBDIR+= games +.if ${MKMAN} != "no" +afterinstall: whatis.db +whatis.db: + cd ${.CURDIR}/share/man && ${MAKE} ${_M} makedb .endif -SUBDIR+= gnu -# This is needed for libstdc++ and gen-params. -includes-gnu: includes-include includes-sys +# Targets (in order!) called by "make build". -.if exists(domestic) && !defined(EXPORTABLE_SYSTEM) -SUBDIR+= domestic +.if ${MKOBJDIRS:Uno} != "no" +BUILDTARGETS+= obj .endif - -.if exists(regress) -.ifmake !(install) -SUBDIR+= regress +.if !defined(UPDATE) && !defined(NOCLEANDIR) +BUILDTARGETS+= cleandir .endif - -regression-tests: - @echo Running regression tests... - @(cd ${.CURDIR}/regress && ${MAKE} regress) +.if ${USETOOLS} == "yes" +BUILDTARGETS+= do-make-tools .endif - -beforeinstall: -.ifmake build - @echo -n "Build started at: " - @date +.if !defined(NODISTRIBDIRS) +BUILDTARGETS+= do-distrib-dirs .endif -.ifndef DESTDIR - (cd ${.CURDIR}/etc && ${MAKE} DESTDIR=/ distrib-dirs) -.else - (cd ${.CURDIR}/etc && ${MAKE} distrib-dirs) +.if !defined(NOINCLUDES) +BUILDTARGETS+= includes .endif +BUILDTARGETS+= do-lib-csu do-lib do-gnu-lib do-build + +# Enforce proper ordering of some rules. + +.ORDER: ${BUILDTARGETS} +includes-lib: includes-include includes-sys +includes-gnu: includes-lib + +# Build the system and install into DESTDIR. -afterinstall: -.ifndef NOMAN - (cd ${.CURDIR}/share/man && ${MAKE} makedb) -.endif - -build: beforeinstall - (cd ${.CURDIR}/share/mk && ${MAKE} install) - (cd ${.CURDIR}/share/tmac && ${MAKE} && ${MAKE} install) -.if !defined(UPDATE) - ${MAKE} cleandir -.endif - ${MAKE} includes - (cd ${.CURDIR}/lib/csu && ${MAKE} depend && ${MAKE} && ${MAKE} install) - (cd ${.CURDIR}/lib && ${MAKE} depend && ${MAKE} && ${MAKE} install) - (cd ${.CURDIR}/gnu/lib && ${MAKE} depend && ${MAKE} && ${MAKE} install) - (cd ${.CURDIR}/gnu/usr.bin/gcc/libgcc && ${MAKE} depend && ${MAKE} && ${MAKE} install) -.if exists(domestic) && !defined(EXPORTABLE_SYSTEM) -# libtelnet depends on libdes and libkrb. libkrb depends on -# libcom_err. -.if exists(domestic/lib/libdes) - (cd ${.CURDIR}/domestic/lib/libdes && \ - ${MAKE} depend && ${MAKE} && ${MAKE} install) -.endif -.if exists(domestic/lib/libcom_err) - (cd ${.CURDIR}/domestic/lib/libcom_err && \ - ${MAKE} depend && ${MAKE} && ${MAKE} install) -.endif -.if exists(domestic/lib/libkrb) - (cd ${.CURDIR}/domestic/lib/libkrb && \ - ${MAKE} depend && ${MAKE} && ${MAKE} install) -.endif - (cd ${.CURDIR}/domestic/lib/ && ${MAKE} depend && ${MAKE} && \ - ${MAKE} install) -.endif - ${MAKE} depend && ${MAKE} && ${MAKE} install -.if defined(USE_EGCS) -.if defined(DESTDIR) && (${HAVE_GCC28} == "") - @echo '***** WARNING ***** Your system compiler is not GCC 2.8 or higher,' - @echo 'and you have built a distribution with GCC 2.8 and DESTDIR set.' - @echo 'You will need to rebuild libgcc from gnu/usr.bin/egcs/libgcc' - @echo 'in order to have full C++ support in the binary set.' +build: +.if defined(BUILD_DONE) + @echo "Build already installed into ${DESTDIR}" .else - (cd ${.CURDIR}/gnu/usr.bin/egcs/libgcc &&\ - ${MAKE} depend && ${MAKE} && ${MAKE} install) -.endif # DESTDIR && !HAVE_GCC28 -.endif # USE_EGCS - @echo -n "Build finished at: " - @date + @echo -n "Build started at: " && date + @${MAKE} ${_J} ${_M} ${BUILDTARGETS} + @echo -n "Build finished at: " && date +.endif + +# Build a release or snapshot (implies "make build"). + +release snapshot: build + cd ${.CURDIR}/etc && ${MAKE} ${_M} INSTALL_DONE=1 release + +# Special components of the "make build" process. + +do-make-tools: + cd ${.CURDIR}/tools && ${MAKE} ${_M} build + +do-distrib-dirs: + cd ${.CURDIR}/etc && ${MAKE} ${_M} DESTDIR=${DESTDIR} distrib-dirs + +.for dir in lib/csu lib gnu/lib +do-${dir:S/\//-/}: +.for targ in dependall install + cd ${.CURDIR}/${dir} && \ + ${MAKE} ${_M} ${_J} MKSHARE=no MKLINT=no ${targ} +.endfor +.endfor + +do-build: + ${MAKE} ${_M} ${_J} dependall + ${MAKE} ${_M} ${_J} install + +# Speedup stubs for some subtrees that don't need to run these rules. +# (Tells not to recurse for them.) + +includes-bin includes-games includes-libexec includes-regress \ +includes-sbin includes-usr.sbin includes-tools \ +dependall-tools depend-tools all-tools install-tools install-regress \ +dependall-distrib depend-distrib all-distrib install-distrib includes-distrib: + @true + +.include "${.CURDIR}/share/mk/bsd.subdir.mk" + +_M:= -m ${.CURDIR}/share/mk + +# Rules for building the BUILDING.* documentation files. + +build-docs: ${.CURDIR}/BUILDING.txt ${.CURDIR}/BUILDING.html + +.SUFFIXES: .mdoc .html .txt + +.mdoc.html: ${.CURDIR}/Makefile + groff -mdoc2html -Tlatin1 -P-b -P-u -P-o -ww -mtty-char $< >$@ -.include +# The awk expression changes line endings from LF to CR-LF to make +# this readable on many more platforms than just Un*x. +.mdoc.txt: ${.CURDIR}/Makefile + groff -mdoc -Tascii -P-b -P-u -P-o $< | \ + awk 'BEGIN{ORS="\r\n"}{print}' >$@