aboutsummaryrefslogtreecommitdiff
path: root/Tools
diff options
context:
space:
mode:
authorKris Kennaway <kris@FreeBSD.org>2002-03-25 00:24:03 +0000
committerKris Kennaway <kris@FreeBSD.org>2002-03-25 00:24:03 +0000
commitba656274f644e2870ca77e6edd1b0e8890969a6c (patch)
tree76f840a8c211bace6eb2638cbe70aec2fb624666 /Tools
parent1b934126cef0e082cdbbc4d4b825d91287cd17b0 (diff)
* Clean up this script a bit
* Add a trap handler to try and clean up the build if it is interrupted by a signal (one problem with the previous version is that package builds whice are interrupted by ptimeout because they are stuck, leave their working files lying around in the chroot). * Switch to NFS v3 mounts instead of v2 * Autogenerate the version string to report in uname within the chroot, based on the version string in the head of the CVS branch being built. * Copy packages via cp from the NFS mount, not scp.
Notes
Notes: svn path=/head/; revision=56568
Diffstat (limited to 'Tools')
-rwxr-xr-xTools/portbuild/scripts/portbuild85
1 files changed, 49 insertions, 36 deletions
diff --git a/Tools/portbuild/scripts/portbuild b/Tools/portbuild/scripts/portbuild
index 2860518d22b1..1b9bd12fd578 100755
--- a/Tools/portbuild/scripts/portbuild
+++ b/Tools/portbuild/scripts/portbuild
@@ -2,6 +2,41 @@
# usage: $0 BRANCH [-noclean] [-norestr] [-plistcheck] [-nodummy] PKGNAME.tgz DIRNAME [DEPENDENCY.tgz ...]
+cleanup()
+{
+ chroot=$1
+ noclean=$2
+ error=$3
+ cleandirs=$4
+ pkgname=$5
+
+ #umount ${chroot}/proc
+
+ umount -f ${chroot}/a/ports
+ umount -f ${chroot}/usr/opt/doc
+ umount -f ${chroot}/usr/src
+
+ if [ $noclean = 0 -o $error = 0 ]; then
+ rm -rf ${chroot}/tmp/*
+ for dir in ${cleandirs}; do
+ if ! rm -rf ${chroot}${dir} >/dev/null 2>&1; then
+ chflags -R noschg ${chroot}${dir}
+ rm -rf ${chroot}${dir} >/dev/null 2>&1
+ fi
+ done
+ chroot ${chroot} /sbin/ldconfig -R
+ chroot ${chroot} /sbin/ldconfig -aout -R #XXX i386 only
+ rm -rf ${chroot}/var/db/pkg/*
+ rm ${chroot}/used/${pkgname}
+ rmdir ${chroot}/used
+ fi
+
+ echo -n "$pkgname done on $(hostname -s) at "
+ date
+
+ exit $error
+}
+
# configurable variables
pb=/var/portbuild
@@ -9,6 +44,7 @@ pb=/var/portbuild
. ${pb}/scripts/buildenv
buildroot=${scratchdir}
+error=0
branch=$1
shift
@@ -45,7 +81,8 @@ shift 2
buildenv ${branch}
-export WRKDIRPREFIX=${scratchdir}
+export WRKDIRPREFIX=${buildroot}
+export DISTDIR=/tmp/distfiles
# to catch missing dependencies
#export DEPENDS_TARGET=/usr/bin/true
@@ -74,7 +111,7 @@ echo "building $pkgname"
chrootdir=${buildroot}/${branch}/chroot
bakdir=${pb}/${branch}/tarballs
-bindist=${bakdir}/bindist.tar
+bindist=${buildroot}/${branch}/tarballs/bindist.tar
packages=${pb}/${branch}/packages
found=0
@@ -109,10 +146,12 @@ if [ ${found} != 1 ]; then
cp -p /usr/bin/killall ${chroot}/usr/bin
# Set up desired uname version
- cp ${bakdir}/UNAME_TARGET ${chroot}/usr/bin
+ echo ${OSREL}-${BRANCH} > ${chroot}/usr/bin/UNAME_TARGET
fi
+trap "cleanup ${chroot} ${noclean} ${error} \"${cleandirs}\" ${pkgname}" 1 2 3 9 10 11 15
+
rm -rf ${chroot}/tmp/*
cd ${chroot}/tmp
mkdir -p depends distfiles packages
@@ -124,13 +163,13 @@ echo "with arguments: ${args}" | tee -a ${chroot}/tmp/${pkgname}.log
# intentionally set up ${PORTSDIR} with symlink to catch broken ports
mkdir -p ${chroot}/a/ports
rm -rf ${chroot}/usr/ports
-mount -o -2 -r ${master}:${pb}/${branch}/ports ${chroot}/a/ports
+mount -r ${master}:${pb}/${branch}/ports ${chroot}/a/ports
ln -sf ../a/ports ${chroot}/usr/ports
mkdir -p ${chroot}/usr/src ${chroot}/usr/opt/doc
-mount -o -2 -r ${master}:${pb}/${branch}/src ${chroot}/usr/src
-mount -o -2 -r ${master}:${pb}/usr/opt/doc ${chroot}/usr/opt/doc
+mount -r ${master}:${pb}/${branch}/src ${chroot}/usr/src
+mount -r ${master}:${pb}/usr/opt/doc ${chroot}/usr/opt/doc
mtree -deU -f ${chroot}/usr/src/etc/mtree/BSD.root.dist -p ${chroot} \
>/dev/null 2>&1
@@ -156,10 +195,10 @@ chroot ${chroot} /sbin/ldconfig -aout -m /usr/lib/compat/aout
chroot ${chroot} /sbin/ldconfig -aout -R
while [ $# -gt 0 ]; do
- if ssh -a -x ${master} [ -f ${packages}/All/$1 ]; then
+ if [ -f ${packages}/All/$1 ]; then
if [ ! -f ${chroot}/tmp/depends/$1 ]; then
echo "copying package $1 for ${pkgname}"
- scp -p $master:${packages}/All/$1 ${chroot}/tmp/depends
+ cp -p ${packages}/All/$1 ${chroot}/tmp/depends
fi
else
echo "skipping package $1 for ${pkgname} since it is missing"
@@ -167,9 +206,7 @@ while [ $# -gt 0 ]; do
shift
done
-scp -p ${master}:${pb}/scripts/{buildscript,pnohang} ${chroot}
-
-#mount_procfs procfs ${chroot}/proc
+cp -p ${pb}/scripts/buildscript ${pb}/scripts/pnohang ${chroot}
# phase 1, make checksum
chroot ${chroot} /buildscript ${dirname} 1 2>&1 | tee -a ${chroot}/tmp/${pkgname}.log
@@ -206,28 +243,4 @@ else
scp ${chroot}/tmp/${pkgname}.log ${master}:${pb}/${branch}/logs/${pkgname}.log
fi
-#umount ${chroot}/proc
-
-umount -f ${chroot}/a/ports
-umount -f ${chroot}/usr/opt/doc
-umount -f ${chroot}/usr/src
-
-if [ $noclean = 0 -o $error = 0 ]; then
- rm -rf ${chroot}/tmp/*
- for dir in ${cleandirs}; do
- if ! rm -rf ${chroot}${dir} >/dev/null 2>&1; then
- chflags -R noschg ${chroot}${dir}
- rm -rf ${chroot}${dir} >/dev/null 2>&1
- fi
- done
- chroot ${chroot} /sbin/ldconfig -R
- chroot ${chroot} /sbin/ldconfig -aout -R
- rm -rf ${chroot}/var/db/pkg/*
- rm ${chroot}/used/${pkgname}
- rmdir ${chroot}/used
-fi
-
-echo -n "$pkgname done on $(hostname -s) at "
-date
-
-exit $error
+cleanup ${chroot} ${noclean} ${error} "${cleandirs}" ${pkgname}