msg "Usage: ./all compile-map mapname1 mapname2 mapname3"
msg "For example: ./all compile-map dance xoylent"
fi
- if ! [ -f "netradiant/install/q3map2" ] ; then
- msg "q3map2 needed! Building netradiant..."
- make -C netradiant install/q3map2
+ if ! [ -f "netradiant/build/q3map2" ] ; then
+ msg "q3map2 needed! Building q3map2..."
+ cmake -H'netradiant' -B'netradiant/build' -G'Unix Makefiles' -D'CMAKE_BUILD_TYPE=Release' -DBUILD_RADIANT=OFF -DDOWNLOAD_GAMEPACKS=OFF
+ cmake --build 'netradiant/build' -- q3map2
fi
for mapfile in "$@"; do
mapfile="data/xonotic-maps.pk3dir/maps/$mapfile.map"
if [ ! -f "$mapfile" ] ; then
msg "ERROR, $mapfile not found!"
else
- time misc/tools/xonotic-map-compiler-optionsfile "$mapfile"
+ verbose measure_time misc/tools/xonotic-map-compiler-optionsfile "$mapfile"
fi
done
;;
cleandp=false
cleanqcc=false
cleanqc=false
- compiled0=false
- debug=debug
- snowleopardhack=false
+ compiled0=
+ debug=release # when changing this default, change the description in the zsh autocompletion script
if [ -z "$CC" ]; then
export CC="gcc"
fi
- export CC="$CC -DSUPPORTIPV6"
while :; do
case "$1" in
-0)
compiled0=true
shift
;;
+ -1)
+ compiled0=false
+ shift
+ ;;
-c)
cleand0=true
cleandp=true
cleanqc=true
shift
;;
- -r|-p)
+ -qc)
+ cleanqc=true
+ shift
+ ;;
+ -d|-p|-r)
case "$1" in
+ -d)
+ debug=debug
+ ;;
-p)
debug=profile
;;
;;
esac
done
- if [ -n "$WE_HATE_OUR_USERS" ]; then
- TARGETS="sv-$debug cl-$debug"
- elif [ x"`uname`" = x"Darwin" ]; then
- case "`uname -r`" in
- ?.*)
- TARGETS="sv-$debug cl-$debug sdl-$debug"
- ;;
- *)
- # AGL cannot be compiled on systems with a kernel > 10.x (Snow Leopard)
- snowleopardhack=true
- TARGETS="sv-$debug sdl-$debug"
- ;;
- esac
- export CC="$CC -fno-reorder-blocks -I$PWD/misc/buildfiles/osx/Xonotic.app/Contents/Frameworks/SDL.framework/Headers -F$PWD/misc/buildfiles/osx/Xonotic.app/Contents/Frameworks"
- else
- TARGETS="sv-$debug cl-$debug sdl-$debug"
+
+ TARGETS="sv-$debug sdl-$debug"
+ if [ x"`uname`" = x"Darwin" ]; then
+ export CC="$CC -fno-reorder-blocks"
fi
+
if [ $# -gt 0 ] && [ x"$1" = x"" ]; then
# if we give the command make the arg "", it will surely fail (invalid filename),
# so better handle it as an empty client option
sdl)
TARGETS="$TARGETS sdl-$debug"
;;
- agl)
- TARGETS="$TARGETS cl-$debug"
- if $snowleopardhack; then
- export CC="$CC -arch i386"
- fi
- ;;
- glx|wgl)
- TARGETS="$TARGETS cl-$debug"
- ;;
dedicated)
TARGETS="$TARGETS sv-$debug"
;;
BAD_TARGETS=
fi
fi
+
+ if [ -z "$MAKE" ]; then
+ MAKE=make
+ fi
+
if [ -z "$MAKEFLAGS" ]; then
ncpus=`getconf _NPROCESSORS_ONLN 2>/dev/null || getconf NPROCESSORS_ONLN 2>/dev/null || echo 1`
if [ $ncpus -gt 1 ]; then
if [ -n "$WE_HATE_OUR_USERS" ]; then
MAKEFLAGS="$MAKEFLAGS DP_MAKE_TARGET=mingw"
fi
+ elif echo $MAKEFLAGS | head -c1 | grep -qv -; then # MAKEFLAGS starts with a single letter option
+ MAKEFLAGS=-$(echo $MAKEFLAGS) # echo here and above will trim whitespaces
fi
- # win32: don't rely on jpeg includes
if [ -n "$WE_HATE_OUR_USERS" ]; then
+ # win32: don't rely on jpeg includes
MAKEFLAGS="$MAKEFLAGS LIB_JPEG= CFLAGS_LIBJPEG="
fi
+ if [ x"`uname`" = x"Darwin" ]; then
+ # osx: use SDL2
+ f=$d0/misc/buildfiles/osx/Xonotic.app/Contents/Frameworks
+ MAKEFLAGS="$MAKEFLAGS SDLCONFIG_MACOSXCFLAGS=-I$f/SDL2.framework/Headers SDLCONFIG_MACOSXLIBS=-F$f SDLCONFIG_MACOSXLIBS+=-framework SDLCONFIG_MACOSXLIBS+=SDL2 SDLCONFIG_MACOSXLIBS+=-framework SDLCONFIG_MACOSXLIBS+=Cocoa SDLCONFIG_MACOSXLIBS+=-I$f/SDL2.framework/Headers SDLCONFIG_MACOSXSTATICLIBS=-F$f SDLCONFIG_MACOSXSTATICLIBS+=-framework SDLCONFIG_MACOSXSTATICLIBS+=SDL2 SDLCONFIG_MACOSXSTATICLIBS+=-framework SDLCONFIG_MACOSXSTATICLIBS+=Cocoa SDLCONFIG_MACOSXSTATICLIBS+=-I$f/SDL2.framework/Headers"
+ fi
+
# workaround ARM issue in DP's makefile.inc
case `uname -m` in
x86_64|*86)
MAKEFLAGS="$MAKEFLAGS CFLAGS_SSE= CFLAGS_SSE2="
;;
esac
-
+
if ! verbose $CC misc/tools/conftest.c -o conftest; then
msg ""
msg "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
rm -f conftest
verbose cd "$d0/d0_blind_id"
- if ! $compiled0; then
- # compilation of crypto library failed
- # use binaries then, if we can...
- mkdir -p .libs
- if [ -n "$WE_HATE_OUR_USERS" ]; then
- verbose cp "$d0/misc/buildfiles/win32/libd0_blind_id"-* .libs/
- verbose cp "$d0/misc/buildfiles/win32/libd0_rijndael"-* .libs/
- verbose cp "$d0/misc/buildfiles/win32/libgmp"-* .libs/
- else
- case "`uname`" in
- Linux)
- case `uname -m` in
- x86_64)
- #verbose cp "$d0/misc/builddeps/dp.linux64/lib/libd0_blind_id".* .libs/
- #verbose cp "$d0/misc/builddeps/dp.linux64/lib/libd0_rijndael".* .libs/
- #verbose cp "$d0/misc/builddeps/dp.linux64/lib/libgmp".* .libs/
- # FIXME(whoeverwantsto) get rid of this -I flag, as we just can't do this (the directory has other stuff, e.g. jpeg, inside).
- # FIXME(whoeverwantsto) maybe use the cp commands from above again, and load via dlopen again? Needs evaluation of whether they work.
- export CC="$CC -I../../../../misc/builddeps/dp.linux64/include"
- export CC="$CC -L../../../../misc/builddeps/dp.linux64/lib"
- export CC="$CC -Wl,-rpath,../../../../misc/builddeps/dp.linux64/lib"
- MAKEFLAGS="$MAKEFLAGS DP_LINK_CRYPTO=shared DP_LINK_CRYPTO_RIJNDAEL=shared LIB_CRYPTO=../../../../misc/builddeps/dp.linux64/lib/libd0_blind_id.a LIB_CRYPTO+=../../../../misc/builddeps/dp.linux64/lib/libgmp.a LIB_CRYPTO_RIJNDAEL=../../../../misc/builddeps/dp.linux64/lib/libd0_rijndael.a"
- ;;
- *86)
- #verbose cp "$d0/misc/builddeps/dp.linux32/lib/libd0_blind_id".* .libs/
- #verbose cp "$d0/misc/builddeps/dp.linux32/lib/libd0_rijndael".* .libs/
- #verbose cp "$d0/misc/builddeps/dp.linux32/lib/libgmp".* .libs/
- # FIXME(whoeverwantsto) get rid of this -I flag, as we just can't do this (the directory has other stuff, e.g. jpeg, inside).
- # FIXME(whoeverwantsto) maybe use the cp commands from above again, and load via dlopen again? Needs evaluation of whether they work.
- export CC="$CC -I../../../../misc/builddeps/dp.linux32/include"
- export CC="$CC -L../../../../misc/builddeps/dp.linux32/lib"
- export CC="$CC -Wl,-rpath,../../../../misc/builddeps/dp.linux32/lib"
- MAKEFLAGS="$MAKEFLAGS DP_LINK_CRYPTO=shared DP_LINK_CRYPTO_RIJNDAEL=shared LIB_CRYPTO=../../../../misc/builddeps/dp.linux32/lib/libd0_blind_id.a LIB_CRYPTO+=../../../../misc/builddeps/dp.linux32/lib/libgmp.a LIB_CRYPTO_RIJNDAEL=../../../../misc/builddeps/dp.linux32/lib/libd0_rijndael.a"
- ;;
- *)
- compiled0=true
- ;;
- esac
- ;;
- Darwin)
- verbose cp "$d0/misc/buildfiles/osx/Xonotic.app/Contents/MacOS/libd0_blind_id".* .libs/
- verbose cp "$d0/misc/buildfiles/osx/Xonotic.app/Contents/MacOS/libd0_rijndael".* .libs/
- ;;
- *)
- compiled0=true
- ;;
- esac
- fi
+ if [ -z "$compiled0" ]; then
+ # In doubt, compile.
+ compiled0=true
fi
if $compiled0; then
+ verbose sh autogen.sh
+ verbose ./configure
if $cleand0; then
- if [ -f Makefile ]; then
- verbose make $MAKEFLAGS distclean
- fi
- fi
- if ! [ -f Makefile ]; then
- verbose sh autogen.sh
- verbose ./configure
+ verbose $MAKE $MAKEFLAGS distclean
fi
- verbose make $MAKEFLAGS
+ verbose $MAKE $MAKEFLAGS
fi
verbose cd "$d0/gmqcc"
if $cleanqcc; then
- verbose make $MAKEFLAGS clean
+ verbose $MAKE $MAKEFLAGS clean
fi
if [ -n "$WE_HATE_OUR_USERS" ]; then
- verbose make $MAKEFLAGS gmqcc.exe
+ verbose $MAKE $MAKEFLAGS gmqcc.exe
else
- verbose make $MAKEFLAGS gmqcc
+ verbose $MAKE $MAKEFLAGS gmqcc
fi
+ if [ -n "$MSYSTEM" ]; then
+ DATAMAKE=mingw32-make
+ else
+ DATAMAKE=$MAKE
+ fi
verbose cd "$d0/data/xonotic-data.pk3dir"
if $cleanqc; then
- verbose make QCC="../../../../gmqcc/gmqcc" "$@" $MAKEFLAGS clean
+ verbose ${DATAMAKE} QCC="../../../../gmqcc/gmqcc" "$@" $MAKEFLAGS clean
fi
- verbose make QCC="../../../../gmqcc/gmqcc" "$@" $MAKEFLAGS
+ verbose ${DATAMAKE} QCC="../../../../gmqcc/gmqcc" "$@" $MAKEFLAGS
# 4 levels up: data, xonotic-data, qcsrc, server
verbose cd "$d0/darkplaces"
$ECHO "Warning: invalid empty client, default clients will be used."
fi
if $cleandp; then
- verbose make $MAKEFLAGS clean
+ verbose $MAKE $MAKEFLAGS clean
fi
for T in $TARGETS; do
- verbose make $MAKEFLAGS STRIP=: "$@" "$T"
+ verbose $MAKE $MAKEFLAGS STRIP=: "$@" "$T"
done
for T in $BAD_TARGETS; do
$ECHO "Warning: discarded invalid client $T."
;;
run)
if [ -n "$WE_HATE_OUR_USERS" ]; then
- client=
- export PATH="$d0/misc/buildfiles/win32:$d0/d0_blind_id/.libs:$PATH"
+ case `uname -m` in
+ x86_64)
+ export PATH="$d0/misc/buildfiles/win64:$d0/d0_blind_id/.libs:$PATH"
+ ;;
+ *)
+ export PATH="$d0/misc/buildfiles/win32:$d0/d0_blind_id/.libs:$PATH"
+ ;;
+ esac
elif [ x"`uname`" = x"Darwin" ]; then
export DYLD_LIBRARY_PATH="$d0/misc/buildfiles/osx/Xonotic.app/Contents/MacOS:$d0/d0_blind_id/.libs"
export DYLD_FRAMEWORK_PATH="$d0/misc/buildfiles/osx/Xonotic.app/Contents/Frameworks"
- client=-sdl
else
- export LD_LIBRARY_PATH="$d0/d0_blind_id/.libs"
- client=-sdl
+ export LD_LIBRARY_PATH="$d0/d0_blind_id/.libs${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}"
fi
+
+ client=-sdl
+ USE_RLWRAP=no
case "$1" in
dedicated)
client=-$1
+ USE_RLWRAP=
shift
;;
- sdl|glx|agl)
- USE_RLWRAP=no
- client=-$1
- shift
- ;;
- wgl)
- USE_RLWRAP=no
- client=
+ sdl)
shift
;;
esac
+
if ! [ -x "darkplaces/darkplaces$client" ]; then
if [ -x "darkplaces/darkplaces$client.exe" ]; then
client=$client.exe
fi
set -- "darkplaces/darkplaces$client" -xonotic "$@"
- # if pulseaudio is running: USE IT
- if [ -z "$SDL_AUDIODRIVER" ] && ! [ -n "$WE_HATE_OUR_USERS" ] && ! [ x"`uname`" = x"Darwin" ]; then
- if ps -C pulseaudio >/dev/null; then
- if ldd /usr/lib/libSDL.so 2>/dev/null | grep pulse >/dev/null; then
- export SDL_AUDIODRIVER=pulse
- fi
- fi
- fi
-
binary=$1
if [ x"$USE_GDB" = x"yes" ]; then
set -- catchsegv "$@"
fi
if [ x"$USE_RLWRAP" != x"no" ] && which rlwrap >/dev/null 2>&1; then
- set -- rlwrap -A -g '^quit' -q "\"" -r -S ']' -w 100 "$@"
+ set -- rlwrap -A -g '^quit' -q "\"" -s 10000 -S ']' -w 100 "$@"
fi
rm -f xonotic.core
- "$@" || true
+ verbose measure_time "$@" || true
if [ -f xonotic.core ]; then
if yesno "The program has CRASHED. Do you want to examine the core dump?"; then
gdb "$binary" xonotic.core
fi
;;
help)
- $ECHO " $SELF compile [-c] [-r|-p] [-0] [sdl|glx|wgl|agl|dedicated]"
+ $ECHO " $SELF compile [-c] [-qc] [-d|-p|-r] [-0] [-1] [sdl|dedicated]"
$ECHO " $SELF update-maps"
- $ECHO " $SELF run [sdl|glx|wgl|agl|dedicated] options..."
+ $ECHO " $SELF run [sdl|dedicated] options..."
$ECHO " $SELF compile-map mapname1 mapname2... (e.g. \"./all compile-map dance drain fuse\")"
handled=false
;;
+ serverbench)
+ # TODO(rpolzer): Why does :anticheat: output differ? Total game time differs? Why?
+ trap "rm -rf .serverbench_temp" 0 1 2 3 11 13 15
+ mkdir -p .serverbench_temp
+ verbose "$SELF" run dedicated "$@" -noconfig -userdir .serverbench_temp +exec serverbench.cfg |\
+ tee /dev/stderr |\
+ grep '^:' |\
+ grep -v '^:gamestart:' |\
+ grep -v '^:anticheat:' |\
+ md5sum
+ ;;
*)
handled=false
;;