2011-09-30 14:43:24 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#set -u
|
|
|
|
set -e -u
|
|
|
|
|
|
|
|
PID=$$
|
2011-10-01 03:22:25 +02:00
|
|
|
echo "**********************************************************************"
|
2011-09-30 14:43:24 +02:00
|
|
|
echo "pid: $PID"
|
2011-10-01 03:22:25 +02:00
|
|
|
echo "**********************************************************************"
|
2011-09-30 14:43:24 +02:00
|
|
|
|
|
|
|
ROOM=ROOM_$PID
|
|
|
|
DIR=$(basename $0)_$PID
|
|
|
|
DICT=dict.xwd
|
|
|
|
|
|
|
|
APP=./obj_linux_memdbg/xwords
|
|
|
|
COMMON_ARGS="--room $ROOM --curses --robot Eric --remote-player --game-dict $DICT --quit-after 2"
|
|
|
|
|
|
|
|
mkdir -p $DIR
|
|
|
|
|
|
|
|
# Run once to connect each with the relay
|
|
|
|
for NUM in $(seq 1 2); do
|
|
|
|
LOG=$DIR/game_${NUM}.log
|
|
|
|
$APP $COMMON_ARGS --file $DIR/game_${NUM}.xwg > /dev/null 2>$LOG &
|
|
|
|
PID1=$!
|
2011-10-08 03:51:27 +02:00
|
|
|
sleep 4
|
2011-09-30 14:43:24 +02:00
|
|
|
kill $PID1
|
|
|
|
wait $PID1
|
|
|
|
done
|
|
|
|
|
|
|
|
# run apps until done
|
|
|
|
NBS=$DIR/nbs
|
2011-10-01 03:22:25 +02:00
|
|
|
ZERO_COUNT=0
|
2011-10-08 03:51:27 +02:00
|
|
|
while [ $ZERO_COUNT -lt 2 ]; do
|
2011-10-01 03:22:25 +02:00
|
|
|
WORK_DONE=""
|
2011-09-30 14:43:24 +02:00
|
|
|
for NUM in $(seq 1 2); do
|
|
|
|
LOG=$DIR/game_${NUM}.log
|
|
|
|
RELAYID=$(./scripts/relayID.sh --short $LOG)
|
|
|
|
MSG_COUNT=$(../relay/rq -m $RELAYID 2>/dev/null | sed 's,^.*-- ,,')
|
|
|
|
if [ "$MSG_COUNT" -gt 0 ]; then
|
2011-10-08 03:51:27 +02:00
|
|
|
echo "*** $MSG_COUNT messages available ***"
|
2011-10-01 03:22:25 +02:00
|
|
|
WORK_DONE=true
|
|
|
|
|
2011-09-30 14:43:24 +02:00
|
|
|
$APP $COMMON_ARGS --file $DIR/game_${NUM}.xwg \
|
|
|
|
--with-nbs $NBS > /dev/null &
|
|
|
|
PID1=$!
|
|
|
|
|
|
|
|
../relay/rq -f $RELAYID -b $NBS
|
|
|
|
|
2011-10-08 03:51:27 +02:00
|
|
|
wait $PID1 || true
|
2011-09-30 14:43:24 +02:00
|
|
|
else
|
2011-10-01 03:22:25 +02:00
|
|
|
sleep 1
|
2011-09-30 14:43:24 +02:00
|
|
|
fi
|
|
|
|
done
|
2011-10-08 03:51:27 +02:00
|
|
|
if [ -z "$WORK_DONE" ]; then
|
|
|
|
ZERO_COUNT=$((ZERO_COUNT+1))
|
|
|
|
fi
|
2011-09-30 14:43:24 +02:00
|
|
|
done
|
|
|
|
|
|
|
|
echo "$0 done (pid: $PID)"
|