Merge pull request #117 from gscholt/build-all-enhancements
authorFredrik Fornwall <fredrik@fornwall.net>
Tue, 29 Dec 2015 15:39:07 +0000 (16:39 +0100)
committerFredrik Fornwall <fredrik@fornwall.net>
Tue, 29 Dec 2015 15:39:07 +0000 (16:39 +0100)
build-all.sh status messages and ability to resume previous run.

build-all.sh

index 77815b2..942f6ad 100755 (executable)
@@ -5,22 +5,42 @@ set -e -u -o pipefail
 
 BUILDSCRIPT=`dirname $0`/build-package.sh
 BUILDORDER_FILE=$HOME/termux/_buildall/buildorder.txt
+BUILDSTATUS_FILE=$HOME/termux/_buildall/buildstatus.txt
 
 if [ -e $BUILDORDER_FILE ]; then
-       echo "Continuing with existing buildorder file: $BUILDORDER_FILE"
+       echo "Using existing buildorder file: $BUILDORDER_FILE"
 else
        rm -Rf $HOME/termux /data/data $HOME/termux/_buildall
        mkdir -p $HOME/termux/_buildall
        ./buildorder.py > $BUILDORDER_FILE
 fi
+if [ -e $BUILDSTATUS_FILE ]; then
+       echo "Continuing build-all from: $BUILDSTATUS_FILE"
+fi
 
-exec >> $HOME/termux/_buildall/ALL.out 2>> $HOME/termux/_buildall/ALL.err
+exec >  >(tee -a $HOME/termux/_buildall/ALL.out)
+exec 2> >(tee -a $HOME/termux/_buildall/ALL.err >&2)
+trap 'echo failure; echo See: $HOME/termux/_buildall/${package}.err' ERR
 
 for package in `cat $BUILDORDER_FILE`; do
-       echo -n "Building $package... " >> $HOME/termux/_buildall/ALL.out
+       # Check build status (grepping is a bit crude, but it works)
+       if [ -e $BUILDSTATUS_FILE ] && \
+                       grep "^$package\$" $BUILDSTATUS_FILE >/dev/null; then
+               echo "Skipping $package"
+               continue
+       fi
+
+       echo -n "Building $package... "
        BUILD_START=`date "+%s"`
        bash -x $BUILDSCRIPT $package > $HOME/termux/_buildall/${package}.out 2> $HOME/termux/_buildall/${package}.err
        BUILD_END=`date "+%s"`
        BUILD_SECONDS=$(( $BUILD_END - $BUILD_START ))
        echo "done in $BUILD_SECONDS"
+
+       # Update build status
+       echo "$package" >> $BUILDSTATUS_FILE
 done
+
+# Update build status
+rm -f $BUILDSTATUS_FILE
+echo "Finished"