#!/bin/bash # vim: set ts=3 sw=3 noet ft=sh : bash # ----- setup ----- export LC_ALL=C # This will use an overridden value from the command-line if provided, otherwise just use the current date BOT="${BOT:-.}" LOGDATE="${LOGDATE:-$(date +%Y-%m-%d)}" TMPDIR="${TMPDIR:-/tmp}" if [ -z "${1}" ]; then echo 'No recipe target, exiting.' >&2 exit 1 fi mkdir -p -- "$TMPDIR/log/${BOT}/${LOGDATE}" ORIGPATH=$PATH WORK=$PWD RECIPE=$1 BRANCH="" ENTRY_ID="" # ----- read variables from recipe config ----- while read line; do [ -z "${line}" ] && continue KEY="${line% *}" VALUE="${line#* }" rm -f -- "$TMPDIR/vars" if [ "${KEY}" = "PATH" ]; then export PATH=${VALUE}:${ORIGPATH} echo PATH=${VALUE}:${ORIGPATH} >> $TMPDIR/vars else export ${KEY}=${VALUE} echo ${KEY}=${VALUE} >> $TMPDIR/vars fi echo "Setting: ${KEY} ${VALUE}" done < $RECIPE.conf read_link() { TARGET_FILE="$1" cd $(dirname "$TARGET_FILE") TARGET_FILE=$(basename "$TARGET_FILE") while [ -L "$TARGET_FILE" ]; do TARGET_FILE=$(readlink "$TARGET_FILE") cd $(dirname "$TARGET_FILE") TARGET_FILE=$(basename "$TARGET_FILE") done PHYS_DIR=$(pwd -P) RESULT="$PHYS_DIR/$TARGET_FILE" echo "$RESULT" } convert_xmb_assets() { local src_dir=$1 local dst_dir=$2 local scale_icon=$3 local scale_bg=$4 # dots per inch, a value of 90 seems to produce a 64x64 resolution for most icons local density=$5 mkdir -p "$dst_dir" IFS_old=$IFS IFS=$(echo -en "\n\b") for theme in `ls $src_dir`; do if [ -d $src_dir/$theme ] ; then theme=`basename "$theme"` mkdir -p "$dst_dir/$theme/png" cp $src_dir/$theme/*.* $dst_dir/$theme/ for png in `ls $src_dir/$theme/png/*.png -d`; do local name=`basename "$png" .png` local src_file="$src_dir/$theme/src/$name.svg" local is_svg=1 if [ ! -e $src_file ] ; then src_file="$src_dir/$theme/png/$name.png" is_svg= fi local dst_file="$dst_dir/$theme/png/$name.png" if [ ! -e $src_file ] || [ $src_file -nt $dst_file ] ; then local scale_factor=$scale_icon if [ $name = "bg" ] ; then scale_factor=$scale_bg fi if [ $is_svg ] ; then echo convert -background none -density $density "$src_file" -resize $scale_factor "$dst_file" convert -background none -density $density "$src_file" -resize $scale_factor "$dst_file" else echo convert -background none "$src_file" -resize $scale_factor "$dst_file" convert -background none "$src_file" -resize $scale_factor "$dst_file" fi fi done fi done IFS=$IFS_old } if [ "${CORE_JOB}" == "YES" ]; then # ----- set target ----- [[ "${ARM_NEON}" ]] && echo 'ARM NEON opts enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-armv-neon" [[ "${CORTEX_A7}" ]] && echo 'Cortex A7 opts enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-cortexa7" [[ "${CORTEX_A8}" ]] && echo 'Cortex A8 opts enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-cortexa8" [[ "${CORTEX_A9}" ]] && echo 'Cortex A9 opts enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-cortexa9" [[ "${ARM_HARDFLOAT}" ]] && echo 'ARM hardfloat ABI enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-hardfloat" [[ "${ARM_SOFTFLOAT}" ]] && echo 'ARM softfloat ABI enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-softfloat" [[ "${IOS}" ]] && echo 'iOS detected...' . $WORK/libretro-config.sh # ----- create dirs ----- SCRIPT=$(read_link "$0") echo "SCRIPT: $SCRIPT" BASE_DIR=$(dirname "$SCRIPT") if [ -z "$RARCH_DIST_DIR" ]; then RARCH_DIR="$BASE_DIR/dist" RARCH_DIST_DIR="$RARCH_DIR/$DIST_DIR" fi mkdir -v -p "$RARCH_DIST_DIR" if [ "${PLATFORM}" = "android" ]; then if [ -n "$ABI_OVERRIDE" ]; then echo "ABIS-pre: $TARGET_ABIS" echo "OVERRIDE: ${ABI_OVERRIDE}" TARGET_ABIS=${ABI_OVERRIDE} export TARGET_ABIS=${ABI_OVERRIDE} echo "ABIS-post: $TARGET_ABIS" fi IFS=' ' read -ra ABIS <<< "$TARGET_ABIS" for a in "${ABIS[@]}"; do echo $a if [ -d $RARCH_DIST_DIR/${a} ]; then echo "Directory $RARCH_DIST_DIR/${a} already exists, skipping creation..." else mkdir -p $RARCH_DIST_DIR/${a} fi done fi # ----- set compilers ----- if [ "$HOST_CC" ]; then CC="${HOST_CC}-gcc" CXX="${HOST_CC}-g++" CXX11="${HOST_CC}-g++" STRIP="${HOST_CC}-strip" fi TMP_MAKE="${HELPER} ${MAKE}" if [ -z "${TMP_MAKE}" ]; then if uname -s | grep -i MINGW32 > /dev/null 2>&1; then MAKE=mingw32-make else if type gmake > /dev/null 2>&1; then MAKE=gmake else MAKE=make fi fi fi if [ -z "$CC" ]; then if [ $FORMAT_COMPILER_TARGET = "osx" ]; then CC=cc elif uname -s | grep -i MINGW32 > /dev/null 2>&1; then CC=mingw32-gcc else CC=gcc fi fi if [ -z "$CXX" ]; then if [ $FORMAT_COMPILER_TARGET = "osx" ]; then CXX=c++ CXX11=clang++ elif uname -s | grep -i MINGW32 > /dev/null 2>&1; then CXX=mingw32-g++f CXX11=mingw32-g++ else CXX=g++ CXX11=g++ fi fi if [ "${CC}" ] && [ "${CXX}" ]; then COMPILER="CC="\""${CC}"\"" CXX="\""${CXX}"\""" else COMPILER="" fi RESET_FORMAT_COMPILER_TARGET=$FORMAT_COMPILER_TARGET RESET_FORMAT_COMPILER_TARGET_ALT=$FORMAT_COMPILER_TARGET_ALT else SCRIPT=$(read_link "$0") echo "SCRIPT: $SCRIPT" BASE_DIR=$(dirname "$SCRIPT") if [ -z "$RARCH_DIST_DIR" ]; then RARCH_DIR="$BASE_DIR/dist" RARCH_DIST_DIR="$RARCH_DIR/$PLATFORM" fi fi # ----- set jobs ----- JOBS="${JOBS:-6}" # ----- set forceful rebuild on/off ----- FORCE="${FORCE:-NO}" FORCE_RETROARCH_BUILD="${FORCE_RETROARCH_BUILD:-NO}" # ----- set release on/off ----- RELEASE="${RELEASE:-NO}" # ----- set cleanup rules ----- CLEANUP=NO DAY=$(date '+%d') HOUR=$(date '+%H') if [ "${DAY}" = 01 ] && [ "${HOUR}" = 06 ]; then FORCE=YES CLEANUP=NO fi # ----- use to keep track of built cores ----- CORES_BUILT=NO FORCE_ORIG=$FORCE JOBS_ORIG=$JOBS cd "${BASE_DIR}" buildbot_log() { echo "buildbot message: $MESSAGE" MESSAGE=`echo -e $1` if [ -n "$LOGURL" ]; then HASH=`echo -n "$MESSAGE" | openssl sha1 -hmac $SIG | cut -f 2 -d " "` curl --max-time 30 --data "message=$MESSAGE&sign=$HASH" $LOGURL fi } buildbot_handle_message() { RET=$1 ENTRY_ID=$2 CORE_NAME=$3 jobid=$4 ERROR=$5 if [ $RET -eq 0 ]; then if [ -n "$LOGURL" ]; then curl -X POST -d type="finish" -d index="$ENTRY_ID" -d status="done" http://buildserver.libretro.com/build_entry/ fi MESSAGE="$CORE_NAME: [status: done] [$jobid]" else if [ -n "$LOGURL" ]; then HASTE="n/a" if [ -n "$ERROR" ]; then gzip -9fk $ERROR HASTE=`curl -X POST http://paste.libretro.com/ --data-binary @${ERROR}.gz` fi curl -X POST -d type="finish" -d index="$ENTRY_ID" -d status="fail" -d log="$HASTE" http://buildserver.libretro.com/build_entry/ LAST_GOOD_TIME=`curl -f http://buildserver.libretro.com/last_good_build_time/$ENTRY_ID/ 2>/dev/null` if [ -n "$LAST_GOOD_TIME" ]; then LAST_GOOD_TIME="N/A" fi MESSAGE="$CORE_NAME: [status: fail] [$jobid] LOG: $HASTE Last good build: $LAST_GOOD_TIME" else MESSAGE="$CORE_NAME: [status: fail] [$jobid]" fi fi echo "buildbot job: $MESSAGE" buildbot_log "$MESSAGE" # used by Travis-CI to exit immediately if a core build fails, instead of trying to build RA anyways (for static/console builds) if [ $RET -ne 0 ] && [ "$EXIT_ON_ERROR" = "1" ]; then exit 1 fi } build_libretro_generic_makefile() { NAME="$1" DIR="$2" SUBDIR="$3" MAKEFILE="$4" PLATFORM="$5" ARGS="$6" CORES="${7:-$NAME}" ENTRY_ID="" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="$NAME" http://buildserver.libretro.com/build_entry/` fi cd "${DIR}" if [ "${COMMAND}" = "CMAKE" ] && [ "${SUBDIR}" != . ]; then rm -rf -- "$SUBDIR" mkdir -p -- "$SUBDIR" elif [ "${COMMAND}" = "GENERIC_GL" ] && [ "${BUILD_LIBRETRO_GL}" ]; then if [ "${ENABLE_GLES}" ]; then export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-gles" export FORMAT_COMPILER_TARGET_ALT="${FORMAT_COMPILER_TARGET}" else export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-opengl" export FORMAT_COMPILER_TARGET_ALT="${FORMAT_COMPILER_TARGET}" fi fi case "{$NAME}" in *higan_sfc*|*bsnes* ) OUT="out" ;; * ) OUT=. ;; esac cd "${SUBDIR}" eval "set -- $CORES" for i do core="${i%:*}" arg="${i##*:}" if [ "$arg" != "$core" ]; then CORE_ARGS="${ARGS} ${arg}" else CORE_ARGS="${ARGS}" fi CORE_ARGS="${CORE_ARGS#"${CORE_ARGS%%[! ]*}"}" CORENAM="${core}_libretro${FORMAT}${LIBSUFFIX}.${FORMAT_EXT}" if [ "${COMMAND}" = "LEIRADEL" ]; then ARG1="${CORE_ARGS%% *}" LOGFILE="$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_${core}_${PLATFORM}_${ARG1}.log" ORIGNAM="${core}_libretro.${PLATFORM}_${ARG1}.${FORMAT_EXT}" OUTPUT="$RARCH_DIST_DIR/${DIST}/${ARG1}/${CORENAM}" mkdir -p -- "$RARCH_DIST_DIR/${DIST}/${ARG1}" else LOGFILE="$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_${core}_${PLATFORM}.log" ORIGNAM="${CORENAM}" OUTPUT="$RARCH_DIST_DIR/${DIST}/${CORENAM}" fi echo '--------------------------------------------------' | tee "$LOGFILE" cat $TMPDIR/vars | tee -a "$LOGFILE" echo '--------------------------------------------------' | tee -a "$LOGFILE" if [ -z "${NOCLEAN}" ] && [ -f "${MAKEFILE}" ] && [ "${COMMAND}" != "CMAKE" ]; then if [ "${NAME}" = "higan_sfc" ] || [ "${NAME}" = "higan_sfc_balanced" ]; then rm -f obj/*.{o,"${FORMAT_EXT}"} 2>&1 | tee -a "$LOGFILE" rm -f out/*.{o,"${FORMAT_EXT}"} 2>&1 | tee -a "$LOGFILE" elif [ "${COMMAND}" = "LEIRADEL" ]; then eval "set -- ${HELPER} ${MAKE} -f ${MAKEFILE}.${PLATFORM}_${ARG1} platform=${PLATFORM}_${CORE_ARGS} -j${JOBS} clean" echo "CLEANUP CMD: $*" 2>&1 | tee -a "$LOGFILE" "$@" 2>&1 | tee -a "$LOGFILE" else eval "set -- ${HELPER} ${MAKE} -f ${MAKEFILE} platform=${PLATFORM} -j${JOBS} ${CORE_ARGS} clean" echo "CLEANUP CMD: $*" 2>&1 | tee -a "$LOGFILE" "$@" 2>&1 | tee -a "$LOGFILE" fi if [ $? -eq 0 ]; then echo "buildbot job: $jobid ${core} cleanup success!" else echo "buildbot job: $jobid ${core} cleanup failed!" fi fi echo '--------------------------------------------------' | tee -a "$LOGFILE" if [ "${COMMAND}" = "CMAKE" ]; then case "${platform}" in msvc2017_desktop_x86 ) EXTRAARGS="-G\"Visual Studio 15 2017\"" ;; msvc2017_desktop_x64 ) EXTRAARGS="-G\"Visual Studio 15 2017 Win64\"" ;; msvc2010_x86 ) EXTRAARGS="-G\"Visual Studio 10 2010\"" ;; msvc2010_x64 ) EXTRAARGS="-G\"Visual Studio 10 2010 Win64\"" ;; msvc2005_x86 ) EXTRAARGS="-G\"Visual Studio 8 2005\"" ;; msvc2005_x64 ) EXTRAARGS="-G\"Visual Studio 8 2005 Win64\"" ;; msvc2003_x86 ) EXTRAARGS="-G\"Visual Studio 7\"" ;; android ) EXTRAARGS="-DANDROID_PLATFORM=android-${API_LEVEL} \ -DANDROID_ABI=${ABI_OVERRIDE} \ -DCMAKE_TOOLCHAIN_FILE=${NDK_ROOT}/build/cmake/android.toolchain.cmake" ;; 3ds|ctr ) EXTRAARGS="-DCMAKE_TOOLCHAIN_FILE=${WORK}/cmake/ctr.cmake" ;; vita ) EXTRAARGS="-DCMAKE_TOOLCHAIN_FILE=${WORK}/cmake/vita.cmake" ;; psp|psp1 ) EXTRAARGS="-DCMAKE_TOOLCHAIN_FILE=${WORK}/cmake/psp1.cmake" ;; libnx ) EXTRAARGS="-DCMAKE_TOOLCHAIN_FILE=${WORK}/cmake/libnx.cmake" ;; qnx ) EXTRAARGS="-DCMAKE_TOOLCHAIN_FILE=${WORK}/cmake/blackberry.cmake" ;; * ) EXTRAARGS="" ;; esac JOBS_FLAG="-j " if [ "${MAKEFILE}" = "sln" ]; then JOBS_FLAG=-maxcpucount: fi eval "set -- ${EXTRAARGS} \${CORE_ARGS} -DCMAKE_VERBOSE_MAKEFILE=ON" echo "BUILD CMD: ${HELPER} ${CMAKE} $*" 2>&1 | tee -a "$LOGFILE" echo "$@" .. | xargs ${HELPER} ${CMAKE} 2>&1 | tee -a "$LOGFILE" echo "BUILD CMD: ${HELPER} ${CMAKE} --build . --target ${core}_libretro --config Release -- ${JOBS_FLAG} ${JOBS}" 2>&1 | tee -a "$LOGFILE" ${HELPER} ${CMAKE} --build . --target ${core}_libretro --config Release -- ${JOBS_FLAG}${JOBS} 2>&1 | tee -a "$LOGFILE" find . -mindepth 2 -name "${CORENAM}" -exec cp -f "{}" . \; elif [ "${COMMAND}" = "LEIRADEL" ]; then eval "set -- ${HELPER} ${MAKE} -f ${MAKEFILE}.${PLATFORM}_${ARG1} platform=${PLATFORM}_${CORE_ARGS} -j${JOBS}" echo "BUILD CMD: $*" 2>&1 | tee -a "$LOGFILE" "$@" 2>&1 | tee -a "$LOGFILE" elif [ "${NAME}" = "higan_sfc" ] || [ "${NAME}" = "higan_sfc_balanced" ]; then platform="" echo "BUILD CMD: ${HELPER} ${MAKE} -f ${MAKEFILE} -j${JOBS}" ${CORE_ARGS} 2>&1 | tee -a "$LOGFILE" ${HELPER} ${MAKE} -f ${MAKEFILE} -j${JOBS} ${CORE_ARGS} 2>&1 | tee -a "$LOGFILE" else eval "set -- ${HELPER} ${MAKE} -f ${MAKEFILE} platform=${PLATFORM} -j${JOBS} ${CORE_ARGS}" echo "BUILD CMD: $*" 2>&1 | tee -a "$LOGFILE" "$@" 2>&1 | tee -a "$LOGFILE" fi if [ "${MAKEPORTABLE}" == "YES" ]; then echo "BUILD CMD $WORK/retrolink.sh ${OUT}/${CORENAM}" 2>&1 | tee -a "$LOGFILE" $WORK/retrolink.sh ${OUT}/${CORENAM} 2>&1 | tee -a "$LOGFILE" fi if [ "${PLATFORM}" = "windows" ] || [ "${PLATFORM}" = "unix" ]; then ${STRIP:=strip} -s ${OUT}/${CORENAM} elif [ "${PLATFORM}" = "android" -a ! -z "${STRIPPATH+x}" ]; then ${NDK_ROOT}/${STRIPPATH} -s ${OUT}/${CORENAM} fi echo "COPY CMD: cp ${OUT}/${ORIGNAM} ${OUTPUT}" 2>&1 | tee -a "$LOGFILE" cp "${OUT}/${ORIGNAM}" "${OUTPUT}" 2>&1 | tee -a "$LOGFILE" cp "${OUT}/${ORIGNAM}" "${OUTPUT}" RET=$? buildbot_handle_message "$RET" "$ENTRY_ID" "$core" "$jobid" "$LOGFILE" done if [ "${COMMAND}" = "GENERIC_GL" ]; then export FORMAT_COMPILER_TARGET=$RESET_FORMAT_COMPILER_TARGET export FORMAT_COMPILER_TARGET_ALT=$RESET_FORMAT_COMPILER_TARGET_ALT fi ENTRY_ID="" } build_libretro_android_cmake() { NAME="$1" DIR="$2" SUBDIR="$3" MAKEFILE="$4" PLATFORM="$5" ARGS="$6" JOBS_FLAG=-j EXTRAARGS="-DANDROID_PLATFORM=android-${API_LEVEL} -DCMAKE_TOOLCHAIN_FILE=${NDK_ROOT}/build/cmake/android.toolchain.cmake -DANDROID_STL=c++_static" if [ -n "NDK_CCACHE" ]; then EXTRAARGS="$EXTRAARGS -DCMAKE_C_COMPILER_LAUNCHER=${NDK_CCACHE} -DCMAKE_CXX_COMPILER_LAUNCHER=${NDK_CCACHE}" fi ENTRY_ID="" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="$NAME" http://buildserver.libretro.com/build_entry/` fi cd ${DIR} mkdir -p ${SUBDIR} cd ${SUBDIR} CORENAM="${NAME}_libretro${FORMAT}${LIBSUFFIX}.${FORMAT_EXT}" LOGFILE="$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_${NAME}_${PLATFORM}.log" echo '--------------------------------------------------' | tee "$LOGFILE" cat $TMPDIR/vars | tee -a "$LOGFILE" echo '--------------------------------------------------' | tee -a "$LOGFILE" RET=0 for ABI in ${TARGET_ABIS}; do rm -rf ${ABI} mkdir ${ABI} pushd ${ABI} eval "set -- ${EXTRAARGS} \${ARGS} -DCMAKE_VERBOSE_MAKEFILE=OFF -DANDROID_ABI=${ABI}" echo "BUILD CMD: ${CMAKE} $*" 2>&1 | tee -a "$LOGFILE" echo "$@" ../.. | xargs ${CMAKE} 2>&1 | tee -a "$LOGFILE" echo "BUILD CMD: ${CMAKE} --build . --target ${NAME}_libretro --config Release -- ${JOBS_FLAG} ${JOBS} " 2>&1 | tee -a "$LOGFILE" ${CMAKE} --build . --target ${NAME}_libretro --config Release -- ${JOBS_FLAG} ${JOBS} 2>&1 | tee -a "$LOGFILE" COREPATH=$(find . -type f -name ${CORENAM}) if [ -n "${COREPATH}" ]; then echo "COPY CMD: cp ${COREPATH} $RARCH_DIST_DIR/${ABI}/${CORENAM}" 2>&1 | tee -a "$LOGFILE" cp ${COREPATH} $RARCH_DIST_DIR/${ABI}/${CORENAM} 2>&1 | tee -a "$LOGFILE" if [ ! -z "${STRIPPATH+x}" ]; then ${NDK_ROOT}/${STRIPPATH} -s $RARCH_DIST_DIR/${ABI}/${CORENAM} fi else echo "${CORENAM} for ${ABI} not found" 2>&1 | tee -a "$LOGFILE" RET=1 fi popd done buildbot_handle_message "$RET" "$ENTRY_ID" "$NAME" "$jobid" "$LOGFILE" ENTRY_ID="" } build_libretro_generic_jni() { NAME="$1" DIR="$2" SUBDIR="$3" MAKEFILE="$4" PLATFORM="$5" ARGS="$6" CORES="${7:-$NAME}" ENTRY_ID="" LIBNAM="libretro" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="$NAME" http://buildserver.libretro.com/build_entry/` fi cd ${DIR} cd ${SUBDIR} ABILIST=$(sed -n 's/APP_ABI *[:?]*= *//p' Application.mk) if [ -z ${ABILIST} -o "${ABILIST}" == "all" ]; then APPABIS=("${ABIS[@]}") else IFS=' ' read -ra APPABIS <<< "${ABILIST}" fi eval "set -- $CORES" for i do core="${i%:*}" arg="${i##*:}" if [ "$arg" != "$core" ]; then CORE_ARGS="${arg} ${ARGS}" else CORE_ARGS="${ARGS}" fi CORENAM="${core}_libretro${FORMAT}${LIBSUFFIX}.${FORMAT_EXT}" if [ "${NAME}" = "bsnes2014" ] || [ "${NAME}" = "bsnes_mercury" ]; then LIBNAM="libretro_${core}" fi LOGFILE="$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_${core}_${PLATFORM}.log" echo '--------------------------------------------------' | tee "$LOGFILE" cat $TMPDIR/vars | tee -a "$LOGFILE" echo '--------------------------------------------------' | tee -a "$LOGFILE" if [ -z "${NOCLEAN}" ]; then echo "CLEANUP CMD: ${NDK} -j${JOBS} ${CORE_ARGS} clean" 2>&1 | tee -a "$LOGFILE" ${NDK} -j${JOBS} ${CORE_ARGS} clean 2>&1 | tee -a "$LOGFILE" if [ $? -eq 0 ]; then echo "buildbot job: $jobid $a ${core} cleanup success!" else echo "buildbot job: $jobid $a ${core} cleanup failed!" fi fi echo '--------------------------------------------------' | tee -a "$LOGFILE" eval "set -- ${NDK} -j${JOBS} ${CORE_ARGS}" echo "BUILD CMD: $*" 2>&1 | tee -a "$LOGFILE" "$@" 2>&1 | tee -a "$LOGFILE" RET=0 for a in "${APPABIS[@]}"; do if [ -f ../libs/${a}/$LIBNAM.${FORMAT_EXT} ]; then echo "COPY CMD: cp ../libs/${a}/$LIBNAM.${FORMAT_EXT} $RARCH_DIST_DIR/${a}/${CORENAM}" 2>&1 | tee -a "$LOGFILE" cp ../libs/${a}/$LIBNAM.${FORMAT_EXT} $RARCH_DIST_DIR/${a}/${CORENAM} 2>&1 | tee -a "$LOGFILE" else echo "$LIBNAM.${FORMAT_EXT} for ${a} not found" 2>&1 | tee -a "$LOGFILE" RET=1 fi done buildbot_handle_message "$RET" "$ENTRY_ID" "$core" "$jobid" "$LOGFILE" done ENTRY_ID="" } # ----- buildbot ----- echo 'buildbot starting' echo '--------------------------------------------------' echo 'Variables:' echo "CC $CC" echo "CXX $CXX" echo "STRIP $STRIP" echo "DISTDIR $RARCH_DIST_DIR" echo "JOBS $JOBS" echo echo export jobid=$1 # ----- fetch a project ----- echo echo while read line; do eval "set -- \$line" NAME="$1" DIR="$2" URL="$3" GIT_BRANCH="$4" ENABLED="$5" COMMAND="$6" MAKEFILE="$7" SUBDIR="$8" ARGS="" CORES="" if [ -z "${SINGLE_CORE:-}" ]; then CORE="" elif [ "$NAME" != "$SINGLE_CORE" ]; then continue fi shift 8 while [ $# -gt 0 ]; do arg="$1"; shift [ "$arg" = \| ] && break ARGS="${ARGS} ${arg}" done for i do if [ -z "${CORE}" ] || [ "${CORE}" = "${i%:*}" ]; then CORES="${CORES} $i" fi done ARGS="${ARGS# }" ARGS="${ARGS%"${ARGS##*[![:space:]]}"}" [ "${ENABLED}" != "YES" ] && { echo "${NAME} is disabled, skipping"; continue; } echo "buildbot job started at: $(date)" echo echo "buildbot job: $jobid processing $NAME" echo '--------------------------------------------------' echo 'Variables:' echo "URL $URL" echo "ENABLED $ENABLED" echo "COMMAND $COMMAND" echo "MAKEFILE $MAKEFILE" echo "DIR $DIR" echo "SUBDIR $SUBDIR" echo echo BUILD="NO" BUILD_ORIG=$BUILD FORCE_ORIG=$FORCE if [ ! -d "${DIR}/.git" ] || [ "${CLEANUP}" = "YES" ]; then rm -rf -- "$DIR" echo "cloning repo $URL..." git clone --depth=1 -b "$GIT_BRANCH" "$URL" "$DIR" BUILD="YES" else if [ -f "$DIR/.forcebuild" ]; then echo "found $DIR/.forcebuild file, building $NAME" BUILD="YES" fi HEAD="$(git --work-tree="$DIR" --git-dir="$DIR/.git" rev-parse HEAD)" || \ { echo "git directory broken, removing $DIR and skipping $NAME."; \ rm -rf -- "$DIR" && continue; } OLDURL="$(git --work-tree="$DIR" --git-dir="$DIR/.git" config --get remote.origin.url)" if [ "$URL" != "$OLDURL" ]; then rm -rf -- "$DIR" echo "cloning repo $URL..." git clone --depth=1 -b "$GIT_BRANCH" "$URL" "$DIR" BUILD="YES" elif [ -z "${NOCLEAN}" ]; then echo "fetching changes from repo $URL..." git --work-tree="$DIR" --git-dir="$DIR/.git" fetch --depth 1 origin "${GIT_BRANCH}" echo "resetting repo state $URL..." git --work-tree="." --git-dir=".git" -C "$DIR" reset --hard FETCH_HEAD git --work-tree="$DIR" --git-dir="$DIR/.git" clean -xdf -e .libretro-core-recipe fi if [ "$HEAD" = "$(git --work-tree="$DIR" --git-dir="$DIR/.git" rev-parse HEAD)" ] && [ "${BUILD}" != "YES" ]; then BUILD="NO" else BUILD="YES" fi fi if [ -f "$DIR/.libretro-core-recipe" ]; then recipe="$(cat "$DIR/.libretro-core-recipe")" if [ "$line" != "$recipe" ]; then rm -f -- "$DIR/.libretro-core-recipe" echo "$line" > "$DIR/.libretro-core-recipe" BUILD="YES" fi else echo "$line" > "$DIR/.libretro-core-recipe" fi CURRENT_BRANCH="$(git --work-tree="$DIR" --git-dir="$DIR/.git" rev-parse --abbrev-ref HEAD)" if [ "${GIT_BRANCH}" != "${CURRENT_BRANCH}" ] && [ "${TRAVIS:-0}" = "0" ]; then echo "Changing to the branch ${GIT_BRANCH} from ${CURRENT_BRANCH}" git --work-tree="$DIR" --git-dir="$DIR/.git" remote set-branches origin "${GIT_BRANCH}" git --work-tree="$DIR" --git-dir="$DIR/.git" fetch --depth 1 origin "${GIT_BRANCH}" git --work-tree="$DIR" --git-dir="$DIR/.git" checkout "${GIT_BRANCH}" git --work-tree="$DIR" --git-dir="$DIR/.git" branch -D "${CURRENT_BRANCH}" BUILD="YES" fi if git config --file "$DIR/.gitmodules" --name-only --get-regexp path >/dev/null 2>&1; then git --work-tree="." --git-dir=".git" -C "$DIR" submodule update --init --recursive fi if [ "${BUILD}" = "YES" ] || [ "${FORCE}" = "YES" ]; then touch $TMPDIR/built-cores CORES_BUILT=YES echo "buildbot job: building $NAME" case "${COMMAND}" in ANDROID_CMAKE ) build_libretro_android_cmake $NAME $DIR $SUBDIR $MAKEFILE ${FORMAT_COMPILER_TARGET} "${ARGS}" ;; CMAKE|GENERIC|GENERIC_GL ) build_libretro_generic_makefile $NAME $DIR $SUBDIR $MAKEFILE ${FORMAT_COMPILER_TARGET} "${ARGS}" "${CORES}" ;; GENERIC_JNI ) build_libretro_generic_jni $NAME $DIR $SUBDIR $MAKEFILE ${FORMAT_COMPILER_TARGET_ALT} "${ARGS}" "${CORES}" ;; GENERIC_ALT ) build_libretro_generic_makefile $NAME $DIR $SUBDIR $MAKEFILE ${FORMAT_COMPILER_TARGET_ALT} "${ARGS}" ;; LEIRADEL ) build_libretro_generic_makefile $NAME $DIR $SUBDIR $MAKEFILE ${PLATFORM} "${ARGS}" "${CORES}" ;; * ) : ;; esac if [ -z "${NOCLEAN}" ]; then echo "Cleaning repo state after build $URL..." git --work-tree="${BASE_DIR}/${DIR}" --git-dir="${BASE_DIR}/${DIR}/.git" clean -xdf -e .libretro-core-recipe fi else echo "buildbot job: building $NAME up-to-date" fi echo echo "buildbot job finished at: $(date)" cd "${BASE_DIR}" BUILD=$BUILD_ORIG FORCE=$FORCE_ORIG done < $RECIPE buildbot_pull(){ [ -f "$RECIPE.ra" ] || return 0 while read line; do eval "set -- \$line" NAME="$1" DIR="$2" URL="$3" TYPE="$4" ENABLED="$5" PARENTDIR="$6" ARGS="" shift 6 while [ $# -gt 0 ]; do ARGS="${ARGS} ${1}" shift done ARGS="${ARGS# }" ARGS="${ARGS%"${ARGS##*[![:space:]]}"}" if [ "${ENABLED}" = "YES" ] && [ "${TYPE}" = "PROJECT" ] || [ "${TRAVIS:-0}" = "0" ]; then echo "buildbot job: $jobid Processing $NAME" echo echo "NAME: $NAME" echo "DIR: $DIR" echo "PARENT: $PARENTDIR" echo "URL: $URL" echo "REPO TYPE: $TYPE" echo "ENABLED: $ENABLED" if [ -d "${PARENTDIR}/${DIR}/.git" ]; then cd $PARENTDIR cd $DIR if [ -f .forcebuild ]; then echo "found .forcebuild file, building $NAME" BUILD="YES" fi echo "pulling changes from repo $URL... " HEAD="$(git rev-parse HEAD)" git pull if [ "${TYPE}" = "PROJECT" ]; then RADIR=$DIR if [ "$HEAD" = "$(git rev-parse HEAD)" ] && [ "${BUILD}" != "YES" ]; then BUILD="NO" else echo "resetting repo state $URL... " git reset --hard FETCH_HEAD git clean -xdf BUILD="YES" fi fi cd $WORK else echo "cloning repo $URL..." cd $PARENTDIR if [ "${BRANCH}" ] && [ "${NAME}" = "retroarch" ]; then git clone "$URL" "$DIR" cd $DIR git checkout "$BRANCH" else git clone -b "${GIT_BRANCH:-master}" "$URL" "$DIR" --depth=1 fi cd $WORK if [ "${TYPE}" = "PROJECT" ]; then BUILD="YES" RADIR=$DIR fi cd $WORK fi echo echo "RADIR=$RADIR" fi done < $RECIPE.ra cd $WORK } compile_filters() { FILTER="$1" HELPER="$2" MAKE="$3" case "$FILTER" in audio ) FILTERDIR='libretro-common/audio/dsp_filters' ;; video ) FILTERDIR='gfx/video_filters' ;; esac echo "compile $FILTER filters" echo "$FILTER filter BUILD CMD: ${HELPER} ${MAKE}" ( cd "$FILTERDIR"; ${HELPER} ${MAKE} ) if [ $? -eq 0 ]; then echo "buildbot job: $jobid $FILTER filter build success!" else echo "buildbot job: $jobid $FILTER filter: [status: fail]!" fi } if [ "${RA}" = "YES" ]; then echo "buildbot job: $jobid Building Retroarch-$PLATFORM" echo '--------------------------------------------------' echo BUILD="" echo "WORKINGDIR=$PWD" echo "RELEASE=$RELEASE" echo "FORCE=$FORCE_RETROARCH_BUILD" echo "RADIR=$RADIR" echo "BRANCH=$BRANCH" buildbot_pull if [ "${BUILD}" = "YES" ] || [ "${FORCE}" = "YES" ] || [ "${FORCE_RETROARCH_BUILD}" = "YES" ] || [ "${CORES_BUILT}" = "YES" ]; then cd "$RADIR" git clean -xdf echo "WORKINGDIR=$PWD" echo "RADIR=$RADIR" echo "buildbot job: $jobid Building" echo if [ -n "${LOGURL}" ]; then ENTRY_ID="$(curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch" http://buildserver.libretro.com/build_entry/)" fi LOGFILE="$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${RECIPE##*/}.log" fi fi if [ "${PLATFORM}" == "osx" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then cd pkg/apple if [ "${METAL}" == "1" ]; then if [ "${METAL_QT}" == "1" ]; then xcodebuild -project RetroArch_Metal.xcodeproj -target RetroArchQt -configuration Release &> "$LOGFILE" else xcodebuild -project RetroArch_Metal.xcodeproj -target RetroArch -configuration Release &> "$LOGFILE" fi else xcodebuild -project RetroArch.xcodeproj -target RetroArch -configuration Release &> "$LOGFILE" fi RET=$? buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch" http://buildserver.libretro.com/build_entry/` fi if [ "${METAL}" != "1" ]; then xcodebuild -project RetroArch.xcodeproj -target "RetroArch Cg" -configuration Release &> $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_CG_${PLATFORM}.log RET=$? ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_CG_${PLATFORM}.log buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$ERROR" fi cd $WORK/$RADIR echo 'Packaging' fi fi if [ "${PLATFORM}" == "ios" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then cd pkg/apple xcodebuild clean build CODE_SIGN_IDENTITY="" CODE_SIGNING_REQUIRED=NO -project RetroArch_iOS11.xcodeproj -configuration Release &> "$LOGFILE" RET=$? if [ $RET -eq 0 ]; then touch $TMPDIR/built-frontend fi buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" cd $WORK/$RADIR echo 'Packaging' fi fi if [ "${PLATFORM}" == "ios9" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then cd pkg/apple xcodebuild clean build CODE_SIGN_IDENTITY="" CODE_SIGNING_REQUIRED=NO -project RetroArch_iOS9.xcodeproj -configuration Release -target "RetroArch iOS9" &> "$LOGFILE" RET=$? if [ $RET -eq 0 ]; then touch $TMPDIR/built-frontend cd build/Release-iphoneos security unlock-keychain -p buildbot /Users/buildbot/Library/Keychains/login.keychain codesign -fs "buildbot" RetroArch.app fi buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" cd $WORK/$RADIR echo 'Packaging' fi fi if [ "${PLATFORM}" = "android" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" = "YES" -o "${FORCE}" = "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" ]; then #${HELPER} ${MAKE} -f Makefile.griffin shaders-convert-glsl PYTHON3=$PYTHON echo "buildbot job: $jobid processing assets" echo rm -rf pkg/android/phoenix$PKG_EXTRA/assets/assets rm -rf pkg/android/phoenix$PKG_EXTRA/assets/cores rm -rf pkg/android/phoenix$PKG_EXTRA/assets/info rm -rf pkg/android/phoenix$PKG_EXTRA/assets/overlays rm -rf pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_glsl/ rm -rf pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_slang/ rm -rf pkg/android/phoenix$PKG_EXTRA/assets/database rm -rf pkg/android/phoenix$PKG_EXTRA/assets/autoconfig rm -rf pkg/android/phoenix$PKG_EXTRA/assets/cheats rm -rf pkg/android/phoenix$PKG_EXTRA/assets/playlists rm -rf pkg/android/phoenix$PKG_EXTRA/assets/dowloads rm -rf pkg/android/phoenix$PKG_EXTRA/assets/remaps rm -rf pkg/android/phoenix$PKG_EXTRA/assets/system mkdir -p pkg/android/phoenix$PKG_EXTRA/assets mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/ mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/assets mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/assets/xmb/monochrome mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/assets/ozone mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/cores mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/info mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/overlays mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_glsl mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_slang mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/database/cursors mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/database/rdb mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/autoconfig mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/cheats mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/playlists mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/dowloads mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/remaps mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/saves/ mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/states/ mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/system/ mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/filters/video mkdir -p pkg/android/phoenix$PKG_EXTRA/assets/filters/audio # Copy over fonts manually cp -rf media/assets/ozone/bold.ttf pkg/android/phoenix$PKG_EXTRA/assets/assets/ozone cp -rf media/assets/ozone/regular.ttf pkg/android/phoenix$PKG_EXTRA/assets/assets/ozone cp -rf media/assets/glui pkg/android/phoenix$PKG_EXTRA/assets/assets/ cp -rf media/assets/xmb/monochrome pkg/android/phoenix$PKG_EXTRA/assets/assets/xmb cp -rf media/assets/ozone/png pkg/android/phoenix$PKG_EXTRA/assets/assets/ozone cp -rf media/assets/menu_widgets pkg/android/phoenix$PKG_EXTRA/assets/assets/ cp -rf media/assets/s* pkg/android/phoenix$PKG_EXTRA/assets/assets/ cp -rf media/autoconfig/* pkg/android/phoenix$PKG_EXTRA/assets/autoconfig/ cp -rf media/overlays/* pkg/android/phoenix$PKG_EXTRA/assets/overlays/ cp -rf media/shaders_glsl/* pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_glsl/ cp -rf media/shaders_slang/* pkg/android/phoenix$PKG_EXTRA/assets/shaders/shaders_slang/ cp -rf media/libretrodb/cursors/* pkg/android/phoenix$PKG_EXTRA/assets/database/cursors/ cp -rf media/libretrodb/rdb/* pkg/android/phoenix$PKG_EXTRA/assets/database/rdb/ cp -rf libretro-common/audio/dsp_filters/*.dsp pkg/android/phoenix$PKG_EXTRA/assets/filters/audio/ cp -rf gfx/video_filters/*.filt pkg/android/phoenix$PKG_EXTRA/assets/filters/video/ find pkg/android/phoenix$PKG_EXTRA/assets/assets/ -type d -name src -exec rm -rf {} \; #cp -rf media/shaders_glsl $TMPDIR/ touch pkg/android/phoenix$PKG_EXTRA/assets/cheats/.empty-folder touch pkg/android/phoenix$PKG_EXTRA/assets/saves/.empty-folder touch pkg/android/phoenix$PKG_EXTRA/assets/states/.empty-folder touch pkg/android/phoenix$PKG_EXTRA/assets/system/.empty-folder cp -rf $RARCH_DIR/info/* pkg/android/phoenix$PKG_EXTRA/assets/info/ echo "buildbot job: $jobid Building" echo cd pkg/android/phoenix$PKG_EXTRA git reset --hard git pull --no-edit python ./version_increment.py ./gradlew clean assembleRelease | tee -a "$LOGFILE" cp -r build/outputs/apk/normal/release/phoenix-normal-release.apk $RARCH_DIR/retroarch-release.apk | tee -a "$LOGFILE" cp -r build/outputs/apk/normal/release/phoenix-normal-release.apk $RARCH_DIR/retroarch-release.apk cp -r build/outputs/apk/normal/release/phoenix-gold-release.apk $RARCH_DIR/retroarch-gold-release.apk | tee -a "$LOGFILE" cp -r build/outputs/apk/normal/release/phoenix-gold-release.apk $RARCH_DIR/retroarch-gold-release.apk cp -r build/outputs/apk/aarch64/release/phoenix-aarch64-release.apk $RARCH_DIR/retroarch-aarch64-release.apk | tee -a "$LOGFILE" cp -r build/outputs/apk/aarch64/release/phoenix-aarch64-release.apk $RARCH_DIR/retroarch-aarch64-release.apk cp -r build/outputs/apk/ra32/release/phoenix-ra32-release.apk $RARCH_DIR/retroarch-ra32-release.apk | tee -a "$LOGFILE" cp -r build/outputs/apk/ra32/release/phoenix-ra32-release.apk $RARCH_DIR/retroarch-ra32-release.apk RET=$? buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ $RET -eq 0 ]; then touch $TMPDIR/built-frontend fi ENTRY_ID="" fi fi if [ "${PLATFORM}" = "MINGW64" ] || [ "${PLATFORM}" = "MINGW32" ] || [ "${PLATFORM}" = "windows" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" = "YES" -o "${FORCE}" = "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" ]; then compile_filters audio ${HELPER} ${MAKE} compile_filters video ${HELPER} ${MAKE} echo 'configuring...' echo "configure command: $CONFIGURE" ${CONFIGURE} echo 'cleaning up...' echo "CLEANUP CMD: ${HELPER} ${MAKE} ${ARGS} clean" ${HELPER} ${MAKE} ${ARGS} clean rm -rf windows mkdir -p windows if [ $? -eq 0 ]; then echo "buildbot job: $jobid retroarch cleanup success!" else echo "buildbot job: $jobid retroarch cleanup failed!" fi if [ $? -eq 0 ]; then echo "buildbot job: $jobid retroarch configure success!" else echo "buildbot job: $jobid retroarch configure failed!" fi echo 'building...' echo "BUILD CMD: ${HELPER} ${MAKE} -j${JOBS} ${ARGS}" ${HELPER} ${MAKE} -j${JOBS} ${ARGS} 2>&1 | tee -a "$LOGFILE" if [ "${CUSTOM_BUILD}" ]; then "${CUSTOM_BUILD}" 2>&1 | tee -a "$LOGFILE" fi strip -s retroarch.exe cp retroarch.exe.manifest windows/retroarch.exe.manifest 2>/dev/null cp retroarch.exe windows/retroarch.exe | tee -a "$LOGFILE" cp retroarch.exe windows/retroarch.exe status=$? echo "$status" buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ $status -eq 0 ]; then touch $TMPDIR/built-frontend echo buildbot job: $MESSAGE >> "$LOGFILE" ${HELPER} ${MAKE} ${ARGS} clean if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch-debug" http://buildserver.libretro.com/build_entry/` fi echo 'configuring...' echo "configure command: $CONFIGURE" ${CONFIGURE} --enable-drmingw ${HELPER} ${MAKE} -j${JOBS} ${ARGS} DEBUG=1 GL_DEBUG=1 CDROM_DEBUG=1 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log for i in $(seq 3); do for bin in $(ntldd -R *exe | grep -i mingw | cut -d">" -f2 | cut -d" " -f2); do cp -u "$bin" . ; done; done if [ "${CUSTOM_BUILD_DEBUG}" ]; then "${CUSTOM_BUILD_DEBUG}" 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log fi cp retroarch.exe.manifest windows/retroarch_debug.exe.manifest 2>/dev/null cp retroarch.exe windows/retroarch_debug.exe | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log cp *.dll windows/ cp retroarch.exe windows/retroarch_debug.exe (cd windows && windeployqt --release --no-patchqt --no-translations retroarch.exe) (cd windows && for i in $(seq 3); do for bin in $(ntldd -R imageformats/*dll | grep -i mingw | cut -d">" -f2 | cut -d" " -f2); do cp -u "$bin" . ; done; done) status=$? ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$ERROR" if [ $status -eq 0 ]; then MESSAGE="retroarch debug: [status: done] [$jobid]" echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log buildbot_log "$MESSAGE" case "$(uname -s)" in MINGW32*) ;; MINGW64*) echo buildbot job: $MESSAGE >> "$LOGFILE" ${HELPER} ${MAKE} ${ARGS} clean if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch-angle" http://buildserver.libretro.com/build_entry/` fi echo 'configuring...' echo "configure command: $CONFIGURE" ${CONFIGURE} --enable-angle --enable-dynamic_egl ${HELPER} ${MAKE} -j${JOBS} ${ARGS} 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_ANGLE_${PLATFORM}.log for i in $(seq 3); do for bin in $(ntldd -R *exe | grep -i mingw | cut -d">" -f2 | cut -d" " -f2); do cp -u "$bin" . ; done; done strip -s retroarch_angle.exe cp retroarch.exe.manifest windows/retroarch_angle.exe.manifest 2>/dev/null cp retroarch_angle.exe windows/retroarch_angle.exe | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_ANGLE_${PLATFORM}.log cp pkg/windows/x86_64/libEGL.dll windows/ cp pkg/windows/x86_64/libGLESv2.dll windows/ cp *.dll windows/ cp retroarch_angle.exe windows/retroarch_angle.exe (cd windows && windeployqt --release --no-patchqt --no-translations retroarch_angle.exe) (cd windows && for i in $(seq 3); do for bin in $(ntldd -R imageformats/*dll | grep -i mingw | cut -d">" -f2 | cut -d" " -f2); do cp -u "$bin" . ; done; done) status=$? ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_ANGLE_${PLATFORM}.log buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$ERROR" if [ $status -eq 0 ]; then MESSAGE="retroarch ANGLE: [status: done] [$jobid]" echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_ANGLE_${PLATFORM}.log buildbot_log "$MESSAGE" else MESSAGE="retroarch ANGLE: [status: fail] [$jobid]" echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_ANGLE_${PLATFORM}.log fi ;; *) ;; esac else MESSAGE="retroarch-debug: [status: fail] [$jobid]" echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log fi ENTRY_ID="" echo 'Packaging' cp retroarch.cfg retroarch.default.cfg mkdir -p windows/filters mkdir -p windows/filters/video mkdir -p windows/filters/audio mkdir -p windows/saves mkdir -p windows/states mkdir -p windows/system mkdir -p windows/screenshots cp retroarch.default.cfg windows/ cp tools/*.exe windows/ echo -e "[Paths]\nPlugins = ./" > windows/qt.conf cp -rf libretro-common/audio/dsp_filters/*.dll windows/filters/audio cp -rf libretro-common/audio/dsp_filters/*.dsp windows/filters/audio cp -rf gfx/video_filters/*.dll windows/filters/video cp -rf gfx/video_filters/*.filt windows/filters/video else MESSAGE="retroarch: [status: fail] [$jobid]" ENTRY_ID="" echo buildbot job: $MESSAGE >> "$LOGFILE" fi fi fi if [ "${PLATFORM}" = "psp1" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh psp1 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ $RET -eq 0 ]; then touch $TMPDIR/built-frontend fi ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p pkg/psp1/ mkdir -p pkg/psp1/info cp $RARCH_DIST_DIR/../info/*.info pkg/psp1/info/ fi fi if [ "${PLATFORM}" = "ps2" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh ps2 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ $RET -eq 0 ]; then touch $TMPDIR/built-frontend fi ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p pkg/ps2/ mkdir -p pkg/ps2/info cp $RARCH_DIST_DIR/../info/*.info pkg/ps2/info/ fi fi if [ "${PLATFORM}" == "libnx" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh libnx 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p pkg/libnx/retroarch/assets mkdir -p pkg/libnx/retroarch/autoconfig mkdir -p pkg/libnx/retroarch/cheats mkdir -p pkg/libnx/retroarch/database/rdb mkdir -p pkg/libnx/retroarch/info mkdir -p pkg/libnx/retroarch/overlays mkdir -p pkg/libnx/retroarch/remaps mkdir -p pkg/libnx/retroarch/shaders cp -rf media/assets/* pkg/libnx/retroarch/assets cp -rf media/autoconfig/* pkg/libnx/retroarch/autoconfig cp -rf media/libretrodb/rdb/* pkg/libnx/retroarch/database/rdb cp -rf media/overlays/* pkg/libnx/retroarch/overlays cp -rf media/shaders_glsl/* pkg/libnx/retroarch/shaders rm -rf pkg/libnx/retroarch/assets/src pkg/libnx/retroarch/assets/nuklear pkg/libnx/retroarch/assets/branding pkg/libnx/retroarch/assets/wallpapers pkg/libnx/retroarch/assets/zarch cp $RARCH_DIST_DIR/../info/*.info pkg/libnx/retroarch/info fi fi if [ "${PLATFORM}" == "wii" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh wii 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p pkg/wii/build/apps/retroarch-wii mkdir -p pkg/wii/build/apps/retroarch-wii/cheats mkdir -p pkg/wii/build/apps/retroarch-wii/overlays mkdir -p pkg/wii/build/apps/retroarch-wii/info mkdir -p pkg/wii/build/apps/retroarch-wii/filters/audio mkdir -p pkg/wii/build/apps/retroarch-wii/filters/video mkdir -p pkg/wii/build/apps/retroarch-wii/assets cp pkg/wii/icon.png pkg/wii/build/apps/retroarch-wii/ cp pkg/wii/meta.xml pkg/wii/build/apps/retroarch-wii/ cp pkg/wii/.empty pkg/wii/build/apps/retroarch-wii/ cp pkg/wii/*.dol pkg/wii/build/apps/retroarch-wii/ cp $RARCH_DIST_DIR/../info/*.info pkg/wii/build/apps/retroarch-wii/info/ cp -rf media/overlays/wii/* pkg/wii/build/apps/retroarch-wii/overlays/ cp $WORK/$RADIR/libretro-common/audio/dsp_filters/*.dsp pkg/wii/build/apps/retroarch-wii/filters/audio/ cp $WORK/$RADIR/gfx/video_filters/*.filt pkg/wii/build/apps/retroarch-wii/filters/video/ cp -r $WORK/$RADIR/media/assets/rgui pkg/wii/build/apps/retroarch-wii/assets/ fi fi if [ "${PLATFORM}" == "wiiu" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . cp $RARCH_DIST_DIR/../info/*.info . cp ../media/assets/pkg/wiiu/*.png . time sh ./wiiu-cores.sh 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR fi fi if [ "${PLATFORM}" == "ngc" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh ngc 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p pkg/ngc/ mkdir -p pkg/ngc/cheats mkdir -p pkg/ngc/remaps mkdir -p pkg/ngc/overlays cp $RARCH_DIST_DIR/../info/*.info pkg/ cp -rf media/overlays/ngc/* pkg/ngc/overlays fi fi if [ "${PLATFORM}" == "ctr" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh ctr 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" cd $WORK/$RADIR echo "$PWD" echo 'Packaging' cp retroarch.cfg retroarch.default.cfg mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/cores mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/cores/info mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/remaps mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/cheats mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/filters mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/filters/audio mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/filters/video mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/database mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/database/rdb mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/database/cursors mkdir -p $WORK/$RADIR/pkg/ctr/build/retroarch/media cp $WORK/$RADIR/gfx/video_filters/*.filt $WORK/$RADIR/pkg/ctr/build/retroarch/filters/video/ cp $WORK/$RADIR/libretro-common/audio/dsp_filters/*.dsp $WORK/$RADIR/pkg/ctr/build/retroarch/filters/audio/ cp $RARCH_DIST_DIR/../info/*.info $WORK/$RADIR/pkg/ctr/build/retroarch/cores/info/ cp $WORK/$RADIR/media/libretrodb/rdb/*.rdb $WORK/$RADIR/pkg/ctr/build/retroarch/database/rdb/ cp $WORK/$RADIR/media/libretrodb/cursors/*.dbc $WORK/$RADIR/pkg/ctr/build/retroarch/database/cursors/ cp -r $WORK/$RADIR/media/assets/rgui $WORK/$RADIR/pkg/ctr/build/retroarch/media/ convert_xmb_assets $WORK/$RADIR/media/assets/xmb $WORK/$RADIR/pkg/ctr/build/retroarch/media/xmb 64x32! 400x240! 90 fi fi if [ "${PLATFORM}" == "vita" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . cp $RARCH_DIST_DIR/arm/*.a . time sh ./dist-cores.sh vita 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR cp retroarch.cfg retroarch.default.cfg mkdir -p $WORK/$RADIR/pkg/vita/retroarch mkdir -p $WORK/$RADIR/pkg/vita/retroarch/info mkdir -p $WORK/$RADIR/pkg/vita/retroarch/remaps mkdir -p $WORK/$RADIR/pkg/vita/retroarch/cheats mkdir -p $WORK/$RADIR/pkg/vita/retroarch/filters mkdir -p $WORK/$RADIR/pkg/vita/retroarch/filters/audio mkdir -p $WORK/$RADIR/pkg/vita/retroarch/filters/video mkdir -p $WORK/$RADIR/pkg/vita/retroarch/database mkdir -p $WORK/$RADIR/pkg/vita/retroarch/database/rdb mkdir -p $WORK/$RADIR/pkg/vita/retroarch/database/cursors mkdir -p $WORK/$RADIR/pkg/vita/retroarch/assets/glui cp $WORK/$RADIR/gfx/video_filters/*.filt $WORK/$RADIR/pkg/vita/retroarch/filters/video/ cp $WORK/$RADIR/libretro-common/audio/dsp_filters/*.dsp $WORK/$RADIR/pkg/vita/retroarch/filters/audio/ cp $RARCH_DIST_DIR/../info/*.info $WORK/$RADIR/pkg/vita/retroarch/info/ cp $WORK/$RADIR/media/libretrodb/rdb/*.rdb $WORK/$RADIR/pkg/vita/retroarch/database/rdb/ cp $WORK/$RADIR/media/libretrodb/cursors/*.dbc $WORK/$RADIR/pkg/vita/retroarch/database/cursors/ cp $WORK/$RADIR/media/libretrodb/cursors/*.dbc $WORK/$RADIR/pkg/vita/retroarch/database/cursors/ cp -r $WORK/$RADIR/media/assets/rgui $WORK/$RADIR/pkg/vita/retroarch/assets cp -r $WORK/$RADIR/media/assets/glui $WORK/$RADIR/pkg/vita/retroarch/assets cp -r $WORK/$RADIR/media/assets/ozone $WORK/$RADIR/pkg/vita/retroarch/assets convert_xmb_assets $WORK/$RADIR/media/assets/xmb $WORK/$RADIR/pkg/vita/retroarch/assets/xmb 64x64! 960x544! 90 fi fi if [ "${PLATFORM}" == "ps3" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . #time sh ./dist-cores.sh dex-ps3 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_dex.log #RET=${PIPESTATUS[0]} #ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_dex.log #buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch-dex" "$jobid" "$ERROR" #if [ -n "$LOGURL" ]; then # ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch" http://buildserver.libretro.com/build_entry/` #fi time sh ./dist-cores.sh cex-ps3 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_cex.log RET=${PIPESTATUS[0]} ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_cex.log buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch-cex" "$jobid" "$ERROR" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch" http://buildserver.libretro.com/build_entry/` fi #time sh ./dist-cores.sh ode-ps3 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_ode.log #RET=${PIPESTATUS[0]} #ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_ode.log #buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch-ode" "$jobid" "$ERROR" ENTRY_ID="" fi fi if [ "${PLATFORM}" == "psl1ght" ] && [ "${RA}" == "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.a . time sh ./dist-cores.sh psl1ght 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}.log RET=${PIPESTATUS[0]} ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}.log buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch-psl1ght" "$jobid" "$ERROR" if [ -n "$LOGURL" ]; then ENTRY_ID=`curl -X POST -d type="start" -d master_log="$MASTER_LOG_ID" -d platform="$jobid" -d name="retroarch" http://buildserver.libretro.com/build_entry/` fi ENTRY_ID="" fi fi if [ "${PLATFORM}" = "emscripten" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then touch $TMPDIR/built-frontend cd dist-scripts rm *.a cp $RARCH_DIST_DIR/*.bc . echo "BUILD CMD $HELPER ./dist-cores.sh emscripten" &> "$LOGFILE" $HELPER ./dist-cores.sh emscripten 2>&1 | tee -a "$LOGFILE" RET=${PIPESTATUS[0]} buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" ENTRY_ID="" echo 'Packaging' cd $WORK/$RADIR fi fi if [ "${PLATFORM}" = "unix" ] && [ "${RA}" = "YES" ]; then if [ "${BUILD}" = "YES" -o "${FORCE}" = "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" ]; then touch $TMPDIR/built-frontend compile_filters audio ${HELPER} ${MAKE} compile_filters video ${HELPER} ${MAKE} echo 'configuring...' echo "configure command: $CONFIGURE $ARGS" ${CONFIGURE} ${ARGS} echo 'cleaning up...' echo "CLEANUP CMD: ${HELPER} ${MAKE} clean" ${HELPER} ${MAKE} clean if [ $? -eq 0 ]; then echo "buildbot job: $jobid retroarch cleanup success!" else echo "buildbot job: $jobid retroarch cleanup failed!" fi echo 'building...' echo "BUILD CMD: ${HELPER} ${MAKE} -j${JOBS}" ${HELPER} ${MAKE} -j${JOBS} 2>&1 | tee -a "$LOGFILE" status=$? echo "$status" buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE" if [ $status -eq 0 ]; then MESSAGE="retroarch: [status: done] [$jobid]" echo buildbot job: $MESSAGE >> "$LOGFILE" echo "Packaging" else MESSAGE="retroarch: [status: fail] [$jobid]" echo buildbot job: $MESSAGE >> "$LOGFILE" fi fi fi PATH=$ORIGPATH