nrelease: kernel moved to boot, make kernel.BOOTP there
[dragonfly.git] / nrelease / Makefile
index 6c8ea1d..60c673d 100644 (file)
@@ -5,40 +5,12 @@
 #                              ENHANCEMENTS                            #
 #########################################################################
 
-# These targets are now obsolete and should not be used 
-#
-installer_release: warning release
-installer_quickrel: warning quickrel
-installer_realquickrel: warning realquickrel
-installer_fetch: warning fetch
-
-.if make(installer_release) || make(installer_quickrel) || make(installer_realquickrel) || make(installer_fetch)
-WITH_INSTALLER=
-.endif
-
-# New method e.g. 'make installer fetch'.  A series of enhancement
+# New method e.g. 'make gui release'.  A series of enhancement
 # targes may be specified which set make variables which enhance
 # the build in various ways.
 #
 gui installer img:
 
-warning:
-       @echo "WARNING: The installer_* targets are now obsolete, please"
-       @echo "use 'make installer blah' instead of 'make installer_blah'"
-       @echo ""
-       @echo "will continue in 10 seconds"
-       @sleep 10
-
-.if make(gui)
-WITH_GUI=
-.endif
-.if make(installer)
-WITH_INSTALLER=
-.endif
-.if make(img)
-WITH_IMG=
-.endif
-
 #########################################################################
 #                               SETUP                                  #
 #########################################################################
@@ -61,72 +33,98 @@ PKGBIN_MKISOFS?=    ${PKGSRC_PREFIX}/bin/mkisofs
 PKGSRC_PKG_PATH?=      ${ISODIR}/packages
 PKGSRC_DB?=            /var/db/pkg
 PKGSRC_BOOTSTRAP_URL?= http://pkgbox.dragonflybsd.org/DragonFly-pkgsrc-packages/i386/1.12.0-RELEASE-BUILD
+CVSUP_BOOTSTRAP_KIT?=  cvsup-bootstrap-20070716
 
-ENVCMD?=       env
-TAR?=  tar
+# We use env -i in the chroot, so that environment variables won't
+# disturb any (pkgsrc) build.  This has happened for TARGET_ARCH,
+# which is used by gmake in completely different context.
+#
+CHROOT_CMD?=           env -i CCVER=${CCVER:Q} /usr/sbin/chroot ${ISOROOT} sh -c
 
-PKGSRC_BOOTSTRAP_KIT?= bootstrap-kit-20080211
-CVSUP_BOOTSTRAP_KIT?=  cvsup-bootstrap-20070716
+# User may specify extra packages in addition to the defaults
+#
+PKGSRC_EXTRA_PACKAGES?=
 
-# Default packages to be installed on the release ISO.
+# Pkgsrc packages to be built and installed on the release ISO
+#
+PKGSRC_PACKAGES?=      pkgtools/pkg_leaves \
+                       pkgtools/pkg_tarup \
+                       devel/scmgit \
+                       net/isc-dhcp4 \
+                       net/isc-dhcpd4 \
+                       sysutils/cdrtools \
+                       ${PKGSRC_EXTRA_PACKAGES}
+
+# pkgsrc options to use when building packages
 #
-PKGSRC_PACKAGES?=      cdrtools-ossdvd-2.01.1.36nb2.tgz \
-                       isc-dhcp-base-4.0.0.tgz isc-dhcp-server-4.0.0.tgz
+.if !make(gui)
+PKGSRC_OPTIONS?=       PKG_OPTIONS.scmgit=-scmgit-gui
+.endif
 
 # Even though buildiso wipes the packages, our check target has to run
 # first and old packages (listed as they appear in pkg_info) must be
 # cleaned out in order for the pkg_add -n test we use in the check target
 # to operate properly.
 #
