nrelease: kernel moved to boot, make kernel.BOOTP there
[dragonfly.git] / nrelease / Makefile
index b201897..60c673d 100644 (file)
@@ -38,6 +38,7 @@ CVSUP_BOOTSTRAP_KIT?= cvsup-bootstrap-20070716
 # 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
 
 # User may specify extra packages in addition to the defaults
@@ -83,7 +84,7 @@ OLD_PKGSRC_PACKAGES?= cdrtools-2.01.01.27nb1 \
                        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 \
@@ -143,21 +144,24 @@ NRLOBJDIR?= /usr/obj
 #########################################################################
 
 release:       check clean buildworld1 buildkernel1 \
-               buildiso syssrcs customizeiso mkaliases mklocatedb \
+               buildiso srcs customizeiso mkaliases mklocatedb \
                mkiso mkimg
 
 quickrel:      check clean buildworld2 buildkernel2 \
-               buildiso syssrcs customizeiso mkaliases mklocatedb \
+               buildiso srcs customizeiso mkaliases mklocatedb \
                mkiso mkimg
 
-realquickrel:  check clean buildiso syssrcs customizeiso \
+realquickrel:  check clean buildiso srcs customizeiso \
                mkaliases mklocatedb \
                mkiso mkimg
 
+restartpkgs:   check customizeiso mkaliases mklocatedb mkiso mkimg
+
 quick:         quickrel
 
 realquick:     realquickrel
 
+
 #########################################################################
 #                         CORE SUPPORT TARGETS                         #
 #########################################################################
@@ -178,7 +182,8 @@ check:
 .endif
 .if !defined(PKGSRC_PATH)
        @echo "Please set PKGSRC_PATH to the pkgsrc tree that shall be used for"
-       @echo "package building."
+       @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
@@ -251,21 +256,41 @@ 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:
+       # 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
        (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
@@ -296,9 +321,6 @@ customizeiso:
        -@umount ${ISOROOT}/usr/pkgsrc
        mkdir -p ${ISODIR}/distfiles
        rm -rf ${ISOROOT}/usr/pkgobj
-       test -e ${ISODIR}/.didbootstrap ||          \
-           rm -rf ${ISOROOT}/usr/pkg ${ISOROOT}/var/db/pkg \
-                   ${ISOROOT}/var/db/pkg.refcount
        #
        # Mount /usr/pkgsrc, make sure /usr/pkgsrc/distfiles is writable
        #
@@ -306,16 +328,32 @@ customizeiso:
        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 || \
-               mount_null ${ISODIR}/distfiles ${ISOROOT}/usr/pkgsrc/distfiles
+       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
+       # Bootstrap, if not already installed, and add licenses needed
+       # for the gui release
        #
-       test -e ${ISODIR}/.didbootstrap ||      \
+       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"
-       sync
-       touch ${ISODIR}/.didbootstrap
+       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
        #
@@ -395,11 +433,11 @@ mkimg:
 .endif
 
 clean:
-       -umount ${ISOROOT}/usr/pkgsrc/distfiles
-       -umount ${ISOROOT}/usr/pkgsrc
+       -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
@@ -408,7 +446,8 @@ realclean:  clean
        # 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
@@ -427,23 +466,19 @@ pkgsrc_cdrecord:
        (cd ${PKGSRC_PATH}/sysutils/cdrtools; bmake clean build install)
 .endif
 
-help:
-       @echo "make release   - complete build from scratch"
-       @echo "make quick     - attempt to do an incremental rebuild"
-       @echo "make realquick - attempt to restart after world & kernel"
-       @echo ""
-       @echo "If the main build works but customizeiso fails you can restart"
-       @echo "at the customize iso step with:"
-       @echo ""
-       @echo "make customizeiso mkaliases mklocatedb mkiso mkimg"
+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 help mkaliases
+.PHONY: clean realclean fetch help all mkaliases srcs
 
 .include <bsd.prog.mk>