libretro-super/libretro-buildbot-recipe.sh

1608 lines
49 KiB
Bash
Raw Normal View History

#!/bin/bash
# vim: set ts=3 sw=3 noet ft=sh : bash
2016-03-17 23:16:42 -05:00
# ----- setup -----
export LC_ALL=C
2017-10-20 21:24:29 -04:00
# 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}"
2017-10-20 21:24:29 -04:00
ORIGPATH=$PATH
2014-12-17 18:59:08 -05:00
WORK=$PWD
2016-03-17 23:13:41 -05:00
RECIPE=$1
2016-03-22 17:36:43 -05:00
BRANCH=""
ENTRY_ID=""
2016-01-14 18:16:40 -05:00
# ----- 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}
2017-06-04 20:05:51 -05:00
echo PATH=${VALUE}:${ORIGPATH} >> $TMPDIR/vars
else
export ${KEY}=${VALUE}
2017-06-04 20:05:51 -05:00
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()
{
2017-06-04 20:05:51 -05:00
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/
2017-06-04 20:05:51 -05:00
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
}
2016-01-14 18:16:40 -05:00
if [ "${CORE_JOB}" == "YES" ]; then
2016-01-18 12:59:40 -05:00
# ----- set target -----
2018-08-15 00:20:51 -05:00
[[ "${ARM_NEON}" ]] && echo 'ARM NEON opts enabled...' && export FORMAT_COMPILER_TARGET="${FORMAT_COMPILER_TARGET}-armv-neon"
2018-07-27 21:56:42 -04:00
[[ "${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
2016-01-14 18:16:40 -05:00
# ----- 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
2017-06-04 20:21:47 -05:00
if [ -n "$ABI_OVERRIDE" ]; then
echo "ABIS-pre: $TARGET_ABIS"
echo "OVERRIDE: ${ABI_OVERRIDE}"
2017-06-04 20:05:51 -05:00
TARGET_ABIS=${ABI_OVERRIDE}
export TARGET_ABIS=${ABI_OVERRIDE}
echo "ABIS-post: $TARGET_ABIS"
2017-06-04 20:05:51 -05:00
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
2017-12-02 17:38:12 -05:00
mkdir -p $RARCH_DIST_DIR/${a}
fi
done
fi
2016-01-18 12:59:40 -05:00
# ----- set compilers -----
if [ "$HOST_CC" ]; then
CC="${HOST_CC}-gcc"
CXX="${HOST_CC}-g++"
CXX11="${HOST_CC}-g++"
STRIP="${HOST_CC}-strip"
fi
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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++
2017-10-09 18:13:08 -05:00
CXX11=clang++
elif uname -s | grep -i MINGW32 > /dev/null 2>&1; then
2016-05-16 00:12:49 -05:00
CXX=mingw32-g++f
CXX11=mingw32-g++
else
CXX=g++
CXX11=g++
fi
fi
if [ "${CC}" ] && [ "${CXX}" ]; then
2015-10-31 13:31:18 -05:00
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
2016-03-01 23:58:42 -05:00
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
2016-01-18 12:59:40 -05:00
# ----- set jobs -----
JOBS="${JOBS:-6}"
2015-09-11 00:14:34 +01:00
2016-01-18 12:59:40 -05:00
# ----- set forceful rebuild on/off -----
FORCE="${FORCE:-NO}"
FORCE_RETROARCH_BUILD="${FORCE_RETROARCH_BUILD:-NO}"
2015-09-11 00:14:34 +01:00
2016-01-22 12:05:34 -05:00
# ----- set release on/off -----
RELEASE="${RELEASE:-NO}"
2016-01-22 12:05:34 -05:00
2016-01-18 12:59:40 -05:00
# ----- set cleanup rules -----
2015-11-01 13:21:25 -05:00
CLEANUP=NO
DAY=$(date '+%d')
HOUR=$(date '+%H')
if [ "${DAY}" = 01 ] && [ "${HOUR}" = 06 ]; then
FORCE=YES
2015-11-01 13:21:25 -05:00
CLEANUP=NO
fi
2016-01-18 12:59:40 -05:00
# ----- use to keep track of built cores -----
CORES_BUILT=NO
2015-09-11 00:14:34 +01:00
2016-01-14 18:16:40 -05:00
FORCE_ORIG=$FORCE
JOBS_ORIG=$JOBS
2015-08-29 04:24:40 +01:00
cd "${BASE_DIR}"
2015-02-01 14:48:09 -05:00
buildbot_log() {
echo "buildbot message: $MESSAGE"
2015-10-18 14:30:45 -05:00
MESSAGE=`echo -e $1`
2015-03-05 19:50:45 -05:00
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
2019-09-13 11:51:25 +02:00
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
2019-09-13 11:51:25 +02:00
HASTE=`curl -X POST http://paste.libretro.com/ --data-binary @${ERROR}.gz`
fi
2019-09-13 11:51:25 +02:00
curl -X POST -d type="finish" -d index="$ENTRY_ID" -d status="fail" -d log="$HASTE" http://buildserver.libretro.com/build_entry/
2019-09-13 11:51:25 +02:00
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"
2017-10-20 21:24:29 -04:00
# 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
2017-10-20 16:09:26 -04:00
exit 1
fi
2015-02-01 14:48:09 -05:00
}
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
2019-09-13 11:51:25 +02:00
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
2015-10-06 06:29:39 +01:00
fi
case "{$NAME}" in
*higan_sfc*|*bsnes* ) OUT="out" ;;
* ) OUT=. ;;
esac
cd "${SUBDIR}"
eval "set -- $CORES"
for i do
core="${i%:*}"
arg="${i##*:}"
2016-12-08 21:27:12 -05:00
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"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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
2016-05-30 16:54:13 -05:00
fi
2017-06-15 15:36:20 +01:00
echo '--------------------------------------------------' | tee -a "$LOGFILE"
if [ "${COMMAND}" = "CMAKE" ]; then
2019-06-27 17:56:11 +02:00
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" ;;
* ) EXTRAARGS="" ;;
esac
2018-07-20 22:11:06 -07:00
2018-07-21 05:47:58 +01:00
JOBS_FLAG=-j
if [ "${MAKEFILE}" = "sln" ]; then
JOBS_FLAG=-maxcpucount:
fi
2015-10-16 00:24:41 -05:00
2018-07-20 23:16:34 +01:00
eval "set -- ${EXTRAARGS} \${CORE_ARGS} -DCMAKE_VERBOSE_MAKEFILE=ON"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
echo "BUILD CMD: ${CMAKE} $*" 2>&1 | tee -a "$LOGFILE"
echo "$@" .. | xargs ${CMAKE} 2>&1 | tee -a "$LOGFILE"
2018-07-21 05:47:58 +01:00
echo "BUILD CMD: ${CMAKE} --build . --target ${core}_libretro --config Release -- ${JOBS_FLAG}${JOBS}" 2>&1 | tee -a "$LOGFILE"
${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}"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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}"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
echo "BUILD CMD: $*" 2>&1 | tee -a "$LOGFILE"
"$@" 2>&1 | tee -a "$LOGFILE"
2017-09-27 13:42:48 -05:00
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
2015-10-16 00:20:40 -05:00
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}"
2016-07-10 10:57:51 -05:00
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=""
}
2019-06-27 17:56:11 +02:00
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
2019-09-13 11:51:25 +02:00
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/`
2019-06-27 17:56:11 +02:00
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=""
}
2014-12-23 18:11:56 -05:00
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
2019-09-13 11:51:25 +02:00
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}"
2019-10-09 04:11:33 +02:00
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"
2016-12-31 14:31:30 -06:00
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"
2016-03-23 21:46:15 -05:00
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}"
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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=""
}
2016-01-14 18:16:40 -05:00
# ----- buildbot -----
echo 'buildbot starting'
echo '--------------------------------------------------'
echo 'Variables:'
echo "CC $CC"
echo "CXX $CXX"
echo "STRIP $STRIP"
echo "DISTDIR $RARCH_DIST_DIR"
echo "JOBS $JOBS"
2016-01-14 18:16:40 -05:00
echo
echo
2015-10-13 18:18:23 -05:00
export jobid=$1
2015-01-17 00:56:23 -05:00
2016-01-14 18:16:40 -05:00
# ----- 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
2015-03-17 23:46:52 -04:00
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
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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
2019-06-27 17:56:11 +02:00
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}"
2015-03-17 23:46:52 -04:00
BUILD=$BUILD_ORIG
2016-01-14 18:16:40 -05:00
FORCE=$FORCE_ORIG
done < $RECIPE
2016-03-17 23:06:49 -05:00
buildbot_pull(){
[ -f "$RECIPE.ra" ] || return 0
2016-03-17 23:22:20 -05:00
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
2016-01-14 18:32:14 -05:00
echo "buildbot job: $jobid Processing $NAME"
2016-03-17 23:06:49 -05:00
echo
echo "NAME: $NAME"
echo "DIR: $DIR"
echo "PARENT: $PARENTDIR"
echo "URL: $URL"
echo "REPO TYPE: $TYPE"
echo "ENABLED: $ENABLED"
2016-03-17 23:06:49 -05:00
if [ -d "${PARENTDIR}/${DIR}/.git" ]; then
cd $PARENTDIR
cd $DIR
2017-03-15 10:20:56 -07:00
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
2017-03-17 22:19:04 -04:00
2016-03-17 22:26:09 -05:00
if [ "${TYPE}" = "PROJECT" ]; then
RADIR=$DIR
if [ "$HEAD" = "$(git rev-parse HEAD)" ] && [ "${BUILD}" != "YES" ]; then
2016-03-17 22:26:09 -05:00
BUILD="NO"
else
echo "resetting repo state $URL... "
git reset --hard FETCH_HEAD
git clean -xdf
2016-03-17 22:26:09 -05:00
BUILD="YES"
fi
fi
2015-10-21 17:18:38 -05:00
cd $WORK
else
echo "cloning repo $URL..."
cd $PARENTDIR
if [ "${BRANCH}" ] && [ "${NAME}" = "retroarch" ]; then
2017-04-15 18:33:30 -05:00
git clone "$URL" "$DIR"
2017-04-15 18:41:39 -05:00
cd $DIR
2017-04-15 18:33:30 -05:00
git checkout "$BRANCH"
2017-04-15 16:52:36 -05:00
else
git clone -b "${GIT_BRANCH:-master}" "$URL" "$DIR" --depth=1
2016-03-22 17:36:43 -05:00
fi
2016-03-23 12:20:23 -05:00
cd $WORK
2016-03-17 22:26:09 -05:00
if [ "${TYPE}" = "PROJECT" ]; then
BUILD="YES"
RADIR=$DIR
fi
cd $WORK
fi
echo
echo "RADIR=$RADIR"
fi
2016-03-17 23:13:41 -05:00
done < $RECIPE.ra
2016-03-25 16:36:33 -05:00
cd $WORK
2016-03-17 23:06:49 -05:00
}
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=""
2016-03-17 23:06:49 -05:00
echo "WORKINGDIR=$PWD"
echo "RELEASE=$RELEASE"
echo "FORCE=$FORCE_RETROARCH_BUILD"
echo "RADIR=$RADIR"
echo "BRANCH=$BRANCH"
2016-12-31 14:31:30 -06:00
buildbot_pull
2016-03-17 22:35:16 -05:00
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
2019-09-13 11:51:25 +02:00
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
2015-03-09 05:23:17 -07:00
if [ "${PLATFORM}" == "osx" ] && [ "${RA}" == "YES" ]; then
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
2015-10-21 17:18:38 -05:00
cd pkg/apple
2016-01-14 18:43:18 -05:00
2018-09-03 09:06:39 -04:00
if [ "${METAL}" == "1" ]; then
if [ "${METAL_QT}" == "1" ]; then
2019-01-10 23:24:52 -08:00
xcodebuild -project RetroArch_Metal.xcodeproj -target RetroArchQt -configuration Release &> "$LOGFILE"
else
2019-01-10 23:24:52 -08:00
xcodebuild -project RetroArch_Metal.xcodeproj -target RetroArch -configuration Release &> "$LOGFILE"
fi
2018-09-03 09:06:39 -04:00
else
2019-01-10 23:24:52 -08:00
xcodebuild -project RetroArch.xcodeproj -target RetroArch -configuration Release &> "$LOGFILE"
2018-09-03 09:06:39 -04:00
fi
2015-07-03 10:40:27 -04:00
RET=$?
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
2015-03-09 05:23:17 -07:00
if [ -n "$LOGURL" ]; then
2019-09-13 11:51:25 +02:00
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/`
2017-10-20 15:12:03 -04:00
fi
2018-09-03 09:37:29 -04:00
if [ "${METAL}" != "1" ]; then
2019-01-10 23:24:52 -08:00
xcodebuild -project RetroArch.xcodeproj -target "RetroArch Cg" -configuration Release &> $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_CG_${PLATFORM}.log
2015-10-21 11:02:46 -05:00
2018-09-03 09:37:29 -04:00
RET=$?
ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_CG_${PLATFORM}.log
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$ERROR"
fi
2015-10-21 17:18:38 -05:00
cd $WORK/$RADIR
echo 'Packaging'
2015-10-21 17:18:38 -05:00
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" == "ios" ] && [ "${RA}" == "YES" ]; then
2015-10-21 17:18:38 -05:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
2015-10-21 17:18:38 -05:00
cd pkg/apple
2018-04-25 16:09:29 +02:00
xcodebuild clean build CODE_SIGN_IDENTITY="" CODE_SIGNING_REQUIRED=NO -project RetroArch_iOS11.xcodeproj -configuration Release &> "$LOGFILE"
RET=$?
2017-11-20 20:26:06 -05:00
if [ $RET -eq 0 ]; then
touch $TMPDIR/built-frontend
fi
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
2015-06-17 00:28:53 -04:00
ENTRY_ID=""
2015-10-21 17:18:38 -05:00
cd $WORK/$RADIR
2015-04-06 23:57:26 -05:00
echo 'Packaging'
2015-03-24 22:15:09 -04:00
2015-10-21 17:18:38 -05:00
fi
fi
2015-03-24 22:15:09 -04:00
2015-04-16 11:40:42 -05:00
2015-10-28 18:42:23 -05:00
if [ "${PLATFORM}" == "ios9" ] && [ "${RA}" == "YES" ]; then
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
2015-10-28 18:42:23 -05:00
cd pkg/apple
2018-04-25 16:09:29 +02:00
xcodebuild clean build CODE_SIGN_IDENTITY="" CODE_SIGNING_REQUIRED=NO -project RetroArch_iOS9.xcodeproj -configuration Release -target "RetroArch iOS9" &> "$LOGFILE"
2015-10-28 18:42:23 -05:00
RET=$?
if [ $RET -eq 0 ]; then
touch $TMPDIR/built-frontend
2015-10-30 01:23:19 -05:00
cd build/Release-iphoneos
security unlock-keychain -p buildbot /Users/buildbot/Library/Keychains/login.keychain
2015-10-30 01:50:30 -05:00
codesign -fs "buildbot" RetroArch.app
2015-10-28 18:42:23 -05:00
fi
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
ENTRY_ID=""
2015-10-28 18:42:23 -05:00
cd $WORK/$RADIR
echo 'Packaging'
2015-10-28 18:42:23 -05:00
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" = "android" ] && [ "${RA}" = "YES" ]; then
2015-10-28 18:42:23 -05:00
2016-03-17 23:06:49 -05:00
if [ "${BUILD}" = "YES" -o "${FORCE}" = "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" ]; then
2017-04-15 17:12:40 -05:00
#${HELPER} ${MAKE} -f Makefile.griffin shaders-convert-glsl PYTHON3=$PYTHON
2015-02-25 20:32:07 -05:00
2016-03-17 23:06:49 -05:00
echo "buildbot job: $jobid processing assets"
echo
2015-02-25 20:32:07 -05:00
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/
2019-05-05 15:28:54 +02:00
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
2019-05-06 02:09:19 +02:00
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
2019-05-05 15:28:54 +02:00
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
2019-05-05 15:28:54 +02:00
# 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
2019-05-05 15:28:54 +02:00
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/
2019-05-05 15:28:54 +02:00
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 {} \;
2015-11-27 21:04:43 -05:00
2016-01-13 10:22:13 -05:00
2017-04-15 18:08:24 -05:00
#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
2015-10-21 17:18:38 -05:00
cp -rf $RARCH_DIR/info/* pkg/android/phoenix$PKG_EXTRA/assets/info/
2015-10-21 17:18:38 -05:00
2016-01-14 18:32:14 -05:00
echo "buildbot job: $jobid Building"
2015-09-13 17:37:15 +01:00
echo
cd pkg/android/phoenix$PKG_EXTRA
2015-02-25 20:32:07 -05:00
git reset --hard
2019-09-20 06:46:46 +02:00
git pull --no-edit
2019-08-28 05:44:50 +02:00
python ./version_increment.py
2019-07-26 10:41:02 -05:00
./gradlew clean assembleRelease | tee -a "$LOGFILE"
2019-06-27 17:56:11 +02:00
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/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
2016-03-22 17:44:32 -05:00
RET=$?
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
2016-02-23 18:19:16 +01:00
if [ $RET -eq 0 ]; then
touch $TMPDIR/built-frontend
2016-02-09 19:30:13 -05:00
fi
ENTRY_ID=""
2015-02-25 20:32:07 -05:00
fi
fi
2015-10-23 02:22:01 -05:00
if [ "${PLATFORM}" = "MINGW64" ] || [ "${PLATFORM}" = "MINGW32" ] || [ "${PLATFORM}" = "windows" ] && [ "${RA}" = "YES" ]; then
2016-03-17 23:10:46 -05:00
2015-10-21 17:18:38 -05:00
if [ "${BUILD}" = "YES" -o "${FORCE}" = "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" ]; then
compile_filters audio ${HELPER} ${MAKE}
compile_filters video ${HELPER} ${MAKE}
2015-03-10 21:38:12 -05:00
echo 'configuring...'
echo "configure command: $CONFIGURE"
${CONFIGURE}
2015-03-10 21:38:12 -05:00
echo 'cleaning up...'
echo "CLEANUP CMD: ${HELPER} ${MAKE} ${ARGS} clean"
${HELPER} ${MAKE} ${ARGS} clean
2016-12-31 14:31:30 -06:00
2016-06-04 19:56:19 -05:00
rm -rf windows
mkdir -p windows
2015-03-10 21:38:12 -05:00
2015-10-21 17:18:38 -05:00
if [ $? -eq 0 ]; then
echo "buildbot job: $jobid retroarch cleanup success!"
2015-10-21 17:18:38 -05:00
else
echo "buildbot job: $jobid retroarch cleanup failed!"
2015-03-10 21:38:12 -05:00
fi
2015-10-21 17:18:38 -05:00
if [ $? -eq 0 ]; then
echo "buildbot job: $jobid retroarch configure success!"
2015-03-10 21:38:12 -05:00
else
echo "buildbot job: $jobid retroarch configure failed!"
2015-03-10 21:38:12 -05:00
fi
echo 'building...'
echo "BUILD CMD: ${HELPER} ${MAKE} -j${JOBS} ${ARGS}"
${HELPER} ${MAKE} -j${JOBS} ${ARGS} 2>&1 | tee -a "$LOGFILE"
2017-03-14 00:16:57 -07:00
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
if [ "${CUSTOM_BUILD}" ]; then
"${CUSTOM_BUILD}" 2>&1 | tee -a "$LOGFILE"
2017-03-14 00:16:57 -07:00
fi
2015-10-21 17:18:38 -05:00
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
2016-12-31 14:31:30 -06:00
2016-06-04 19:47:00 -05:00
status=$?
echo "$status"
2015-06-17 00:28:53 -04:00
buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
2016-06-04 19:45:36 -05:00
if [ $status -eq 0 ]; then
2016-12-28 11:20:06 -05:00
touch $TMPDIR/built-frontend
echo buildbot job: $MESSAGE >> "$LOGFILE"
2016-06-04 11:27:25 -05:00
${HELPER} ${MAKE} ${ARGS} clean
2016-12-31 14:53:13 -06:00
if [ -n "$LOGURL" ]; then
2019-09-13 11:51:25 +02:00
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...'
2018-12-30 12:19:03 -05:00
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
2016-12-24 16:12:37 -05:00
libretro-buildbot-recipe.sh: Silence shellcheck warnings. In libretro-buildbot-recipe.sh line 148: if [ -z "${HELPER} ${MAKE}" ]; then ^-- SC2157: Argument to -z is always false due to literal strings. In libretro-buildbot-recipe.sh line 348: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 352: echo "CLEANUP CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 372: echo "BUILD CMD: ${CMAKE} $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 380: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 388: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 480: echo "BUILD CMD: $@" 2>&1 | tee -a "$LOGFILE" ^-- SC2145: Argument mixes string and array. Use * or separate argument. In libretro-buildbot-recipe.sh line 626: if git config --file "$DIR/.gitmodules" --name-only --get-regexp path 2>&1 >/dev/null; then ^-- SC2069: The order of the 2>&1 and the redirect matters. The 2>&1 has to be last. In libretro-buildbot-recipe.sh line 1018: if [ -n ${CUSTOM_BUILD} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]]. In libretro-buildbot-recipe.sh line 1045: if [ -n ${CUSTOM_BUILD_DEBUG} ]; then ^-- SC2070: -n doesn't work with unquoted arguments. Quote or use [[ ]].
2018-07-04 06:49:14 -07:00
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
2016-06-04 11:27:25 -05:00
MESSAGE="retroarch debug: [status: done] [$jobid]"
echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log
2017-03-15 07:22:17 -07:00
buildbot_log "$MESSAGE"
else
MESSAGE="retroarch-debug: [status: fail] [$jobid]"
echo buildbot job: $MESSAGE >>$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_DEBUG_${PLATFORM}.log
2016-06-04 11:27:25 -05:00
fi
2017-03-15 07:22:17 -07:00
ENTRY_ID=""
echo 'Packaging'
2015-10-21 17:18:38 -05:00
cp retroarch.cfg retroarch.default.cfg
mkdir -p windows/filters
mkdir -p windows/filters/video
mkdir -p windows/filters/audio
2016-04-30 14:41:08 -05:00
mkdir -p windows/saves
mkdir -p windows/states
mkdir -p windows/system
2016-05-01 12:35:17 -05:00
mkdir -p windows/screenshots
2016-04-30 07:15:44 -05:00
cp retroarch.default.cfg windows/
cp tools/*.exe windows/
2019-05-05 16:11:01 +02:00
echo -e "[Paths]\nPlugins = ./" > windows/qt.conf
2017-01-09 12:32:32 +01:00
cp -rf libretro-common/audio/dsp_filters/*.dll windows/filters/audio
cp -rf libretro-common/audio/dsp_filters/*.dsp windows/filters/audio
2015-10-21 17:18:38 -05:00
cp -rf gfx/video_filters/*.dll windows/filters/video
cp -rf gfx/video_filters/*.filt windows/filters/video
2015-09-13 17:52:57 +01:00
else
MESSAGE="retroarch: [status: fail] [$jobid]"
ENTRY_ID=""
echo buildbot job: $MESSAGE >> "$LOGFILE"
2015-03-10 21:38:12 -05:00
fi
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" = "psp1" ] && [ "${RA}" = "YES" ]; then
2015-09-07 20:39:28 +01:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
2016-12-31 14:31:30 -06:00
2015-09-13 17:54:11 +01:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
2015-09-07 20:39:28 +01:00
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
2016-12-28 11:20:06 -05:00
touch $TMPDIR/built-frontend
2015-09-07 20:39:28 +01:00
fi
ENTRY_ID=""
2015-09-07 20:39:28 +01:00
echo 'Packaging'
2016-01-14 18:32:14 -05:00
2015-10-21 17:18:38 -05:00
cd $WORK/$RADIR
2015-09-07 20:39:28 +01:00
cp retroarch.cfg retroarch.default.cfg
2015-10-21 17:18:38 -05:00
mkdir -p pkg/psp1/
2016-09-04 00:00:22 -05:00
mkdir -p pkg/psp1/info
cp $RARCH_DIST_DIR/../info/*.info pkg/psp1/info/
2015-10-21 17:18:38 -05:00
2015-09-07 20:39:28 +01:00
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
2018-09-28 02:16:38 +02:00
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 .
2018-09-28 02:16:38 +02:00
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'
2018-09-28 02:16:38 +02:00
cd $WORK/$RADIR
cp retroarch.cfg retroarch.default.cfg
2018-09-29 13:07:25 -05:00
mkdir -p pkg/libnx/retroarch/assets
2018-09-29 13:09:52 -05:00
mkdir -p pkg/libnx/retroarch/autoconfig
2018-09-29 13:03:09 -05:00
mkdir -p pkg/libnx/retroarch/cheats
2018-09-29 13:31:24 -05:00
mkdir -p pkg/libnx/retroarch/database/rdb
2018-09-29 13:07:25 -05:00
mkdir -p pkg/libnx/retroarch/info
2018-09-29 13:03:09 -05:00
mkdir -p pkg/libnx/retroarch/overlays
2018-09-29 13:07:25 -05:00
mkdir -p pkg/libnx/retroarch/remaps
2018-09-29 13:03:09 -05:00
mkdir -p pkg/libnx/retroarch/shaders
2018-09-29 13:07:25 -05:00
cp -rf media/assets/* pkg/libnx/retroarch/assets
2018-09-29 13:09:52 -05:00
cp -rf media/autoconfig/* pkg/libnx/retroarch/autoconfig
2018-09-29 13:31:24 -05:00
cp -rf media/libretrodb/rdb/* pkg/libnx/retroarch/database/rdb
2018-09-29 13:03:09 -05:00
cp -rf media/overlays/* pkg/libnx/retroarch/overlays
2018-09-29 13:31:24 -05:00
cp -rf media/shaders_glsl/* pkg/libnx/retroarch/shaders
2018-09-29 13:27:31 -05:00
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
2018-09-29 13:03:09 -05:00
2018-09-28 02:16:38 +02:00
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" == "wii" ] && [ "${RA}" == "YES" ]; then
2016-12-31 14:31:30 -06:00
2015-10-21 17:18:38 -05:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
touch $TMPDIR/built-frontend
2016-03-19 12:32:42 -05:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
2015-10-21 17:18:38 -05:00
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=""
2015-10-21 17:18:38 -05:00
echo 'Packaging'
2016-01-14 18:32:14 -05:00
2016-03-19 12:32:42 -05:00
cd $WORK/$RADIR
2019-05-23 12:13:45 +01:00
2015-10-21 17:18:38 -05:00
cp retroarch.cfg retroarch.default.cfg
2019-05-23 12:13:45 +01:00
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
2019-05-23 12:13:45 +01:00
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/
2019-05-23 12:13:45 +01:00
2015-10-21 17:18:38 -05:00
fi
fi
2016-11-07 15:53:03 -05:00
if [ "${PLATFORM}" == "wiiu" ] && [ "${RA}" == "YES" ]; then
2016-12-31 14:31:30 -06:00
2016-11-07 15:53:03 -05:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
touch $TMPDIR/built-frontend
2016-11-07 15:53:03 -05:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
cp $RARCH_DIST_DIR/../info/*.info .
cp ../media/assets/pkg/wiiu/*.png .
2016-11-07 15:53:03 -05:00
time sh ./wiiu-cores.sh 2>&1 | tee -a "$LOGFILE"
RET=${PIPESTATUS[0]}
buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
ENTRY_ID=""
2016-11-07 15:53:03 -05:00
echo 'Packaging'
2016-11-07 15:53:03 -05:00
cd $WORK/$RADIR
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" == "ngc" ] && [ "${RA}" == "YES" ]; then
2016-12-31 14:31:30 -06:00
2015-09-15 00:25:58 +01:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
touch $TMPDIR/built-frontend
2015-09-15 00:25:58 +01:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
2015-09-15 00:25:58 +01:00
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=""
2015-09-15 00:25:58 +01:00
echo 'Packaging'
2016-01-14 18:32:14 -05:00
2016-03-19 12:32:42 -05:00
cd $WORK/$RADIR
2015-09-15 00:25:58 +01:00
cp retroarch.cfg retroarch.default.cfg
2015-10-21 17:18:38 -05:00
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/
2016-07-16 20:40:01 -05:00
cp -rf media/overlays/ngc/* pkg/ngc/overlays
2015-09-15 00:25:58 +01:00
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" == "ctr" ] && [ "${RA}" == "YES" ]; then
2015-10-19 14:47:52 -05:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
touch $TMPDIR/built-frontend
2015-10-21 17:18:38 -05:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
2015-10-19 14:47:52 -05:00
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=""
2015-10-19 14:47:52 -05:00
cd $WORK/$RADIR
echo "$PWD"
2015-10-19 14:47:52 -05:00
echo 'Packaging'
2016-01-14 18:32:14 -05:00
2015-10-21 17:18:38 -05:00
cp retroarch.cfg retroarch.default.cfg
2015-10-19 14:47:52 -05:00
2018-05-19 19:06:55 -07:00
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
2018-05-19 19:06:55 -07:00
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/
2018-05-19 19:06:55 -07:00
convert_xmb_assets $WORK/$RADIR/media/assets/xmb $WORK/$RADIR/pkg/ctr/build/retroarch/media/xmb 64x32! 400x240! 90
2015-10-19 14:47:52 -05:00
fi
fi
2015-10-21 17:18:38 -05:00
if [ "${PLATFORM}" == "vita" ] && [ "${RA}" == "YES" ]; then
2015-10-21 16:57:27 -05:00
if [ "${BUILD}" == "YES" -o "${FORCE}" == "YES" -o "${FORCE_RETROARCH_BUILD}" == "YES" -o "${CORES_BUILT}" == "YES" ]; then
touch $TMPDIR/built-frontend
2015-10-21 17:18:38 -05:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.a .
cp $RARCH_DIST_DIR/arm/*.a .
2015-10-21 16:57:27 -05:00
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'
2016-01-14 18:32:14 -05:00
2016-03-19 12:32:42 -05:00
cd $WORK/$RADIR
2015-10-21 17:18:38 -05:00
cp retroarch.cfg retroarch.default.cfg
2017-11-13 21:06:40 +01:00
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
2017-11-13 21:06:40 +01:00
2017-11-16 08:30:15 +01:00
convert_xmb_assets $WORK/$RADIR/media/assets/xmb $WORK/$RADIR/pkg/vita/retroarch/assets/xmb 64x64! 960x544! 90
2017-11-13 21:06:40 +01:00
2015-10-21 16:57:27 -05:00
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 .
2019-09-20 06:46:46 +02:00
#time sh ./dist-cores.sh dex-ps3 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_dex.log
2019-09-20 06:46:46 +02:00
#RET=${PIPESTATUS[0]}
#ERROR=$TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_dex.log
#buildbot_handle_message "$RET" "$ENTRY_ID" "retroarch-dex" "$jobid" "$ERROR"
2017-10-20 15:12:03 -04:00
2019-09-20 06:46:46 +02:00
#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
2017-08-07 18:39:22 -05:00
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
2019-09-13 11:51:25 +02:00
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/`
2017-10-20 15:12:03 -04:00
fi
2019-09-20 06:46:46 +02:00
#time sh ./dist-cores.sh ode-ps3 2>&1 | tee -a $TMPDIR/log/${BOT}/${LOGDATE}/${LOGDATE}_RetroArch_${PLATFORM}_ode.log
2019-09-20 06:46:46 +02:00
#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
2016-08-28 19:20:32 -05:00
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
2016-08-28 19:20:32 -05:00
cd dist-scripts
rm *.a
cp $RARCH_DIST_DIR/*.bc .
2016-08-28 19:20:32 -05:00
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=""
2016-08-28 19:20:32 -05:00
echo 'Packaging'
2016-08-28 19:20:32 -05:00
cd $WORK/$RADIR
fi
fi
if [ "${PLATFORM}" = "unix" ] && [ "${RA}" = "YES" ]; then
2016-11-23 21:20:46 -05:00
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}
2016-11-23 21:20:46 -05:00
echo 'configuring...'
2016-11-23 21:20:46 -05:00
echo "configure command: $CONFIGURE $ARGS"
${CONFIGURE} ${ARGS}
echo 'cleaning up...'
2016-11-23 21:20:46 -05:00
echo "CLEANUP CMD: ${HELPER} ${MAKE} clean"
${HELPER} ${MAKE} clean
2016-12-31 14:31:30 -06:00
2016-11-23 21:20:46 -05:00
if [ $? -eq 0 ]; then
echo "buildbot job: $jobid retroarch cleanup success!"
2016-11-23 21:20:46 -05:00
else
echo "buildbot job: $jobid retroarch cleanup failed!"
2016-11-23 21:20:46 -05:00
fi
echo 'building...'
2016-11-23 21:20:46 -05:00
echo "BUILD CMD: ${HELPER} ${MAKE} -j${JOBS}"
${HELPER} ${MAKE} -j${JOBS} 2>&1 | tee -a "$LOGFILE"
2016-12-31 14:31:30 -06:00
2016-11-23 21:20:46 -05:00
status=$?
echo "$status"
2016-11-23 21:20:46 -05:00
buildbot_handle_message "$status" "$ENTRY_ID" "retroarch" "$jobid" "$LOGFILE"
2016-11-23 21:20:46 -05:00
if [ $status -eq 0 ]; then
MESSAGE="retroarch: [status: done] [$jobid]"
echo buildbot job: $MESSAGE >> "$LOGFILE"
2016-11-23 21:20:46 -05:00
echo "Packaging"
else
MESSAGE="retroarch: [status: fail] [$jobid]"
echo buildbot job: $MESSAGE >> "$LOGFILE"
2016-11-23 21:20:46 -05:00
fi
fi
fi
2015-09-07 20:39:28 +01:00
PATH=$ORIGPATH