-OLD_PKGSRC_PACKAGES?= cdrtools-2.01.01.27nb1 cdrecord-2.00.3nb2 \
-                     bootstrap-kit-20070205
+OLD_PKGSRC_PACKAGES?=  cdrtools-2.01.01.27nb1 \
+                       cdrecord-2.00.3nb2 \
+                       bootstrap-kit-20070205 \
+                       dfuibe_installer-1.1.6 \
+                       gettext-lib-0.14.5 \
+                       dfuibe_installer-1.1.7nb1 \
+                       dfuife_curses-1.5 \
+                       gettext-lib-0.14.6 \
+                       gettext-tools-0.14.6nb1 \
+                       libaura-3.1 \
+                       libdfui-4.2 \
+                       libinstaller-5.1 \
+                       bootstrap-kit-20080211 \
+                       cdrtools-ossdvd-2.01.1.36nb2 \
+                       isc-dhcp-base-4.0.0 \
+                       isc-dhcp-server-4.0.0
 
 # Specify which root skeletons are required, and let the user include
-# their own.  They are copied into ISODIR during the `pkgcustomizeiso'
+# their own.  They are copied into ISODIR during the `customizeiso'
 # target; each overwrites the last.
 #
-REQ_ROOTSKELS= ${.CURDIR}/root
+REQ_ROOTSKELS= ${.CURDIR}/root \
+               ${.CURDIR}/installer
 ROOTSKELS?=    ${REQ_ROOTSKELS}
 
-.if defined(WITH_INSTALLER)
-OLD_PKGSRC_PACKAGES+=  dfuibe_installer-1.1.6 gettext-lib-0.14.5 \
-                       dfuibe_installer-1.1.7nb1 dfuife_curses-1.5 \
-                       gettext-lib-0.14.6 gettext-tools-0.14.6nb1 \
-                       libaura-3.1 libdfui-4.2 libinstaller-5.1
-ROOTSKELS+=            ${.CURDIR}/installer
-.endif
-
-.if defined(WITH_GUI)
+.if make(gui)
 ISOFILE?=              ${ISODIR}/dfly-gui.iso
 IMGFILE?=              ${ISODIR}/dfly-gui.img
-PKGSRC_PACKAGES+=      modular-xorg-apps \
-                       modular-xorg-drivers \
-                       modular-xorg-fonts \
-                       modular-xorg-libs \
-                       fluxbox \
-                       firefox3 \
-                       xpdf \
-                       zsh \
-                       emacs \
-                       vim \
-                       pidgin \
-                       irssi \
-                       xchat \
-                       rxvt-unicode \
-                       eterm \
-                       perl \
-                       nano \
-                       bash \
-                       exctags \
-                       zip \
-                       sudo \
-                       links-gui \
-                       nmap \
-                       wget \
-                       terminus-font \
-                       rsync \
-                       idesk \
-                       screen
+PKGSRC_PACKAGES+=      meta-pkgs/modular-xorg-apps \
+                       meta-pkgs/modular-xorg-drivers \
+                       meta-pkgs/modular-xorg-fonts \
+                       meta-pkgs/modular-xorg-libs \
+                       wm/fluxbox \
+                       wm/fvwm \
+                       www/firefox3 \
+                       print/xpdf \
+                       shells/zsh \
+                       editors/emacs \
+                       editors/vim \
+                       chat/pidgin \
+                       chat/irssi \
+                       chat/xchat \
+                       x11/modular-xorg-server \
+                       x11/rxvt-unicode \
+                       x11/eterm \
+                       lang/perl5 \
+                       editors/nano \
+                       shells/bash \
+                       devel/exctags \
+                       archivers/zip \
+                       security/sudo \
+                       www/links-gui \
+                       net/nmap \
+                       net/wget \
+                       fonts/terminus-font \
+                       net/rsync \
+                       sysutils/idesk \
+                       time/asclock \
+                       misc/screen
 ROOTSKELS+=            ${.CURDIR}/gui
 .endif
 
@@ -146,55 +144,59 @@ NRLOBJDIR?= /usr/obj
 #########################################################################
 
 release:       check clean buildworld1 buildkernel1 \
-               buildiso syssrcs customizeiso mklocatedb mkiso mkimg
+               buildiso srcs customizeiso mkaliases mklocatedb \
+               mkiso mkimg
 
 quickrel:      check clean buildworld2 buildkernel2 \
-               buildiso syssrcs customizeiso mklocatedb mkiso mkimg
+               buildiso srcs customizeiso mkaliases mklocatedb \
+               mkiso mkimg
 
