-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck.sh
executable file
·101 lines (88 loc) · 2.43 KB
/
check.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
fsettings="./.idea/settings.ini" #! path to settings file
# © JOHANNES SCHMID, REBEKKA SEIDENSCHWAND, PETER PAULUS @ G3 2021
function init() {
echo "[ VER ] CKECK version 1.1"
}
function usage() {
init
echo "[ ERR ] $1"
echo "[USAGE] ./check.sh 1"
echo " -> start check with server mode 1 on default folder"
echo "[USAGE] ./check.sh 1 2"
echo " -> start check with server mode 1 on folder 2"
echo " server mode:"
echo " tX: timelimit X seconds"
echo " dX: depthlimit X layers"
exit 1
}
function wait_removed() {
while true; do
sleep 1
if ! [ -f "$1" ]; then
break
fi
done
}
function check() {
read PLAYERCOUNT <$1
PLAYERCOUNT=$(sed 's/\r$//g' <<<$PLAYERCOUNT)
./run.sh $1 $(printf 'o%.0s' $(seq 1 $PLAYERCOUNT)) $mode >"${client_log_path}check$(printf "%02d" $counter)" &&
./compare.sh >>"${client_log_path}check$(printf "%02d" $counter)"
case "$?" in
0)
echo "[ O K ] $(printf "%02d" $counter) $1"
;;
1)
echo "[ ERR ] USAGE ERROR"
echo " check ${client_log_path}check$(printf "%02d" $counter) for more information"
exit 1
;;
2)
echo ""
echo "[ ERR ] TERMINATED"
exit 2
;;
3)
echo ""
echo "[ ERR ] $(printf "%02d" $counter) $1"
echo " ERROR OCCURED"
echo " check ${client_log_path}check$(printf "%02d" $counter) for more information"
exit 3
;;
5)
echo "[ ERR ] $(printf "%02d" $counter) $1"
;;
esac
}
init
if ! [ -f "$fsettings" ]; then
echo "[ ERR ] no settings file at $fsettings"
echo " create by starting client run.sh"
exit 1
fi
client_log_path=$(awk -F "= " '/client_log_path/ {print $2}' "$fsettings")
check_default_folder=$(awk -F "= " '/check_default_folder/ {print $2}' "$fsettings")
[ $# -ge 1 ] || usage "invalid arguments"
echo "[CHECK] deleting old logs"
shopt -s nullglob
for file in ${client_log_path}check*; do
rm $file
done
if [ $# -eq 1 ]; then
echo "[CHECK] default folder"
folder=$check_default_folder
mode=$1
else
echo "[CHECK] folder $2"
mode=$1
folder=$2
fi
[ -d $folder ] || usage "folder doesn't exist"
counter=1
shopt -s nullglob
for file in $folder*; do
check $file $mode $counter
# sleep 1.01
((counter++))
done
echo "[CHECK] folder checked"