[BACK]Return to Makefile CVS log [TXT][DIR] Up to [cvs.NetBSD.org] / src

Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.

Diff for /src/Makefile between version 1.94 and 1.146

version 1.94, 1999/03/10 19:18:59 version 1.146, 2001/10/31 01:20:09
Line 1 
Line 1 
 #       $NetBSD$  #       $NetBSD$
 .include <bsd.own.mk>                   # for configuration variables.  # 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
 # Configurations variables (can be set either in /etc/mk.conf or  # information, see http://www.netbsd.org/developers/releng/index.html
 # as environement variable  #
 # NBUILDJOBS:   the number of jobs to start in parallel in a 'make build'.  # Not everything you can set or do is documented in this makefile. In
 #               defaults to 1  # particular, you should review the files in /usr/share/mk (especially
 # MKMAN:        if set to no, don't build and install man pages  # bsd.README) for general information on building programs and writing
 # MKSHARE:      if set to no, don't build or install /usr/share stuffs  # Makefiles within this structure, and see the comments in src/etc/Makefile
 # UPDATE:       if set to 1, don't do a 'make cleandir' before compile  # for further information on installation and release set options.
 # DESTDIR:      The target directory for installation (default to '/',  #
 #               which mean the current system is updated).  # Variables listed below can be set on the make command line (highest
   # priority), in /etc/mk.conf (middle priority), or in the environment
 HAVE_GCC28!=    ${CXX} --version | egrep "^(2\.8|egcs)" ; echo  # (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.
   .if ${.MAKEFLAGS:M${.CURDIR}/share/mk} == ""
   .MAKEFLAGS: -m ${.CURDIR}/share/mk
   .include <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)
           @echo 'BUILD ABORTED: "make build" and "make ${targ}" are mutually exclusive.'
 .if defined(NBUILDJOBS)  .if defined(NBUILDJOBS)
 _J= -j${NBUILDJOBS}  _J=             -j${NBUILDJOBS}
 .endif  .endif
 # NOTE THAT etc *DOES NOT* BELONG IN THE LIST BELOW  _SUBDIR=        tools lib include gnu bin games libexec sbin usr.bin \
                   usr.sbin share sys etc distrib regress
 SUBDIR+= lib include bin libexec sbin usr.bin usr.sbin share sys  # Weed out directories that don't exist.
 .if exists(games)  .for dir in ${_SUBDIR}
 SUBDIR+= games  .if exists(${dir}/Makefile)
 .endif  SUBDIR+=        ${dir}
 SUBDIR+= gnu  
 # This is needed for libstdc++ and gen-params.  
 includes-gnu: includes-include includes-sys  
 # Descend into the domestic tree if it exists AND  
 #  1) the target is clean, cleandir, or obj, OR  
 #  2) the the target is install or includes AND  
 #    NOT compiling only "exportable" code AND  
 #    doing it as part of installing a distribution.  
 # NOTE:  due to the use of the make(foo) construct here, using the  
 # clean, cleandir, and obj targets on the command line in conjunction  
 # with any other target may produce unexpected results.  
 .if exists(domestic) && \  
     (make(clean) || make(cleandir) || make(obj) || \  
     ((make(includes) || make(install)) && \  
     !defined(EXPORTABLE_SYSTEM) && defined(_DISTRIB)))  
 SUBDIR+= domestic  
 .endif  .endif
 .if exists(regress)  .if exists(regress)
 .ifmake !(install)  
 SUBDIR+= regress  
 regression-tests:  regression-tests:
         @echo Running regression tests...          @echo Running regression tests...
         @(cd ${.CURDIR}/regress && ${MAKE} regress)          @cd ${.CURDIR}/regress && ${MAKE} regress
 .endif  .endif
 beforeinstall:  .if ${MKMAN} != "no"
 .ifmake build  afterinstall: whatis.db
         @echo -n "Build started at: "  whatis.db:
         @date          cd ${.CURDIR}/share/man && ${MAKE} makedb
 .ifndef DESTDIR  
         (cd ${.CURDIR}/etc && ${MAKE} DESTDIR=/ distrib-dirs)  
         (cd ${.CURDIR}/etc && ${MAKE} distrib-dirs)  
 .endif  .endif
 afterinstall:  # Targets (in order!) called by "make build".
 .if ${MKMAN} != "no" && !defined(_BUILD)  
         ${MAKE} whatis.db  .if ${MKOBJDIRS:Uno} != "no"
   .if !defined(UPDATE) && !defined(NOCLEANDIR)
   BUILDTARGETS+=  cleandir
   .if ${USETOOLS} == "yes"
   BUILDTARGETS+=  do-make-tools
   .if !defined(NODISTRIBDIRS)
   BUILDTARGETS+=  do-distrib-dirs
   .if !defined(NOINCLUDES)
   BUILDTARGETS+=  includes
 .endif  .endif
   BUILDTARGETS+=  do-lib-csu do-lib do-gnu-lib do-build
 whatis.db:  # Enforce proper ordering of some rules.
         (cd ${.CURDIR}/share/man && ${MAKE} makedb)  
 # wrt info/dir below:  It's safe to move this over top of /usr/share/info/dir,  .ORDER:         ${BUILDTARGETS}
 # as the build will automatically remove/replace the non-pkg entries there.  includes-lib:   includes-include includes-sys
   includes-gnu:   includes-lib
 build: beforeinstall  # Build the system and install into DESTDIR.
 .if ${MKSHARE} != "no"  
         (cd ${.CURDIR}/share/mk && ${MAKE} install)  build:
         (cd ${.CURDIR}/share/tmac && ${MAKE} && ${MAKE} install)  .if defined(BUILD_DONE)
 .endif          @echo "Build already installed into ${DESTDIR}"
 .if !defined(UPDATE)  
         ${MAKE} cleandir  
 .if empty(HAVE_GCC28)  
 .if defined(DESTDIR)  
         @echo "*** CAPUTE!"  
         @echo "    You attempted to compile the world without egcs.  You must"  
         @echo "    first install a native egcs compiler."  
 .else  .else
         (cd ${.CURDIR}/gnu/usr.bin/egcs && \          @echo -n "Build started at: " && date
             ${MAKE} depend && ${MAKE} ${_J} MKMAN=no && \  .for tgt in ${BUILDTARGETS}
             ${MAKE} MKMAN=no install && ${MAKE} cleandir)          ${MAKE} ${_J} ${tgt}
 .endif  .endfor
 .endif          @echo -n "Build finished at: " && date
         ${MAKE} includes  .endif
         (cd ${.CURDIR}/lib/csu && \  
             ${MAKE} depend && ${MAKE} ${_J} MKMAN=no && \  # Build a release or snapshot (implies "make build").
             ${MAKE} MKMAN=no install)  
         (cd ${.CURDIR}/lib && \  
             ${MAKE} depend && ${MAKE} ${_J} MKMAN=no && \  
             ${MAKE} MKMAN=no install)  
         (cd ${.CURDIR}/gnu/lib && \  
             ${MAKE} depend && ${MAKE} ${_J} MKMAN=no MKINFO=no && \  
             ${MAKE} MKMAN=no MKINFO=no install)  
         ${MAKE} depend && ${MAKE} ${_J} && ${MAKE} _BUILD= install  
 .if exists(domestic) && !defined(EXPORTABLE_SYSTEM)  
         (cd ${.CURDIR}/domestic && ${MAKE} ${_J} _SLAVE_BUILD= build)  
         ${MAKE} whatis.db  
         @echo -n "Build finished at: "  
 release snapshot: build  release snapshot: build
         (cd ${.CURDIR}/etc && ${MAKE} INSTALL_DONE=1 release)          cd ${.CURDIR}/etc && ${MAKE} INSTALL_DONE=1 release
   # Special components of the "make build" process.
           cd ${.CURDIR}/tools && ${MAKE} build
           cd ${.CURDIR}/etc && ${MAKE} DESTDIR=${DESTDIR} distrib-dirs
   .for dir in lib/csu lib gnu/lib
   .for targ in dependall install
           cd ${.CURDIR}/${dir} && \
                   ${MAKE} ${_J} MKSHARE=no MKLINT=no ${targ}
           ${MAKE} ${_J} dependall
           ${MAKE} ${_J} install
   # Speedup stubs for some subtrees that don't need to run these rules.
   # (Tells <bsd.subdir.mk> 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:
 .include <bsd.subdir.mk>  .include <bsd.subdir.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 $< >$@
   # 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}' >$@

Removed from v.1.94  
changed lines
  Added in v.1.146

CVSweb <webmaster@jp.NetBSD.org>