-realquickrel:  check clean buildiso syssrcs customizeiso mklocatedb mkiso \
-               mkimg
+realquickrel:  check clean buildiso srcs customizeiso \
+               mkaliases mklocatedb \
+               mkiso mkimg
+
+restartpkgs:   check customizeiso mkaliases mklocatedb mkiso mkimg
 
 quick:         quickrel
 
 realquick:     realquickrel
 
+
 #########################################################################
 #                         CORE SUPPORT TARGETS                         #
 #########################################################################
 
 check:
-.if !exists(${PKGBIN_PKG_ADD})
-       @echo "Unable to find ${PKGBIN_PKG_ADD}.  You can use the following"
-       @echo "command to bootstrap pkgsrc:"
+.if !exists(${PKGBIN_PKG_ADMIN})
+       @echo "You never bootstrapped pkgsrc on your machine.  You can install it with:"
        @echo "    make pkgsrc_bootstrap"
-       @exit 1
 .endif
-.for PKG in ${OLD_PKGSRC_PACKAGES}
-       @${ENVCMD} PKG_PATH=${PKGSRC_PKG_PATH} ${PKGBIN_PKG_DELETE} -K ${ISOROOT}${PKGSRC_DB} ${PKG} > /dev/null 2>&1 || exit 0
-.endfor
-.for PKG in ${PKGSRC_PACKAGES}
-       @${ENVCMD} PKG_PATH=${PKGSRC_PKG_PATH} ${PKGBIN_PKG_ADD} -K ${ISOROOT}${PKGSRC_DB} -n ${PKG} > /dev/null 2>&1 || \
-               (echo "Unable to find ${PKG}, use the following command to fetch required packages:"; echo "    make [installer] fetch"; exit 1)
-.endfor
-.if !exists(${PKGBIN_MKISOFS})
-       @echo "mkisofs is not installed.  It is part of the cdrecord package."
-       @echo "You can install it with:"
+.if !exists(${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}.tgz)
+       @echo "The cvsup bootstrap kit is not installed.  You can install it with:"
+       @echo "    make fetch"
+.endif
+.if !exists (${PKGBIN_MKISOFS})
+       @echo
+       @echo "Your machine does not have cdrtools installed.  You can install it with:"
        @echo "    make pkgsrc_cdrecord"
+.endif
+.if !defined(PKGSRC_PATH)
+       @echo "Please set PKGSRC_PATH to the pkgsrc tree that shall be used for"
+       @echo "package building.  For example /usr/pkgsrc.  See the Makefile"
+       @echo "in /usr if you are unfamiliar with pkgsrc."
+.endif
+.if !exists(${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}.tgz)
        @exit 1
 .endif
-.if !exists(${PKGSRC_PKG_PATH}/${PKGSRC_BOOTSTRAP_KIT}.tgz)
-       @echo "The pkgsrc bootstrap kit is not installed.  You can install it with:"
-       @echo "    make [installer] fetch"
+.if !exists (${PKGBIN_MKISOFS})
        @exit 1
 .endif
-.if !exists(${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}.tgz)
-       @echo "The cvsup bootstrap kit is not installed.  You can install it with:"
-       @echo "    make [installer] fetch"
+.if !defined(PKGSRC_PATH)
        @exit 1
 .endif
 
 buildworld1 buildworld2:
