Makefile revision 1.176
1#	$NetBSD: Makefile,v 1.176 2002/06/19 00:17:11 lukem Exp $
2
3# This is the top-level makefile for building NetBSD. For an outline of
4# how to build a snapshot or release, as well as other release engineering
5# information, see http://www.netbsd.org/developers/releng/index.html
6#
7# Not everything you can set or do is documented in this makefile. In
8# particular, you should review the files in /usr/share/mk (especially
9# bsd.README) for general information on building programs and writing
10# Makefiles within this structure, and see the comments in src/etc/Makefile
11# for further information on installation and release set options.
12#
13# Variables listed below can be set on the make command line (highest
14# priority), in /etc/mk.conf (middle priority), or in the environment
15# (lowest priority).
16#
17# Variables:
18#   DESTDIR is the target directory for installation of the compiled
19#	software. It defaults to /. Note that programs are built against
20#	libraries installed in DESTDIR.
21#   MKMAN, if set to `no', will prevent building of manual pages.
22#   MKOBJDIRS, if not set to `no', will build object directories at 
23#	an appropriate point in a build.
24#   MKSHARE, if set to `no', will prevent building and installing
25#	anything in /usr/share.
26#   UPDATE, if defined, will avoid a `make cleandir' at the start of
27#     `make build', as well as having the effects listed in
28#     /usr/share/mk/bsd.README.
29#   NOCLEANDIR, if defined, will avoid a `make cleandir' at the start
30#     of the `make build'.
31#   NOINCLUDES will avoid the `make includes' usually done by `make build'.
32#
33# Targets:
34#   build:
35#	Builds a full release of NetBSD in DESTDIR.  If BUILD_DONE is
36#	set, this is an empty target.
37#   release:
38#	Does a `make build,' and then tars up the DESTDIR files
39#	into RELEASEDIR, in release(7) format. (See etc/Makefile for
40#	more information on this.)
41#   regression-tests:
42#	Runs the regression tests in "regress" on this host.
43#
44# Targets invoked by `make build,' in order:
45#   cleandir:        cleans the tree.
46#   obj:             creates object directories.
47#   do-tools:        builds host toolchain.
48#   do-distrib-dirs: creates the distribution directories.
49#   includes:        installs include files.
50#   do-lib-csu:      builds and installs prerequisites from lib/csu.
51#   do-lib:          builds and installs prerequisites from lib.
52#   do-gnu-lib:      builds and installs prerequisites from gnu/lib.
53#   do-build:        builds and installs the entire system.
54
55.if ${.MAKEFLAGS:M${.CURDIR}/share/mk} == ""
56.MAKEFLAGS: -m ${.CURDIR}/share/mk
57.endif
58
59# If _SRC_TOP_OBJ_ gets set here, we will end up with a directory that may
60# not be the top level objdir, because "make obj" can happen in the *middle*
61# of "make build" (long after <bsd.own.mk> is calculated it).  So, pre-set
62# _SRC_TOP_OBJ_ here so it will not be added to ${.MAKEOVERRIDES}.
63_SRC_TOP_OBJ_=
64
65.include <bsd.own.mk>
66
67# Sanity check: make sure that "make build" is not invoked simultaneously
68# with a standard recursive target.
69
70.if make(build) || make(release) || make(snapshot)
71.for targ in ${TARGETS:Nobj:Ncleandir}
72.if make(${targ}) && !target(.BEGIN)
73.BEGIN:
74	@echo 'BUILD ABORTED: "make build" and "make ${targ}" are mutually exclusive.'
75	@false
76.endif
77.endfor
78.endif
79
80_SUBDIR=	tools lib include gnu bin games libexec sbin usr.bin
81_SUBDIR+=	usr.sbin share sys etc distrib regress
82
83# Weed out directories that don't exist.
84
85.for dir in ${_SUBDIR}
86.if exists(${dir}/Makefile) && (${BUILD_${dir}:Uyes} != "no")
87SUBDIR+=	${dir}
88.endif
89.endfor
90
91.if exists(regress)
92regression-tests:
93	@echo Running regression tests...
94	@(cd ${.CURDIR}/regress && ${MAKE} regress)
95.endif
96
97afterinstall:
98.if ${MKMAN} != "no"
99	(cd ${.CURDIR}/share/man && ${MAKE} makedb)
100.endif
101.if defined(UNPRIVED) && (${MKINFO} != "no")
102	(cd ${.CURDIR}/gnu/usr.bin/texinfo/install-info && ${MAKE} infodir-meta)
103.endif
104.if !defined(DESTDIR) || ${DESTDIR} == "" || ${DESTDIR} == "/"
105	(${MAKE} postinstall-check)
106.endif
107
108postinstall-check:
109	@echo "   === Post installation checks ==="
110	sh ${.CURDIR}/etc/postinstall -s ${.CURDIR} -d ${DESTDIR}/ check
111	@echo "   ================================"
112
113postinstall-fix: .NOTMAIN
114	@echo "   === Post installation fixes ==="
115	sh ${.CURDIR}/etc/postinstall -s ${.CURDIR} -d ${DESTDIR}/ fix
116	@echo "   ================================"
117
118
119# Targets (in order!) called by "make build".
120
121BUILDTARGETS+=	check-tools
122.if !defined(UPDATE) && !defined(NOCLEANDIR)
123BUILDTARGETS+=	cleandir
124.endif
125.if ${MKOBJDIRS} != "no"
126BUILDTARGETS+=	obj
127.endif
128.if ${USETOOLS} == "yes"
129BUILDTARGETS+=	do-tools
130.endif
131.if !defined(NODISTRIBDIRS)
132BUILDTARGETS+=	do-distrib-dirs
133.endif
134.if !defined(NOINCLUDES)
135BUILDTARGETS+=	includes
136.endif
137BUILDTARGETS+=	do-lib-csu do-lib do-gnu-lib do-build
138
139# Enforce proper ordering of some rules.
140
141.ORDER:		${BUILDTARGETS}
142includes-lib:	includes-include includes-sys
143includes-gnu:	includes-lib
144
145# Build the system and install into DESTDIR.
146
147build:
148.if defined(BUILD_DONE)
149	@echo "Build already installed into ${DESTDIR}"
150.else
151	@printf "Build started at: " && date
152.for tgt in ${BUILDTARGETS}
153	@(cd ${.CURDIR} && ${MAKE} ${tgt})
154.endfor
155	@printf "Build finished at: " && date
156.endif
157
158# Build a full distribution, but not a release (i.e. no sets into
159# ${RELEASEDIR}).
160
161distribution: build
162	(cd ${.CURDIR}/etc && ${MAKE} INSTALL_DONE=1 distribution)
163
164# Build a release or snapshot (implies "make build").
165
166release snapshot: build
167	(cd ${.CURDIR}/etc && ${MAKE} INSTALL_DONE=1 release)
168
169# Special components of the "make build" process.
170
171check-tools:
172.if defined(USE_NEW_TOOLCHAIN) && (${USE_NEW_TOOLCHAIN} != "nowarn")
173	@echo '*** WARNING:  Building on MACHINE=${MACHINE} with USE_NEW_TOOLCHAIN.'
174	@echo '*** This platform is not yet verified to work with the new toolchain,'
175	@echo '*** and may result in a failed build or corrupt binaries!'
176.endif
177.if defined(NBUILDJOBS)
178	@echo '*** WARNING: NBUILDJOBS is obsolete; use -j directly instead!'
179.endif
180
181do-distrib-dirs:
182.if !defined(DESTDIR) || ${DESTDIR} == ""
183	(cd ${.CURDIR}/etc && ${MAKE} DESTDIR=/ distrib-dirs)
184.else
185	(cd ${.CURDIR}/etc && ${MAKE} DESTDIR=${DESTDIR} distrib-dirs)
186.endif
187
188.for dir in tools lib/csu lib gnu/lib
189do-${dir:S/\//-/}:
190.for targ in dependall install
191	(cd ${.CURDIR}/${dir} && ${MAKE} ${targ})
192.endfor
193.endfor
194
195do-build:
196.for targ in dependall install
197	(cd ${.CURDIR} && ${MAKE} ${targ} BUILD_tools=no BUILD_lib=no)
198.endfor
199
200# Speedup stubs for some subtrees that don't need to run these rules.
201# (Tells <bsd.subdir.mk> not to recurse for them.)
202
203.for dir in bin etc distrib games libexec regress sbin usr.sbin tools
204includes-${dir}:
205	@true
206.endfor
207.for dir in etc distrib regress
208install-${dir}:
209	@true
210.endfor
211
212# XXX this needs to change when distrib Makefiles are recursion compliant
213dependall-distrib depend-distrib all-distrib:
214	@true
215
216.include <bsd.obj.mk>
217.include <bsd.subdir.mk>
218
219build-docs: ${.CURDIR}/BUILDING
220${.CURDIR}/BUILDING: BUILDING.mdoc
221	groff -mdoc -Tascii -P-b -P-u -P-o $> >$@
222