| 1 | #!/bin/bash |
| 2 | # build-all.sh - script to build all packages with a build order specified by buildorder.py |
| 3 | |
| 4 | set -e -u -o pipefail |
| 5 | |
| 6 | # Read settings from .termuxrc if existing |
| 7 | test -f $HOME/.termuxrc && . $HOME/.termuxrc |
| 8 | : ${TERMUX_TOPDIR:="$HOME/.termux-build"} |
| 9 | |
| 10 | BUILDSCRIPT=`dirname $0`/build-package.sh |
| 11 | BUILDORDER_FILE=$TERMUX_TOPDIR/_buildall/buildorder.txt |
| 12 | BUILDSTATUS_FILE=$TERMUX_TOPDIR/_buildall/buildstatus.txt |
| 13 | |
| 14 | if [ -e $BUILDORDER_FILE ]; then |
| 15 | echo "Using existing buildorder file: $BUILDORDER_FILE" |
| 16 | else |
| 17 | mkdir -p $TERMUX_TOPDIR/_buildall |
| 18 | ./scripts/buildorder.py > $BUILDORDER_FILE |
| 19 | fi |
| 20 | if [ -e $BUILDSTATUS_FILE ]; then |
| 21 | echo "Continuing build-all from: $BUILDSTATUS_FILE" |
| 22 | fi |
| 23 | |
| 24 | exec > >(tee -a $TERMUX_TOPDIR/_buildall/ALL.out) |
| 25 | exec 2> >(tee -a $TERMUX_TOPDIR/_buildall/ALL.err >&2) |
| 26 | trap 'echo failure; echo See: $TERMUX_TOPDIR/_buildall/${package}.err' ERR |
| 27 | |
| 28 | for package in `cat $BUILDORDER_FILE`; do |
| 29 | # Check build status (grepping is a bit crude, but it works) |
| 30 | if [ -e $BUILDSTATUS_FILE ] && \ |
| 31 | grep "^$package\$" $BUILDSTATUS_FILE >/dev/null; then |
| 32 | echo "Skipping $package" |
| 33 | continue |
| 34 | fi |
| 35 | |
| 36 | echo -n "Building $package... " |
| 37 | BUILD_START=`date "+%s"` |
| 38 | bash -x $BUILDSCRIPT $package > $TERMUX_TOPDIR/_buildall/${package}.out 2> $TERMUX_TOPDIR/_buildall/${package}.err |
| 39 | BUILD_END=`date "+%s"` |
| 40 | BUILD_SECONDS=$(( $BUILD_END - $BUILD_START )) |
| 41 | echo "done in $BUILD_SECONDS" |
| 42 | |
| 43 | # Update build status |
| 44 | echo "$package" >> $BUILDSTATUS_FILE |
| 45 | done |
| 46 | |
| 47 | # Update build status |
| 48 | rm -f $BUILDSTATUS_FILE |
| 49 | echo "Finished" |