# HG changeset patch # User Giulio Moro # Date 1463410602 -3600 # Node ID 60ccd1fe5a58502f3073705d602d95dc176030bb # Parent 7fe0d7c54bce01dc744cede4a92bdc1be35b009a Using rsync instead of scp. scp remains as as fallback diff -r 7fe0d7c54bce -r 60ccd1fe5a58 scripts/build_project.sh --- a/scripts/build_project.sh Mon May 16 15:13:20 2016 +0100 +++ b/scripts/build_project.sh Mon May 16 15:56:42 2016 +0100 @@ -6,12 +6,14 @@ # set defaults unless variables are already set [ -z "$BBB_ADDRESS" ] && BBB_ADDRESS="root@192.168.7.2" -[ -z "$BBB_PATH" ] && BBB_PATH="~/BeagleRT" +[ -z "$BBB_BELA_HOME" ] && BBB_BELA_HOME="~/Bela/" [ -z "$RUN_PROJECT" ] && RUN_PROJECT=1 [ -z "$COMMAND_ARGS" ] && COMMAND_ARGS= [ -z "$RUN_IN_FOREGROUND" ] && RUN_IN_FOREGROUND=1 [ -z "$RUN_WITHOUT_SCREEN" ] && RUN_WITHOUT_SCREEN=0 [ -z "$SCREEN_NAME" ] && SCREEN_NAME=Bela +[ -z "$BBB_PROJECT_HOME" ] && BBB_PROJECT_HOME="${BBB_BELA_HOME}/projects/" +[ -x "$BBB_PROJECT_NAME" ] && BBB_PROJECT_NAME="scriptUploadedProject" function usage { @@ -39,13 +41,13 @@ while getopts "b:c:nfFh" opt; do case $opt in - b) BBB_PATH=$OPTARG + b) BBB_BELA_HOME=$OPTARG ;; c) COMMAND_ARGS=$OPTARG ;; - f) RUN_IN_FOREGROUND=0 + f) RUN_IN_FOREGROUND=0 ;; - F) RUN_WITHOUT_SCREEN=1 + F) RUN_WITHOUT_SCREEN=1 ;; n) RUN_PROJECT=0 ;; @@ -85,22 +87,26 @@ ssh $BBB_ADDRESS "date -s '`date`' > /dev/null; screen -X -S '"$SCREEN_NAME"' quit &>/dev/null;" #concatenate arguments to form path. -BBB_SOURCE_PATH= #initially empty, will be filled with input arguments +HOST_SOURCE_PATH= #initially empty, will be filled with input arguments for i in "$@" #parse input arguments do - if [ -d "$1" ] #check if the path is a folder - then #if it is, include all of its files - BBB_SOURCE_PATH+=" ${1}/* " - else - BBB_SOURCE_PATH+=" $1 " - fi + HOST_SOURCE_PATH+=" $1 " shift # Copy new souce files to the board done # Copy new source files to the board echo "Copying new source files to BeagleBone..." -scp $BBB_SOURCE_PATH "$BBB_ADDRESS:$BBB_PATH/source/" +if [ -z `which rsync` ]; +then + #if rsync is not available, brutally clean the destination folder + #and copy over all the files again and recompile them + ssh bbb "make -C $BBB_BELA_HOME sourceclean"; + scp $HOST_SOURCE_PATH "$BBB_ADDRESS:$BBB_BELA_HOME/source/" +else + #rsync --delete makes sure it removes files that are not in the origin folder + rsync -av --delete-after $HOST_SOURCE_PATH "$BBB_ADDRESS:$BBB_BELA_HOME/source/" +fi; if [ $? -ne 0 ] then @@ -112,17 +118,17 @@ if [ $RUN_PROJECT -eq 0 ] then echo "Building project..." - ssh $BBB_ADDRESS "make all -C $BBB_PATH" + ssh $BBB_ADDRESS "make all -C $BBB_BELA_HOME" else echo "Building and running project..." if [ $RUN_WITHOUT_SCREEN -ne 0 ] then - ssh -t $BBB_ADDRESS "cd $BBB_PATH && make all && cd source && ../BeagleRT $COMMAND_ARGS" + ssh -t $BBB_ADDRESS "cd $BBB_BELA_HOME && make all && cd source && ../BeagleRT $COMMAND_ARGS" elif [ $RUN_IN_FOREGROUND -eq 0 ] then - ssh $BBB_ADDRESS "cd $BBB_PATH && make all && cd source && screen -S $SCREEN_NAME -d -m ../BeagleRT $COMMAND_ARGS" + ssh $BBB_ADDRESS "cd $BBB_BELA_HOME && make all && cd source && screen -S $SCREEN_NAME -d -m ../BeagleRT $COMMAND_ARGS" else - ssh -t $BBB_ADDRESS "cd $BBB_PATH && make all && cd source && screen -S $SCREEN_NAME ../BeagleRT $COMMAND_ARGS" + ssh -t $BBB_ADDRESS "cd $BBB_BELA_HOME && make all && cd source && screen -S $SCREEN_NAME ../BeagleRT $COMMAND_ARGS" fi fi