summaryrefslogtreecommitdiffstats
path: root/Tools
diff options
context:
space:
mode:
Diffstat (limited to 'Tools')
-rwxr-xr-xTools/portbuild/scripts/dopackages324
1 files changed, 180 insertions, 144 deletions
diff --git a/Tools/portbuild/scripts/dopackages b/Tools/portbuild/scripts/dopackages
index 365f0c7..b00061f 100755
--- a/Tools/portbuild/scripts/dopackages
+++ b/Tools/portbuild/scripts/dopackages
@@ -4,14 +4,13 @@
pb=/var/portbuild
. ${pb}/portbuild.conf
-
. ${pb}/scripts/buildenv
# packages for dependencies only
-dummyports="" #x11/XFree86"
+dummyports="x11/XFree86"
# packages that take very long to build -- try to start building these first
-quickports="lang/ghc games/civ2demo games/rt2-demo x11/XFree86-4 editors/openoffice games/hlserver-cs misc/heyu x11/gnome x11/kde2"
+quickports="lang/ghc games/civ2demo games/rt2-demo x11/XFree86-4 editors/openoffice games/hlserver-cs misc/heyu x11/gnome x11/kde3"
status=${pb}/status
@@ -21,7 +20,7 @@ errorexit () {
}
usage () {
- echo "usage: [-nobuild] [-nocdrom] [-noindex] [-noduds] [-nocvsup] [-nocvs] [-noportscvs] [-norestr] [-plistcheck] [-nodummy] [-ftp] branch date"
+ echo "usage: [-restart] [-ftp] [-cdrom] [-nodummy] [-nobuild] [-noindex] [-noduds] [-nocvsup] [-nocvs] [-noportscvs] [-norestr] [-plistcheck] branch date"
errorexit 1
}
@@ -87,7 +86,7 @@ makeduds () {
cp -p ${pb}/${branch}/duds ${pb}/${branch}/duds.old
}
-# usage: setupnode pb scripts branch me node md5
+# usage: setupnode pb scripts branch me node md5 tmpdir
setupnode () {
pb=$1
scripts=$2
@@ -95,11 +94,11 @@ setupnode () {
me=$4
node=$5
md5=$6
+ tmpdir=$7
echo "setting up of $node started at $(date)"
- ssh -n ${node} mkdir -p ${scripts}
- scp -p ${scripts}/setupnode ${node}:${scripts}
- ssh -n ${node} ${scripts}/setupnode ${me} ${pb} ${branch} ${md5}
+ scp -p ${scripts}/setupnode ${node}:/tmp
+ ssh -n ${node} /tmp/setupnode ${me} ${pb} ${branch} ${tmpdir} ${md5}
echo "setting up of $node ended at $(date)"
}
@@ -115,8 +114,8 @@ restrictedlist () {
echo "================================================"
echo "restricted list generation started at $(date)"
make ECHO_MSG=/usr/bin/true clean-restricted-list \
- | sed -e "s./usr/ports/distfiles/./distfiles/.g" \
- -e "s./usr/ports/./${branch}/.g" \
+ | sed -e "s./usr/ports/packages/.${pb}/${branch}/packages/.g" \
+ -e "s./usr/ports/.${pb}/${branch}/ports/.g" \
> ${pb}/${branch}/restricted.sh
echo "restricted list generation ended at $(date)"
echo $(grep -c '^#' ${pb}/${branch}/restricted.sh) "ports in ${pb}/${branch}/restricted.sh"
@@ -159,7 +158,7 @@ generatemd5 () {
echo "started generating CHECKSUM.MD5 at $(date)"
cd ${pb}/${branch}/packages/All
- find . -name '*.tgz' | sort | sed -e 's/^..//' | xargs md5 > CHECKSUM.MD5
+ find . -name '*.t[bg]z' | sort | sed -e 's/^..//' | xargs md5 > CHECKSUM.MD5
echo "ended generating CHECKSUM.MD5 at $(date)"
}
@@ -191,8 +190,9 @@ noportscvs=0
norestr=0
plistcheck=0
nodummy=0
-nocdrom=0
+cdrom=0
ftp=0
+restart=0
# optional arguments
while [ $# -gt 2 ]; do
@@ -206,8 +206,8 @@ while [ $# -gt 2 ]; do
x-noduds)
noduds=1
;;
- x-nocdrom)
- nocdrom=1
+ x-cdrom)
+ cdrom=1
;;
x-nocvsup)
nocvsup=1
@@ -230,6 +230,9 @@ while [ $# -gt 2 ]; do
x-ftp)
ftp=1
;;
+ x-restart)
+ restart=1
+ ;;
*)
usage
;;
@@ -240,66 +243,73 @@ done
# mandatory arguments
branch=$1
date=$2
+
+buildenv ${pb} ${branch}
+
if [ "x$branch" != x4 -a "x$branch" != x4-exp -a "x$branch" != x5 ]; then
usage
fi
if [ "$norestr" = 1 ]; then
- export NO_RESTRICTED=t
+ export NO_RESTRICTED=1
fi
if [ "$plistcheck" = 1 ]; then
- export PLISTCHECK=t
+ export PLISTCHECK=1
fi
if [ "$nodummy" = 1 ]; then
- export NODUMMY=t
+ export NODUMMY=1
fi
-buildenv $branch
+if [ "$cdrom" = 1 ]; then
+ export FOR_CDROM=1
+fi
+
+export DISTDIR=${pb}/${branch}/distfiles
+export PACKAGES=${pb}/${branch}/packages
-cd ${PORTSDIR}
-if [ "$nocvsup" = 0 ]; then
-# echo "================================================"
-# echo "running cvsup"
-# echo "================================================"
-# su ${user} -c 'cvsup -g -L 0 /etc/supfile.cvsup'
+if [ "$restart" = 0 ]; then
if [ "$noportscvs" = 0 ]; then
echo "================================================"
- echo "running cvs update on ${PORTSDIR}"
+ echo "running cvs update -PAd on ${PORTSDIR}"
echo "================================================"
- su ${user} -c 'cvs -qR update -d -P'
+ cd ${PORTSDIR}
+ su ${user} -c 'cvs -qR update -PAd'
# XXX Check for conflicts
fi
date > ${pb}/cvsdone
+
echo "================================================"
- echo "running make checksubdirs"
- echo "================================================"
- make checksubdirs
- echo "================================================"
- echo "running cvs update on /usr/opt/doc"
+ echo "running cvs update on ${pb}/doc"
echo "================================================"
- cd ${pb}/usr/opt/doc
- su ${user} -c 'cvs -qR update -d -P'
+ cd ${pb}/${branch}/doc
+ su ${user} -c 'cvs -qR update -PdA'
# XXX Check for conflicts
-fi
+
+ if [ "$nocvs" = 0 ]; then
+ echo "================================================"
+ echo "running cvs update on ${SRCBASE}"
+ echo "================================================"
+ cd ${SRCBASE}
+ su ${user} -c 'cvs -qR update -Pd'
+ # XXX Check for conflicts
+ fi
-if [ "$nocvs" = 0 ]; then
echo "================================================"
- echo "running cvs update on ${SRCBASE}"
+ echo "running make checksubdirs"
echo "================================================"
- cd ${SRCBASE}
- su ${user} -c 'cvs -qR update -d -P'
- # XXX Check for conflicts
-fi
-
-# this one not in background to check return status
-if [ "$noduds" = 0 ]; then
- makeduds ${pb} ${scripts} ${branch}
-fi
-
-if [ "$noindex" = 0 ]; then
- makeindex ${pb} ${scripts} ${branch} ${user} &
+ cd ${PORTSDIR}
+ make checksubdirs
+
+ # this one not in background to check return status
+ if [ "$noduds" = 0 ]; then
+ makeduds ${pb} ${scripts} ${branch}
+ fi
+
+ if [ "$noindex" = 0 ]; then
+ makeindex ${pb} ${scripts} ${branch} ${user} &
+ fi
fi
md5=$(/sbin/md5 ${pb}/${branch}/tarballs/bindist.tar | awk '{print $4}')
@@ -307,99 +317,108 @@ echo "================================================"
echo "setting up nodes"
echo "================================================"
for node in $(awk '{print $1}' ${pb}/mlist); do
- setupnode ${pb} ${scripts} ${branch} ${me} ${node} ${md5} &
+ setupnode ${pb} ${scripts} ${branch} ${me} ${node} ${md5} ${scratchdir} &
sleep 2
done
-restrictedlist ${pb} ${scripts} ${branch} &
-sleep 2
-
-if [ "$nocdrom" = 0 ]; then
- cdromlist ${pb} ${scripts} ${branch} &
+if [ "$restart" = 0 ]; then
+ restrictedlist ${pb} ${scripts} ${branch} &
+ sleep 2
+
+ if [ "$cdrom" = 1 ]; then
+ cdromlist ${pb} ${scripts} ${branch} &
+ fi
fi
-
+
wait
-checkindex ${pb} ${branch}
-
-echo "all preparation ended at $(date)"
-
-cd ${PORTSDIR}
-make parallel branch=${branch} > ${pb}/${branch}/Makefile
-
-if [ "$nodummy" = 0 ]; then
- dummypkgs=""
- for i in ${dummyports}; do
+if [ "$restart" = 0 ]; then
+ checkindex ${pb} ${branch}
+
+ cd ${PORTSDIR}
+ make parallel branch=${branch} > ${pb}/${branch}/Makefile
+
+ if [ "$nodummy" = 0 ]; then
+ dummypkgs=""
+ for i in ${dummyports}; do
+ if [ -d $i ]; then
+ dummypkgs="${dummypkgs} $(cd $i; make package-name)${PKGSUFFIX}"
+ else
+ echo "dummy port directory \"$i\" does not exist -- skipping"
+ fi
+ done
+ fi
+
+ # hack to extend length of dependency chain to build quickports first
+ for i in ${quickports}; do
if [ -d $i ]; then
- dummypkgs="${dummypkgs} $(cd $i; make package-name).tgz"
+ quickpkg="$(cd $i; make package-name)${PKGSUFFIX}"
+ echo "all: dummy1-$quickpkg" >> ${pb}/${branch}/Makefile
+ echo "dummy1-$quickpkg: dummy2-$quickpkg" >> ${pb}/${branch}/Makefile
+ echo "dummy2-$quickpkg: dummy3-$quickpkg" >> ${pb}/${branch}/Makefile
+ echo "dummy3-$quickpkg: $quickpkg" >> ${pb}/${branch}/Makefile
else
- echo "dummy port directory \"$i\" does not exist -- skipping"
+ echo "quick port directory \"$i\" does not exist -- skipping"
fi
done
-fi
-
-# hack to extend length of dependency chain to build quickports first
-for i in ${quickports}; do
- if [ -d $i ]; then
- quickpkg="$(cd $i; make package-name).tgz"
- echo "all: dummy1-$quickpkg" >> ${pb}/${branch}/Makefile
- echo "dummy1-$quickpkg: dummy2-$quickpkg" >> ${pb}/${branch}/Makefile
- echo "dummy2-$quickpkg: dummy3-$quickpkg" >> ${pb}/${branch}/Makefile
- echo "dummy3-$quickpkg: $quickpkg" >> ${pb}/${branch}/Makefile
- else
- echo "quick port directory \"$i\" does not exist -- skipping"
+
+ cd ${pb}
+ if [ "$nobuild" = 0 ]; then
+ mkdir -p ${branch}/distfiles
+ chown -R ${user} ${branch}/distfiles
+
+ cd ${pb}/${branch}/bak
+ rm -rf errors logs packages old-errors
+
+ cd ${pb}/${branch}
+ # need to preserve symlinks for packages but not for errorlogs
+ mv -f packages make.* tarballs/ports.tar.gz bak
+
+ cp -rp errors logs old-errors bak
+ rm -rf errors logs old-errors
+
+ shortdate=$(echo ${date} | sed -e 's/..$//')
+
+ cd ${pb}/${branch}
+ mkdir -p packages/All
+ mkdir -p ${pb}/archive/errorlogs
+ rm -rf ${pb}/archive/errorlogs/e.${branch}.${date} ${pb}/archive/errorlogs/e.${branch}.${shortdate}
+ mkdir -p ${pb}/archive/errorlogs/e.${branch}.${date}
+ ln -sf ${pb}/archive/errorlogs/e.${branch}.${date} ${pb}/${branch}/errors
+ ln -sf e.${branch}.${date} ${pb}/archive/errorlogs/e.${branch}.${shortdate}
+ mkdir -p ${pb}/${branch}/errors/old-errors
+ rm -rf ${pb}/archive/errorlogs/a.${branch}.${date} ${pb}/archive/errorlogs/a.${branch}.${shortdate}
+ mkdir -p ${pb}/archive/errorlogs/a.${branch}.${date}
+ ln -sf ${pb}/archive/errorlogs/a.${branch}.${date} ${pb}/${branch}/logs
+ ln -sf a.${branch}.${date} ${pb}/archive/errorlogs/a.${branch}.${shortdate}
+ chown -RL ${user} errors logs packages
+
+ echo "error logs in ${pb}/archive/errorlogs/e.${branch}.${date}"
+ cp -p ${pb}/cvsdone ${pb}/archive/errorlogs/e.${branch}.${date}/cvsdone
+ cp -p ${pb}/cvsdone ${pb}/archive/errorlogs/a.${branch}.${date}/cvsdone
+ cp -p ${pb}/${branch}/ports/INDEX-${branch} ${pb}/archive/errorlogs/e.${branch}.${date}/INDEX
+ cp -p ${pb}/${branch}/ports/INDEX-${branch} ${pb}/archive/errorlogs/a.${branch}.${date}/INDEX
+
+ if [ "$nodummy" = 0 ]; then
+ for dir in ${dummyports}; do
+ pkgname=$(cd ${pb}/${branch}/ports/$dir; make package-name)${PKGSUFFIX}
+ if [ -f ${pb}/${branch}/tarballs/${pkgname} ]; then
+ cp -p ${pb}/${branch}/tarballs/${pkgname} packages/All
+ else
+ echo "Dummy package ${pkgname} does not exist!"
+ fi
+ done
+ fi
fi
-done
+fi
-cd ${pb}
if [ "$nobuild" = 0 ]; then
-### rm -rf bak/distfiles
-### mv -f distfiles bak
- mkdir -p ${branch}/distfiles
- chown -R ${user} ${branch}/distfiles
- cd ${pb}/${branch}/bak
- rm -rf errors logs packages old-errors
- cd ${pb}/${branch}
- # need to preserve symlinks for packages but not for errorlogs
- mv -f packages make.* tarballs/ports.tar.gz bak
- cp -rp errors logs old-errors bak
- rm -rf errors logs old-errors
-###delete old packages -- use when diskspace is scarce
-# if cd bak/packages/All; then
-# for i in *.tgz; do
-# cp /dev/null $i
-# done
-# fi
- shortdate=$(echo ${date} | sed -e 's/..$//')
- cd ${pb}/${branch}
- mkdir -p packages/All
- mkdir -p ${pb}/archive/errorlogs
- rm -rf ${pb}/archive/errorlogs/e.${branch}.${date} ${pb}/archive/errorlogs/e.${branch}.${shortdate}
- mkdir -p ${pb}/archive/errorlogs/e.${branch}.${date}
- ln -sf ${pb}/archive/errorlogs/e.${branch}.${date} ${pb}/${branch}/errors
- ln -sf e.${branch}.${date} ${pb}/archive/errorlogs/e.${branch}.${shortdate}
- mkdir -p ${pb}/${branch}/errors/old-errors
- rm -rf ${pb}/archive/errorlogs/a.${branch}.${date} ${pb}/archive/errorlogs/a.${branch}.${shortdate}
- mkdir -p ${pb}/archive/errorlogs/a.${branch}.${date}
- ln -sf ${pb}/archive/errorlogs/a.${branch}.${date} ${pb}/${branch}/logs
- ln -sf a.${branch}.${date} ${pb}/archive/errorlogs/a.${branch}.${shortdate}
- chown -RL ${user} errors logs packages
- echo "error logs in ${pb}/archive/errorlogs/e.${branch}.${date}"
- cp -p ${pb}/cvsdone ${pb}/archive/errorlogs/e.${branch}.${date}/cvsdone
- cp -p ${pb}/cvsdone ${pb}/archive/errorlogs/a.${branch}.${date}/cvsdone
- cp -p ${pb}/${branch}/ports/INDEX-${branch} ${pb}/archive/errorlogs/e.${branch}.${date}/INDEX
- cp -p ${pb}/${branch}/ports/INDEX-${branch} ${pb}/archive/errorlogs/a.${branch}.${date}/INDEX
- if [ "$nodummy" = 0 ]; then
- for dir in ${dummyports}; do
- cp -p tarballs/$(cd ${pb}/${branch}/ports/$dir; make package-name).tgz packages/All
- done
- fi
-
find /tmp -name 'make*' -mmin +60 | xargs rm -f
count=$(awk '{sum+=$2}END{print sum+NR/2}' ${pb}/mlist | sed -e 's/\..*$//')
cd ${pb}/${branch}/packages/All
ln -sf ../../Makefile .
+
echo "================================================"
echo "building packages (phase 1)"
echo "================================================"
@@ -412,11 +431,13 @@ if [ "$nobuild" = 0 ]; then
echo $(echo $(ls -1 ${pb}/${branch}/packages/All | wc -l) - 2 | bc) "packages built"
echo $(echo $(du -sk ${pb}/${branch}/packages | awk '{print $1}') / 1024 | bc) "MB of packages"
echo $(echo $(du -sk ${pb}/${branch}/distfiles | awk '{print $1}') / 1024 | bc) "MB of distfiles"
+
cd ${pb}/${branch}
if grep -qE '(ptimeout|pnohang): killing' make.0; then
echo "The following port(s) timed out:"
grep -E '(ptimeout|pnohang): killing' make.0 | sed -e 's/^.*ptimeout:/ptimeout:/' -e 's/^.*pnohang:/pnohang:/'
fi
+
ls -asFlrt ${pb}/${branch}/packages/All > ${pb}/${branch}/logs/ls-lrt-1
cp -rp errors old-errors
cd ${pb}/${branch}/old-errors
@@ -427,7 +448,7 @@ if [ "$nobuild" = 0 ]; then
echo "setting up nodes"
echo "================================================"
for node in $(awk '{print $1}' ${pb}/mlist); do
- setupnode ${pb} ${scripts} ${branch} ${me} ${node} ${md5} &
+ setupnode ${pb} ${scripts} ${branch} ${me} ${node} ${md5} ${scratchdir} &
sleep 2
done
@@ -446,42 +467,48 @@ if [ "$nobuild" = 0 ]; then
echo "ended at $(date)"
phase2end=$(date +%s)
echo "phase 2 took $(date -u -j -r $(($phase2end - $phase2start)) | awk '{print $4}')"
+
rm Makefile
- if [ "$nodummy" = 0 ]; then
- rm ${dummypkgs}
- fi
+# if [ "$nodummy" = 0 ]; then
+# rm ${dummypkgs}
+# fi
+
${pb}/scripts/chopindex ${pb}/${branch}/ports/INDEX-${branch} ${pb}/${branch}/packages > \
${pb}/${branch}/packages/INDEX
echo $(ls -1 ${pb}/${branch}/packages/All | wc -l) "packages built"
echo $(cat ${pb}/${branch}/packages/INDEX | wc -l) "lines in INDEX"
echo $(echo $(du -sk ${pb}/${branch}/packages | awk '{print $1}') / 1024 | bc) "MB of packages"
echo $(echo $(du -sk ${pb}/${branch}/distfiles | awk '{print $1}') / 1024 | bc) "MB of distfiles"
- if [ "$norestr" = 0 ]; then
- echo "deleting restricted ports"
- sh ${pb}/${branch}/restricted.sh
- ${pb}/scripts/chopindex ${pb}/${branch}/ports/INDEX ${pb}/${branch}/packages > \
- ${pb}/${branch}/packages/INDEX
- echo $(ls -1 ${pb}/${branch}/packages/All | wc -l) "packages built"
- echo $(cat ${pb}/${branch}/packages/INDEX | wc -l) "lines in INDEX"
- echo $(echo $(du -sk ${pb}/${branch}/packages | awk '{print $1}') / 1024 | bc) "MB of packages"
- echo $(echo $(du -sk ${pb}/${branch}/distfiles | awk '{print $1}') / 1024 | bc) "MB of distfiles"
- fi
+
+ # Always delete restricted packages/distfiles since they're published on the
+ # website
+ echo "deleting restricted ports"
+ sh ${pb}/${branch}/restricted.sh
+ ${pb}/scripts/chopindex ${pb}/${branch}/ports/INDEX ${pb}/${branch}/packages > \
+ ${pb}/${branch}/packages/INDEX
+ echo $(ls -1 ${pb}/${branch}/packages/All | wc -l) "packages built"
+ echo $(cat ${pb}/${branch}/packages/INDEX | wc -l) "lines in INDEX"
+ echo $(echo $(du -sk ${pb}/${branch}/packages | awk '{print $1}') / 1024 | bc) "MB of packages"
+ echo $(echo $(du -sk ${pb}/${branch}/distfiles | awk '{print $1}') / 1024 | bc) "MB of distfiles"
+
rm -rf ${pb}/${branch}/bad
mkdir -p ${pb}/${branch}/bad
echo "checking packages"
- for i in *.tgz; do
- if ! gzip -t $i; then
+ for i in *${PKGSUFFIX}.; do
+ if ! ${PKGZIPCMD} -t $i; then
echo "Warning: package $i is bad, moving to ${pb}/${branch}/bad"
# the latest link will be left behind...
mv $i ${pb}/${branch}/bad
rm ../*/$i
fi
done
+
cd ${pb}/${branch}
if grep -qE '(ptimeout|pnohang): killing' make.1; then
echo "The following port(s) timed out:"
grep -E '(ptimeout|pnohang): killing' make.1 | sed -e 's/^.*ptimeout:/ptimeout:/' -e 's/^.*pnohang:/pnohang:/'
fi
+
cd ${pb}/${branch}/old-errors
new=""
for i in *.log; do
@@ -496,6 +523,7 @@ if [ "$nobuild" = 0 ]; then
archiveports ${pb} ${branch} &
generatemd5 ${pb} ${branch} &
sleep 5
+
echo "================================================"
echo "new failures"
echo "================================================"
@@ -505,17 +533,19 @@ if [ "$nobuild" = 0 ]; then
echo -n " $(basename $i .log)"
fi
done
+
if cd ${pb}/${branch}/bak/packages/All; then
echo
echo "================================================"
echo "old packages"
echo "================================================"
- for i in *.tgz; do
+ for i in *${PKGSUFFIX}; do
if [ ! -f ${pb}/${branch}/packages/All/$i ]; then
- echo -n " $(basename $i .tgz)"
+ echo -n " $(basename $i ${PKGSUFFIX})"
fi
done
fi
+
if cd ${pb}/${branch}/bak/errors; then
echo
echo "================================================"
@@ -527,20 +557,23 @@ if [ "$nobuild" = 0 ]; then
fi
done
fi
+
echo
echo "================================================"
echo "new packages"
echo "================================================"
cd ${pb}/${branch}/packages/All
- for i in *.tgz; do
+ for i in *${PKGSUFFIX}; do
if [ ! -f ${pb}/${branch}/bak/packages/All/$i ]; then
- echo -n " $(basename $i .tgz)"
+ echo -n " $(basename $i ${PKGSUFFIX})"
fi
done
echo
wait
+
ls -asFlrt ${pb}/${branch}/packages/All > ${pb}/${branch}/logs/ls-lrt
cp -p ${pb}/${branch}/make.[01] ${pb}/${branch}/logs
+
echo "================================================"
echo "copying distfiles"
echo "================================================"
@@ -551,8 +584,10 @@ if [ "$nobuild" = 0 ]; then
${scripts}/dodistfiles ${pb}/${branch}/bak/distfiles
rm -rf ${pb}/${branch}/bak/distfiles/.btmp
rm -f ${pb}/${branch}/bak/distfiles/.done
+
if [ "$branch" != "4-exp" ]; then
- su ${user} -c "${scripts}/cpdistfiles ${branch} > ${pb}/${branch}/cpdistfiles.log 2>&1 </dev/null" &
+ # Currently broken - kk
+ #su ${user} -c "${scripts}/cpdistfiles ${branch} > ${pb}/${branch}/cpdistfiles.log 2>&1 </dev/null" &
if [ "$ftp" = 1 ]; then
echo "ended at $(date)"
echo "================================================"
@@ -562,6 +597,7 @@ if [ "$nobuild" = 0 ]; then
fi
fi
fi
+
endtime=$(date +%s)
echo "================================================"
echo "all done at $(date)"
OpenPOWER on IntegriCloud