mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-10 05:26:10 +01:00
126 lines
2.8 KiB
Bash
Executable file
126 lines
2.8 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
#set -u
|
|
set -e -u
|
|
|
|
SEED=""
|
|
RELAY_LOG="../relay/xwrelay.log"
|
|
NDEVS=${NDEVS:-2}
|
|
|
|
usage() {
|
|
echo "usage: $(basename $0) [--seed RANDOM_SEED]"
|
|
exit 0
|
|
}
|
|
|
|
logname() {
|
|
echo ${DIR}/game_${1}.log
|
|
}
|
|
|
|
PID=$$
|
|
echo "**********************************************************************"
|
|
echo "pid: $PID"
|
|
echo "**********************************************************************"
|
|
|
|
while [ $# -gt 0 ]; do
|
|
case $1 in
|
|
--seed)
|
|
[ $# -gt 1 ] || usage
|
|
shift
|
|
SEED=$1
|
|
;;
|
|
*) usage
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
ROOM=ROOM_$PID
|
|
DIR=$(basename $0)_$PID
|
|
DICT=dict.xwd
|
|
|
|
APP=./obj_linux_memdbg/xwords
|
|
COMMON_ARGS="--room $ROOM --curses --robot Eric --game-dict $DICT --quit-after 2"
|
|
for NUM in $(seq 2 $NDEVS); do
|
|
COMMON_ARGS="$COMMON_ARGS --remote-player"
|
|
done
|
|
|
|
mkdir -p $DIR
|
|
|
|
if [ -e $RELAY_LOG ]; then
|
|
echo "removing xwrelay.log"
|
|
rm $RELAY_LOG
|
|
else
|
|
echo "xwrelay.log not found"
|
|
fi
|
|
|
|
# Run once to connect each with the relay
|
|
for NUM in $(seq 1 $((NDEVS))); do
|
|
LOG="$(logname $NUM)"
|
|
ARGS=$COMMON_ARGS
|
|
if [ -n "$SEED" ]; then
|
|
ARGS="$ARGS --seed $((SEED+NUM))"
|
|
fi
|
|
$APP $ARGS --file $DIR/game_${NUM}.xwg > /dev/null 2>>$LOG &
|
|
PID1=$!
|
|
sleep 2
|
|
kill $PID1
|
|
wait $PID1
|
|
done
|
|
|
|
# run apps until done
|
|
NBS=$DIR/nbs
|
|
ZERO_COUNT=0
|
|
while [ $ZERO_COUNT -lt 2 ]; do
|
|
WORK_DONE=""
|
|
for NUM in $(seq 1 $((NDEVS))); do
|
|
LOG="$(logname $NUM)"
|
|
RELAYID=$(./scripts/relayID.sh --short $LOG)
|
|
MSG_COUNT=$(../relay/rq -m $RELAYID 2>/dev/null | sed 's,^.*-- ,,')
|
|
if [ "$MSG_COUNT" -gt 0 ]; then
|
|
WORK_DONE=true
|
|
|
|
ARGS=$COMMON_ARGS
|
|
if [ -n "$SEED" ]; then
|
|
ARGS="$ARGS --seed $((SEED+NUM))"
|
|
fi
|
|
$APP $ARGS --file $DIR/game_${NUM}.xwg --with-nbs $NBS \
|
|
> /dev/null 2>>$LOG &
|
|
PID1=$!
|
|
|
|
../relay/rq -f $RELAYID -b $NBS
|
|
|
|
wait $PID1 || true
|
|
sleep 1 # make it easy to see sequences in the logs
|
|
fi
|
|
sleep 1
|
|
done
|
|
if [ -z "$WORK_DONE" ]; then
|
|
ZERO_COUNT=$((ZERO_COUNT+1))
|
|
fi
|
|
done
|
|
|
|
# Check first if we got to the point where one device recognized that
|
|
# the game's over. Strictly speaking we need to get beyond that, but
|
|
# reaching it is the first step. Debug failure to get that far first.
|
|
ENDED=""
|
|
for NUM in $(seq 1 $((NDEVS))); do
|
|
LOG="$(logname $NUM)"
|
|
if grep -q 'waiting for server to end game' $LOG; then
|
|
ENDED=1
|
|
break;
|
|
fi
|
|
done
|
|
|
|
if [ -z "$ENDED" ]; then
|
|
for NUM in $(seq 1 $((NDEVS))); do
|
|
LOG="$(logname $NUM)"
|
|
if ! grep -q 'all remaining tiles' $LOG; then
|
|
echo "$LOG didn't seem to end correctly"
|
|
mv $RELAY_LOG $DIR
|
|
break
|
|
fi
|
|
done
|
|
fi
|
|
|
|
echo "$0 done (pid: $PID)"
|
|
echo ""
|