-       cd ${.CURDIR}/..; ${WORLD_CCVER:C/^..*$/WORLD_CCVER=/}${WORLD_CCVER} make ${WITH_INSTALLER:C/^/-DWANT_INSTALLER/} ${.TARGET:C/build(.*)2/quick\1/:C/1//}
+       cd ${.CURDIR}/..; ${WORLD_CCVER:C/^..*$/WORLD_CCVER=/}${WORLD_CCVER} make -DWANT_INSTALLER ${.TARGET:C/build(.*)2/quick\1/:C/1//}
 
 buildkernel1 buildkernel2:
 .if make(gui)
@@ -224,12 +226,12 @@ buildkernel1 buildkernel2:
 buildiso:
        if [ ! -d ${ISOROOT} ]; then mkdir -p ${ISOROOT}; fi
        if [ ! -d ${NRLOBJDIR}/nrelease ]; then mkdir -p ${NRLOBJDIR}/nrelease; fi
-       ( cd ${.CURDIR}/..; make ${WITH_INSTALLER:C/^/-DWANT_INSTALLER/} DESTDIR=${ISOROOT} installworld )
+       ( cd ${.CURDIR}/..; make -DWANT_INSTALLER DESTDIR=${ISOROOT} installworld )
        ( cd ${.CURDIR}/../etc; MAKEOBJDIRPREFIX=${NRLOBJDIR}/nrelease \
                make -m ${.CURDIR}/../share/mk DESTDIR=${ISOROOT} distribution )
        cpdup ${ISOROOT}/etc ${ISOROOT}/etc.hdd
 .if make(gui)
-       if [ ! -d ${ISOROOT}/kernel.smp ]; then mkdir -p ${ISOROOT}/kernel.smp; fi
+       if [ ! -d ${ISOROOT}/kernel.smp/boot ]; then mkdir -p ${ISOROOT}/kernel.smp/boot; fi
        cd ${.CURDIR}/..; \
        make installkernel DESTDIR=${ISOROOT} \
        KERNCONF=DFLYLIVE DESTKERNNAME=kernel KERNCONFDIR=${.CURDIR}/gui/root; \
@@ -254,29 +256,45 @@ buildiso:
                first=done; \
        done
 .endif
-       ln -s kernel ${ISOROOT}/kernel.BOOTP
+       ln -s kernel ${ISOROOT}/boot/kernel.BOOTP
        mtree -deU -f ${.CURDIR}/../etc/mtree/BSD.local.dist -p ${ISOROOT}/usr/local/
        mtree -deU -f ${.CURDIR}/../etc/mtree/BSD.var.dist -p ${ISOROOT}/var
        dev_mkdb -f ${ISOROOT}/var/run/dev.db ${ISOROOT}/dev
 
-# Include kernel sources on the release CD (~14MB)
+# Release CD: Kernel sources (~16M) and the full pkgsrc tree (~27M)
+# Release DVD: Full sources (~90M) and the full pkgsrc tree (~27M)
 #
-syssrcs:
+srcs:
 .if !defined(WITHOUT_SRCS)
-       ( cd ${.CURDIR}/../..; tar -cf - src/Makefile src/Makefile.inc1 src/sys | bzip2 -9 > ${ISOROOT}/usr/src-sys.tar.bz2 )
+       rm -f ${ISOROOT}/usr/pkgsrc-all.tgz
+       cd ${PKGSRC_PATH} && tar --exclude distfiles --exclude packages --exclude work --exclude CVS --exclude .git \
+               -czf ${ISOROOT}/usr/pkgsrc-all.tgz .
+.if make(gui)
+       rm -f ${ISOROOT}/usr/src-all.tgz
+       cd ${.CURDIR}/../.. && tar --exclude .git --exclude CVS \
+               -czf ${ISOROOT}/usr/src-all.tgz src
+.else
+       rm -f ${ISOROOT}/usr/src-sys.tgz
+       cd ${.CURDIR}/../.. && tar --exclude .git --exclude CVS \
+               -czf ${ISOROOT}/usr/src-sys.tgz src/Makefile src/Makefile.inc1 src/sys
+.endif
 .endif
 
+# Customize the ISO by copying rootskels in reverse priority order,
+# building packages, and doing other post-install tasks.
+#
 customizeiso:
-       (cd ${PKGSRC_PKG_PATH}; tar xzpf ${CVSUP_BOOTSTRAP_KIT}.tgz)
+       # Copy the rootskels.  Allow sources to be owned by someone other
+       # then root (as is common when checked out via git).
+       #
 .for ROOTSKEL in ${ROOTSKELS}
        cpdup -X cpignore -o ${ROOTSKEL} ${ISOROOT}
+       @test -O ${.CURDIR} || echo "chowning copied files to root:wheel"
+       @test -O ${.CURDIR} || ((cd ${ROOTSKEL} && find .) | fgrep -v cpignore | (cd ${ISOROOT} && xargs chown root:wheel))
 .endfor
-       rm -rf ${ISOROOT}/tmp/bootstrap ${ISOROOT}/usr/obj/pkgsrc
-       cd ${ISOROOT}; tar xvzpf ${PKGSRC_PKG_PATH}/${PKGSRC_BOOTSTRAP_KIT}.tgz
+       (cd ${PKGSRC_PKG_PATH}; tar xzpf ${CVSUP_BOOTSTRAP_KIT}.tgz)
        cp -p ${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}/usr/local/bin/cvsup ${ISOROOT}/usr/local/bin/cvsup
        cp -p ${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}/usr/local/man/man1/cvsup.1 ${ISOROOT}/usr/local/man/man1/cvsup.1
-       rm -rf ${ISOROOT}/tmp/bootstrap ${ISOROOT}/usr/obj/pkgsrc
-       rm -rf ${ISOROOT}/usr/local/share/pristine
        pwd_mkdb -p -d ${ISOROOT}/etc ${ISOROOT}/etc/master.passwd
 .for UPGRADE_ITEM in Makefile                  \
                     etc.${MACHINE_ARCH}        \
@@ -289,22 +307,80 @@ customizeiso:
                     periodic/monthly/Makefile
        cp -R ${.CURDIR}/../etc/${UPGRADE_ITEM} ${ISOROOT}/etc/${UPGRADE_ITEM}
 .endfor
-       # There seems to be no reliable way to install a package to a target
-       # directory prefix so we mount_null our package directory into the
-       # ISO root and do the install chrooted.
        #
-       mkdir ${ISOROOT}/tmp/packages
-       mount_null -o ro ${PKGSRC_PKG_PATH} ${ISOROOT}/tmp/packages
+       # Setup some things & mount pkgsrc tree.  Use defensive umounts and
+       # rm -rf's to allow restarts.  Allow /usr/pkgsrc to be read-only.
+       #
+       # If we did not get past the bootstrap we clean out the entire
+       # /usr/pkg infrastructure.  Otherwise we attempt to pick up where
+       # we left off.
+       #
+       cp -p /etc/resolv.conf ${ISOROOT}/etc
+       ${CHROOT_CMD} "ldconfig -elf /usr/lib /usr/lib/gcc* /usr/lib/compat"
+       -@umount ${ISOROOT}/usr/pkgsrc/distfiles
+       -@umount ${ISOROOT}/usr/pkgsrc
+       mkdir -p ${ISODIR}/distfiles
+       rm -rf ${ISOROOT}/usr/pkgobj
+       #
+       # Mount /usr/pkgsrc, make sure /usr/pkgsrc/distfiles is writable
+       #
+       mkdir -p ${ISOROOT}/usr/pkgobj
+       mkdir -p ${ISOROOT}/usr/pkgobj/bootstrap/work
+       mkdir -p ${ISOROOT}/usr/pkgsrc
+       mount_null ${PKGSRC_PATH} ${ISOROOT}/usr/pkgsrc
+       cp /etc/shells ${ISOROOT}/usr/pkgsrc/distfiles/.test > /dev/null 2>&1 \
+           || mount_null ${ISODIR}/distfiles ${ISOROOT}/usr/pkgsrc/distfiles
+       #
+       # Bootstrap, if not already installed, and add licenses needed
+       # for the gui release
+       #
+       test -e ${ISODIR}/.didbootstrap || \
+           rm -rf ${ISOROOT}/usr/pkg ${ISOROOT}/var/db/pkg \
+                   ${ISOROOT}/var/db/pkg.refcount
+       test -e ${ISODIR}/.didbootstrap || \
+           ${CHROOT_CMD} "cd /usr/pkgsrc/bootstrap;    \
+               ./bootstrap --workdir /usr/pkgobj/bootstrap/work"
+       test -e ${ISODIR}/.didbootstrap || \
+           echo ".ifdef BSD_PKG_MK     # added by nrelease" \
+               >> ${ISOROOT}/usr/pkg/etc/mk.conf
+       test -e ${ISODIR}/.didbootstrap || \
+           echo "ACCEPTABLE_LICENSES+=openmotif-license" \
+               >> ${ISOROOT}/usr/pkg/etc/mk.conf
+       test -e ${ISODIR}/.didbootstrap || \
+           echo "ACCEPTABLE_LICENSES+=vim-license" \
+               >> ${ISOROOT}/usr/pkg/etc/mk.conf
+       test -e ${ISODIR}/.didbootstrap || \
+           echo ".endif                        # added by nrelease" \
+               >> ${ISOROOT}/usr/pkg/etc/mk.conf
+       test -e ${ISODIR}/.didbootstrap || sync
+       test -e ${ISODIR}/.didbootstrap || touch ${ISODIR}/.didbootstrap
+       #
+       # Build and install packages, skip packages already installed
+       #
 .for PKG in ${PKGSRC_PACKAGES}
-       ${ENVCMD} PKG_PATH=/tmp/packages chroot ${ISOROOT} ${PKGBIN_PKG_ADD} ${PKG}
+       ${CHROOT_CMD} "cd /usr/pkgsrc/${PKG} && \
+           (bmake WRKOBJDIR=/usr/pkgobj check > /dev/null 2>&1 || \
+           bmake WRKOBJDIR=/usr/pkgobj ${PKGSRC_OPTIONS} clean build install)"
 .endfor
-       umount ${ISOROOT}/tmp/packages
-       rmdir ${ISOROOT}/tmp/packages
-       find ${ISOROOT}${PKGSRC_DB} -name +CONTENTS -type f -exec sed -i '' -e 's,${ISOROOT},,' -- {} \;
-       chroot ${ISOROOT} ${PKGBIN_PKG_ADMIN} rebuild
+       #
+       # Remove packages which nothing depends on and clean up
+       #
+       ${CHROOT_CMD} "pkg_leaves | xargs pkg_delete -R"
+       -umount ${ISOROOT}/usr/pkgsrc/distfiles
+       umount ${ISOROOT}/usr/pkgsrc
+       rmdir ${ISOROOT}/usr/pkgsrc
+       rm -rf ${ISOROOT}/usr/pkgobj
+       rm -f ${ISOROOT}/etc/resolv.conf
        makewhatis ${ISOROOT}/usr/local/man
        makewhatis ${ISOROOT}/usr/pkg/man
 
+# So a CD boot does not complain about a missing aliases database
+#
+mkaliases:
+       ${CHROOT_CMD} "newaliases"
+
+# So locate works
+#
 mklocatedb:
        ( find -s ${ISOROOT} -path ${ISOROOT}/tmp -or \
                -path ${ISOROOT}/usr/tmp -or -path ${ISOROOT}/var/tmp \
@@ -314,17 +390,18 @@ mklocatedb:
 
 mkiso:
        ( cd ${ISOROOT}; ${PKGBIN_MKISOFS} -b boot/cdboot -no-emul-boot \
-               -R -J -V DragonFly -o ${ISOFILE} . )
+               -R -J -o ${ISOFILE} \
+               -V DragonFly-`${.CURDIR}/../tools/gitrev.sh | cut -c -22` . )
 
 
 mkimg:
-.if defined(WITH_IMG)
+.if make(img)
        if [ ! -d ${IMGMNT} ]; then mkdir -p ${IMGMNT}; fi
 
        echo "determine required image size" > /dev/null;               \
        sz=`du -ck ${ISOROOT} | tail -n 1 | cut -f 1`;                  \
-       echo "add 15 MB more space as required" > /dev/null;            \
-       sz=`bc -e "($${sz}) / 1024 + 15" -equit`;                       \
+       echo "add 15% more space as required" > /dev/null;              \
+       sz=`bc -e "(($${sz}) / 1024) * 1.15" -equit | cut -f1 -d.`;     \
        dd if=/dev/zero of=${IMGFILE} bs=1m count=$${sz};               \
        fdisk -IB -p ${IMGFILE};                                        \
        echo "determine free vn device" > /dev/null;                    \
@@ -356,49 +433,52 @@ mkimg:
 .endif
 
 clean:
-       -umount ${ISOROOT}/tmp/packages
+       -umount ${ISOROOT}/usr/pkgsrc/distfiles > /dev/null 2>&1
+       -umount ${ISOROOT}/usr/pkgsrc > /dev/null 2>&1
        if [ -d ${ISOROOT} ]; then chflags -R noschg ${ISOROOT}; fi
-       if [ -d ${ISOROOT} ]; then rm -rf ${ISOROOT}/*; fi
-       if [ -d ${NRLOBJDIR}/nrelease ]; then rm -rf ${NRLOBJDIR}/nrelease; fi
+       rm -rf ${ISOROOT}
+       rm -rf ${NRLOBJDIR}/nrelease
+       rm -f ${ISODIR}/.didbootstrap
 
 realclean:     clean
        rm -rf ${OBJSYS}/${KERNCONF}
+       #
        # do not use PKGSRC_PKG_PATH here, we do not want to destroy an
        # override location.
-       if [ -d ${ISODIR}/packages ]; then rm -rf ${ISODIR}/packages; fi
+       #
+       rm -rf ${ISODIR}/packages
+       rm -rf ${ISODIR}/distfiles
 
 fetch:
        @if [ ! -d ${PKGSRC_PKG_PATH} ]; then mkdir -p ${PKGSRC_PKG_PATH}; fi
-.for PKG in ${PKGSRC_PACKAGES}
-       @${ENVCMD} PKG_PATH=${PKGSRC_PKG_PATH} ${PKGBIN_PKG_ADD} -K ${ISOROOT}${PKGSRC_DB} -n ${PKG} > /dev/null 2>&1 || \
-       (cd ${PKGSRC_PKG_PATH}; echo "Fetching ${PKGSRC_BOOTSTRAP_URL}/${PKG}"; fetch ${PKGSRC_BOOTSTRAP_URL}/${PKG})
-.endfor
-.if !exists(${PKGSRC_PKG_PATH}/${PKGSRC_BOOTSTRAP_KIT}.tgz)
-       (cd ${PKGSRC_PKG_PATH}; fetch ${PKGSRC_BOOTSTRAP_URL}/${PKGSRC_BOOTSTRAP_KIT}.tgz)
-.endif
 .if !exists(${PKGSRC_PKG_PATH}/${CVSUP_BOOTSTRAP_KIT}.tgz)
        (cd ${PKGSRC_PKG_PATH}; fetch ${PKGSRC_BOOTSTRAP_URL}/${CVSUP_BOOTSTRAP_KIT}.tgz)
 .endif
 
 pkgsrc_bootstrap:
-       mkdir -p ${PKGSRC_PKG_PATH}
 .if !exists(${PKGSRC_PKG_PATH}/${PKGSRC_BOOTSTRAP_KIT}.tgz)
-       (cd ${PKGSRC_PKG_PATH}; fetch ${PKGSRC_BOOTSTRAP_URL}/${PKGSRC_BOOTSTRAP_KIT}.tgz)
+       mkdir -p /usr/release/bootstrap
+       (cd ${PKGSRC_PATH}/bootstrap; ./bootstrap --workdir /usr/release/bootstrap)
 .endif
-       (cd ${PKGSRC_PKG_PATH}; tar xzpf ${PKGSRC_BOOTSTRAP_KIT}.tgz)
-       (cd ${PKGSRC_PKG_PATH}/${PKGSRC_BOOTSTRAP_KIT}/bootstrap; ./bootstrap)
 
 pkgsrc_cdrecord:
 .if !exists (${PKGBIN_MKISOFS})
-       ${PKGBIN_PKG_ADD} ${PKGSRC_PKG_PATH}/cdrtools*
+       (cd ${PKGSRC_PATH}/sysutils/cdrtools; bmake clean build install)
 .endif
 
+help all:
+       @echo "make [gui] release   - complete build from scratch"
+       @echo "make [gui] quick     - attempt to do an incremental rebuild"
+       @echo "make [gui] realquick - attempt to restart after world & kernel"
+       @echo "make [gui] restartpkgs - attempt to restart at the pkg building stage"
+       @echo ""
+       @echo "Extra packages may be specified with PKGSRC_EXTRA_PACKAGES"
 
-.PHONY: all release installer_release quickrel installer_quickrel realquickrel
-.PHONY: installer_fetch installer
+.PHONY: release quickrel realquickrel
+.PHONY: installer
 .PHONY: quick realquick
-.PHONY: installer_realquickrel check buildworld1 buildworld2
+.PHONY: check buildworld1 buildworld2
 .PHONY: buildkernel1 buildkernel2 buildiso customizeiso mklocatedb mkiso mkimg
-.PHONY: clean realclean fetch
+.PHONY: clean realclean fetch help all mkaliases srcs
 
 .include <bsd.prog.mk>