#!/bin/bash export PATH=/usr/local/bin:$HOME/prefix/bin:$HOME/APM/px4/gcc-arm-none-eabi-4_6-2012q2/bin:$PATH export PYTHONUNBUFFERED=1 export PYTHONPATH=$HOME/APM export PX4_ROOT=$HOME/APM/px4/PX4Firmware cd $HOME/APM || exit 1 test -n "$FORCEBUILD" || { (cd APM && git fetch > /dev/null 2>&1) newtags=$(cd APM && git fetch --tags | wc -l) oldhash=$(cd APM && git rev-parse origin/master) newhash=$(cd APM && git rev-parse HEAD) if [ "$oldhash" = "$newhash" -a "$newtags" = "0" ]; then echo "no change $oldhash $newhash `date`" >> build.log exit 0 fi } ############################ # grab a lock file. Not atomic, but close :) # tries to cope with NFS lock_file() { lck="$1" pid=`cat "$lck" 2> /dev/null` if test -f "$lck" && kill -0 $pid 2> /dev/null; then LOCKAGE=$(($(date +%s) - $(stat -c '%Y' "build.lck"))) test $LOCKAGE -gt 7200 && { echo "old lock file $lck is valid for $pid with age $LOCKAGE seconds" } return 1 fi /bin/rm -f "$lck" echo "$$" > "$lck" return 0 } lock_file build.lck || { exit 1 } #ulimit -m 500000 #ulimit -s 500000 #ulimit -t 1800 #ulimit -v 500000 ( date report() { d="$1" old="$2" new="$3" cat < ../../buildlogs/$d.txt 2>&1 status=$? if [ $status != 0 ]; then report $d $oldhash $newhash fi popd APM/Tools/scripts/frame_sizes.py buildlogs/$d.build > buildlogs/$d.framesizes.txt ( avr-size buildlogs/$d.build/$d.elf avr-nm --size-sort --print-size -C buildlogs/$d.build/$d.elf ) > buildlogs/$d.sizes.txt done mkdir -p "buildlogs/history/$hdate" (cd buildlogs && cp -f *.txt *.flashlog *.tlog *.km[lz] *.gpx *.html *.png "history/$hdate/") echo $githash > "buildlogs/history/$hdate/githash.txt" (cd APM && Tools/scripts/build_parameters.sh) timelimit 4800 APM/Tools/autotest/autotest.py --timeout=5000 > buildlogs/autotest-output.txt 2>&1 ) >> build.log 2>&1