Commit | Line | Data |
---|---|---|
59f0d218 FF |
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 | ||
a0057943 FF |
6 | # Read settings from .termuxrc if existing |
7 | test -f $HOME/.termuxrc && . $HOME/.termuxrc | |
8 | : ${TERMUX_TOPDIR:="$HOME/.termux-build"} | |
75a13474 | 9 | : ${TERMUX_ARCH:="aarch64"} |
63091e18 | 10 | : ${TERMUX_DEBUG:=""} |
75a13474 FF |
11 | |
12 | _show_usage () { | |
63091e18 HG |
13 | echo "Usage: ./build-all.sh [-a ARCH] [-d]" |
14 | echo "Build all packages." | |
15 | echo " -a The architecture to build for: aarch64(default), arm, i686, x86_64 or all." | |
16 | echo " -d Build with debug symbols." | |
75a13474 FF |
17 | exit 1 |
18 | } | |
19 | ||
20 | while getopts :a:hdDs option; do | |
21 | case "$option" in | |
22 | a) TERMUX_ARCH="$OPTARG";; | |
63091e18 | 23 | d) TERMUX_DEBUG='-d';; |
75a13474 FF |
24 | h) _show_usage;; |
25 | esac | |
26 | done | |
27 | shift $((OPTIND-1)) | |
28 | if [ "$#" -ne 0 ]; then _show_usage; fi | |
29 | ||
30 | if [[ ! "$TERMUX_ARCH" =~ ^(aarch64|arm|i686|x86_64)$ ]]; then | |
31 | echo "ERROR: Invalid arch '$TERMUX_ARCH'" 1>&2 | |
32 | exit 1 | |
33 | fi | |
a0057943 | 34 | |
59f0d218 | 35 | BUILDSCRIPT=`dirname $0`/build-package.sh |
75a13474 FF |
36 | BUILDALL_DIR=$TERMUX_TOPDIR/_buildall-$TERMUX_ARCH |
37 | BUILDORDER_FILE=$BUILDALL_DIR/buildorder.txt | |
38 | BUILDSTATUS_FILE=$BUILDALL_DIR/buildstatus.txt | |
59f0d218 FF |
39 | |
40 | if [ -e $BUILDORDER_FILE ]; then | |
12622a95 | 41 | echo "Using existing buildorder file: $BUILDORDER_FILE" |
59f0d218 | 42 | else |
75a13474 | 43 | mkdir -p $BUILDALL_DIR |
658bba67 | 44 | ./scripts/buildorder.py > $BUILDORDER_FILE |
59f0d218 | 45 | fi |
12622a95 GS |
46 | if [ -e $BUILDSTATUS_FILE ]; then |
47 | echo "Continuing build-all from: $BUILDSTATUS_FILE" | |
48 | fi | |
59f0d218 | 49 | |
75a13474 FF |
50 | exec > >(tee -a $BUILDALL_DIR/ALL.out) |
51 | exec 2> >(tee -a $BUILDALL_DIR/ALL.err >&2) | |
52 | trap "echo ERROR: See $BUILDALL_DIR/\${package}.err" ERR | |
59f0d218 | 53 | |
02764a91 FF |
54 | for package_path in `cat $BUILDORDER_FILE`; do |
55 | package=`basename $package_path` | |
12622a95 | 56 | # Check build status (grepping is a bit crude, but it works) |
75a13474 | 57 | if [ -e $BUILDSTATUS_FILE ] && grep "^$package\$" $BUILDSTATUS_FILE >/dev/null; then |
12622a95 GS |
58 | echo "Skipping $package" |
59 | continue | |
60 | fi | |
61 | ||
62 | echo -n "Building $package... " | |
59f0d218 | 63 | BUILD_START=`date "+%s"` |
63091e18 | 64 | bash -x $BUILDSCRIPT -a $TERMUX_ARCH -s $TERMUX_DEBUG $package \ |
75a13474 | 65 | > $BUILDALL_DIR/${package}.out 2> $BUILDALL_DIR/${package}.err |
59f0d218 FF |
66 | BUILD_END=`date "+%s"` |
67 | BUILD_SECONDS=$(( $BUILD_END - $BUILD_START )) | |
68 | echo "done in $BUILD_SECONDS" | |
12622a95 GS |
69 | |
70 | # Update build status | |
71 | echo "$package" >> $BUILDSTATUS_FILE | |
59f0d218 | 72 | done |
12622a95 GS |
73 | |
74 | # Update build status | |
75 | rm -f $BUILDSTATUS_FILE | |
76 | echo "Finished" |