2009-09-26 15:48:58 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
HOSTNAME=localhost
|
|
|
|
ROOM_ADD=""
|
|
|
|
NGAMES=10
|
|
|
|
PORT=10999
|
|
|
|
DBUG=0
|
2010-03-28 18:09:27 +02:00
|
|
|
HOW_LONG=360
|
2009-09-26 15:48:58 +02:00
|
|
|
DICT=dict.xwd
|
|
|
|
|
2010-03-28 18:09:27 +02:00
|
|
|
RUN_NAME=$(basename $0)_$$
|
|
|
|
LOG_DIR=/tmp/${RUN_NAME}_LOG
|
|
|
|
mkdir -p ${LOG_DIR}
|
|
|
|
|
|
|
|
|
2009-09-26 15:48:58 +02:00
|
|
|
usage() {
|
|
|
|
[ -n "$1" ] && echo "$1" >&2
|
|
|
|
echo "usage: $0 \\" >&2
|
|
|
|
echo " [--relay <hostname>] # default: $HOSTNAME \\" >&2
|
|
|
|
echo " [--port <port>] # default: $PORT \\" >&2
|
|
|
|
echo " [--room <anything>] # appended to room; default: $ROOM_ADD \\" >&2
|
|
|
|
echo " [--games <0..N>] # run how many games; default: $NGAMES \\" >&2
|
|
|
|
echo " [--dict <dict.xwd>] # use what dict; default: $DICT \\" >&2
|
|
|
|
echo " [--delay <nSeconds>] # restart after nSeconds; default: $HOW_LONG \\" >&2
|
|
|
|
echo " [--debug] # use debug version; default: $DBUG \\" >&2
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
do_one() {
|
|
|
|
EXE=$1
|
|
|
|
INDEX=$2
|
|
|
|
|
2010-03-28 18:09:27 +02:00
|
|
|
while [ -d ${LOG_DIR} ]; do
|
2009-09-26 15:48:58 +02:00
|
|
|
ROOM="playme ${INDEX}$ROOM_ADD"
|
2010-03-28 18:09:27 +02:00
|
|
|
LOG_FILE="${LOG_DIR}/${ROOM}.log"
|
2009-09-26 15:48:58 +02:00
|
|
|
#COMMAND="$EXE -u -0 -C \"$ROOM\" -a $HOSTNAME -r Relay -d $DICT -p $PORT"
|
|
|
|
# it's a server if INDEX is odd
|
2010-03-28 18:09:27 +02:00
|
|
|
if [ 0 -ne $((INDEX%2)) ]; then
|
2009-09-26 15:48:58 +02:00
|
|
|
SERVER=" -s -N "
|
|
|
|
fi
|
|
|
|
#echo $COMMAND
|
|
|
|
|
2010-03-28 18:09:27 +02:00
|
|
|
$EXE -u -o -0 -C "$ROOM" -a $HOSTNAME -r Relay -d $DICT -p $PORT \
|
|
|
|
$SERVER >/dev/null 2>>${LOG_FILE} &
|
2009-09-26 15:48:58 +02:00
|
|
|
PID=$!
|
2010-03-28 18:09:27 +02:00
|
|
|
echo "launched $ROOM (pid=$PID)"
|
2009-09-26 15:48:58 +02:00
|
|
|
|
|
|
|
END_TIME=$(($(date +%s) + $HOW_LONG))
|
|
|
|
while [ -d /proc/$PID ]; do
|
|
|
|
sleep 10
|
|
|
|
|
2010-03-28 18:09:27 +02:00
|
|
|
if [ ! -d ${LOG_DIR} ]; then
|
|
|
|
break
|
|
|
|
elif [ ! -d /proc/$PID ]; then
|
|
|
|
break
|
|
|
|
elif [ $(date +%s) -ge $END_TIME ]; then
|
2009-09-26 15:48:58 +02:00
|
|
|
echo "timing out $ROOM ($PID)"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
kill $PID # in case we timed out
|
|
|
|
sleep 2
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
while [ -n "$1" ]; do
|
|
|
|
case $1 in
|
|
|
|
--delay)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
HOW_LONG=$2
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--relay)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
HOSTNAME=$2
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--port)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
PORT=$2
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--room)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
ROOM_ADD=$2
|
|
|
|
shift
|
|
|
|
;;
|
2010-03-28 18:09:27 +02:00
|
|
|
--dict)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
DICT=$2
|
|
|
|
shift
|
|
|
|
;;
|
2009-09-26 15:48:58 +02:00
|
|
|
--games)
|
|
|
|
[ -n "$2" ] || usage
|
|
|
|
NGAMES=$2
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--debug)
|
|
|
|
DBUG=1
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
2010-03-28 18:09:27 +02:00
|
|
|
[ -f $DICT ] || usage "dict $DICT not found"
|
|
|
|
|
2009-09-26 15:48:58 +02:00
|
|
|
if [ $DBUG ]; then
|
|
|
|
EXE="./obj_linux_memdbg/xwords"
|
|
|
|
else
|
|
|
|
EXE="./obj_linux_rel/xwords"
|
|
|
|
fi
|
|
|
|
|
|
|
|
[ -x $EXE ] || usage "file $EXE not found"
|
|
|
|
|
|
|
|
for II in $(seq $NGAMES); do
|
|
|
|
do_one $EXE $II &
|
|
|
|
sleep $(($HOW_LONG/$NGAMES))
|
|
|
|
done
|
|
|
|
|
|
|
|
wait
|