From 95d0b2a41370a1aea4aa55999ff8b1bcc5079ecc Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sun, 11 Jan 2015 01:23:47 +0100 Subject: [PATCH] add current version of processing scripts fix a crash in checkpasswd --- process/cron/backup-eressea | 31 +++++++++++++++++++++++++++++++ process/cron/create-orders | 16 ++++++++++++++++ process/cron/run-eressea | 5 +++-- process/cron/run-turn | 14 ++++++++++++++ src/build.h | 2 +- src/kernel/faction.c | 4 +--- 6 files changed, 66 insertions(+), 6 deletions(-) create mode 100755 process/cron/backup-eressea create mode 100755 process/cron/create-orders create mode 100755 process/cron/run-turn diff --git a/process/cron/backup-eressea b/process/cron/backup-eressea new file mode 100755 index 000000000..4f1d42144 --- /dev/null +++ b/process/cron/backup-eressea @@ -0,0 +1,31 @@ +#!/bin/bash +if [ -z $ERESSEA ] ; then + ERESSEA=$HOME/eressea + echo "The ERESSEA environment variable is not set. Assuming $ERESSEA." +fi +GAME=$1 +if [ ! -d $ERESSEA/game-$GAME ]; then + echo "No such game: game-$GAME." + exit 1 +fi +cd $ERESSEA/game-$GAME +TURN=$2 +if [ -z $TURN ]; then + TURN=$(cat turn) +fi +if [ ! -e data/$TURN.dat ]; then + echo "No data for turn $TURN in game $GAME." + exit 2 +fi +if [ ! -d backup ] ; then + echo "creating missing backup directory for game $GAME." + mkdir -p ~/backup/eressea/game-$GAME + ln -sf ~/backup/eressea/game-$GAME backup +fi + +files="data/$TURN.dat parteien.full parteien" +if [ -e orders.$TURN ]; then +files="$files orders.$TURN" +fi +echo "backup turn $TURN, game $GAME, files: $files" +tar cjf backup/$TURN.tar.bz2 $files diff --git a/process/cron/create-orders b/process/cron/create-orders new file mode 100755 index 000000000..ff784f9aa --- /dev/null +++ b/process/cron/create-orders @@ -0,0 +1,16 @@ +GAME=$1 +TURN=$2 + +if [ ! -d $ERESSEA/game-$GAME ] ; then + echo "No such game: $GAME" + exit 1 +fi + +cd $ERESSEA/game-$GAME +if [ -d orders.dir.$TURN ]; then + echo "orders.dir.$TURN already exists" +else + mv orders.dir orders.dir.$TURN + mkdir -p orders.dir +fi +ls -1rt orders.dir.$TURN/turn-* | xargs cat > orders.$TURN diff --git a/process/cron/run-eressea b/process/cron/run-eressea index f31150c1a..e932378fc 100755 --- a/process/cron/run-eressea +++ b/process/cron/run-eressea @@ -12,14 +12,15 @@ if [ -d $REPORTS ]; then rm -rf $REPORTS fi mkdir $REPORTS -$BIN/backup-eressea $GAME $TURN cd $ERESSEA/game-$GAME if [ -d test ]; then touch test/execute.lock fi +$BIN/create-orders $GAME $TURN +$BIN/backup-eressea $GAME $TURN rm -f execute.lock -$BIN/run-turn $GAME +$BIN/run-turn $GAME $TURN touch execute.lock if [ ! -s $ERESSEA/game-$GAME/orders.$TURN ]; then diff --git a/process/cron/run-turn b/process/cron/run-turn new file mode 100755 index 000000000..80e12b093 --- /dev/null +++ b/process/cron/run-turn @@ -0,0 +1,14 @@ +GAME=$1 +TURN=$2 + +if [ ! -d $ERESSEA/game-$GAME ] ; then + echo "No such game: $GAME" + exit 1 +fi + +cd $ERESSEA/game-$GAME + +echo "running turn $TURN, game $GAME" +$ERESSEA/server/bin/eressea -v1 -t $TURN run-turn.lua +mkdir -p log +ln -f eressea.log log/eressea.log.$TURN diff --git a/src/build.h b/src/build.h index 1b880e8d1..46a2e1316 100644 --- a/src/build.h +++ b/src/build.h @@ -1,3 +1,3 @@ #define VERSION_MAJOR 3 #define VERSION_MINOR 3 -#define VERSION_BUILD 694 +#define VERSION_BUILD 695 diff --git a/src/kernel/faction.c b/src/kernel/faction.c index b46848e3c..958640862 100755 --- a/src/kernel/faction.c +++ b/src/kernel/faction.c @@ -274,9 +274,7 @@ unit *addplayer(region * r, faction * f) bool checkpasswd(const faction * f, const char *passwd, bool shortp) { - if (unicode_utf8_strcasecmp(f->passw, passwd) == 0) - return true; - return false; + return (passwd && unicode_utf8_strcasecmp(f->passw, passwd) == 0); } variant read_faction_reference(struct storage * store)