1#!/bin/bash 2# 3# android_run_skia: starts the correct skia program on the device, prints the 4# output, and kills the app if interrupted. 5 6SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" 7source $SCRIPT_DIR/utils/android_setup.sh 8source $SCRIPT_DIR/utils/setup_adb.sh 9 10if [ ! -f "${SKIA_OUT}/${APP_ARGS[0]}" ]; 11then 12 echo "Unable to find ${APP_ARGS[0]} executable" 13 exit 1 14fi 15 16verbose "pushing binaries onto the device..." 17adb_push_if_needed "${SKIA_OUT}/${APP_ARGS[0]}" /data/local/tmp 18if [[ -n $RESOURCE_PATH ]]; then 19 verbose "pushing resources onto the device..." 20 adb_push_if_needed "${SCRIPT_DIR}/../../../resources" $RESOURCE_PATH 21fi 22 23if [ $LOGCAT ]; then 24 verbose "clearing the device logs..." 25 $ADB $DEVICE_SERIAL logcat -c; 26fi 27STATUS_FILENAME="/data/local/tmp/.skia_tmp_$(date +%s%N)" 28CMD_FILENAME=".skia_cmd_tmp_$(date +%s%N)" 29echo "/data/local/tmp/${APP_ARGS[*]}; \ 30 echo \$? > ${STATUS_FILENAME}" > ${CMD_FILENAME} 31chmod +x ${CMD_FILENAME} 32verbose "======== To reproduce this run: ========" 33verbose "android_run_skia ${APP_ARGS[*]}" 34verbose "========================================" 35verbose "pushing command file onto the device..." 36$ADB ${DEVICE_SERIAL} push ${CMD_FILENAME} /data/local/tmp 37rm ${CMD_FILENAME} 38verbose "preparing to run ${APP_ARGS[0]} on the device..." 39$ADB ${DEVICE_SERIAL} shell sh /data/local/tmp/${CMD_FILENAME} 40 41if [ -z "$($ADB $DEVICE_SERIAL shell 'if [ -f $STATUS_FILENAME ]; then echo exists; fi')" ]; then 42 if [ $LOGCAT ]; then $ADB $DEVICE_SERIAL logcat -d; fi 43 echo "***********************************************************************" 44 echo "The application terminated unexpectedly and did not produce an exit code" 45 echo "***********************************************************************" 46 exit 1 47fi 48 49EXIT_CODE=`$ADB ${DEVICE_SERIAL} shell cat ${STATUS_FILENAME}` 50$ADB ${DEVICE_SERIAL} shell rm -f ${STATUS_FILENAME} ${CMD_FILENAME} 51 52# check to see if the 'cat' command failed and print errors accordingly 53if [[ ${EXIT_CODE} == *${STATUS_FILENAME}* ]]; then 54 if [ $LOGCAT ]; then $ADB $DEVICE_SERIAL logcat -d; fi 55 echo "***********************************************************************" 56 echo "ADB failed to retrieve the application's exit code" 57 echo "***********************************************************************" 58 exit 1 59fi 60 61echo "EXIT_CODE is ${EXIT_CODE}" 62if [[ "${EXIT_CODE}" != 0* ]]; then 63 if [ $LOGCAT ]; then $ADB $DEVICE_SERIAL logcat -d; fi 64 exit 1 65fi 66exit 0 67