rbx.cp 0.5.46__py3-none-any.whl → 0.5.48__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. rbx/box/checkers.py +81 -28
  2. rbx/box/cli.py +12 -10
  3. rbx/box/environment.py +1 -1
  4. rbx/box/naming.py +22 -0
  5. rbx/box/packaging/boca/extension.py +1 -0
  6. rbx/box/packaging/boca/packager.py +54 -11
  7. rbx/box/packaging/main.py +7 -0
  8. rbx/box/packaging/moj/packager.py +89 -19
  9. rbx/box/packaging/packager.py +15 -3
  10. rbx/box/packaging/polygon/packager.py +5 -4
  11. rbx/box/solutions.py +2 -2
  12. rbx/box/statements/build_statements.py +2 -1
  13. rbx/box/stresses.py +0 -1
  14. rbx/box/tasks.py +6 -4
  15. rbx/grading/judge/sandbox.py +29 -1
  16. rbx/grading/judge/sandboxes/isolate.py +10 -0
  17. rbx/grading/judge/sandboxes/stupid_sandbox.py +16 -4
  18. rbx/grading/judge/sandboxes/timeit.py +12 -3
  19. rbx/grading/processing_context.py +48 -0
  20. rbx/grading/steps.py +25 -14
  21. rbx/resources/packagers/boca/checker.sh +8 -6
  22. rbx/resources/packagers/boca/compare.sh +48 -0
  23. rbx/resources/packagers/boca/interactive/c +207 -0
  24. rbx/resources/packagers/boca/interactive/cc +207 -0
  25. rbx/resources/packagers/boca/interactive/cpp +207 -0
  26. rbx/resources/packagers/boca/interactive/java +240 -0
  27. rbx/resources/packagers/boca/interactive/kt +231 -0
  28. rbx/resources/packagers/boca/interactive/py2 +209 -0
  29. rbx/resources/packagers/boca/interactive/py3 +209 -0
  30. rbx/resources/packagers/boca/interactor_compile.sh +45 -0
  31. rbx/resources/packagers/boca/run/bkp +163 -0
  32. rbx/resources/packagers/boca/run/c +19 -19
  33. rbx/resources/packagers/boca/run/cc +19 -19
  34. rbx/resources/packagers/boca/run/cpp +19 -19
  35. rbx/resources/packagers/boca/run/java +51 -51
  36. rbx/resources/packagers/boca/run/kt +30 -30
  37. rbx/resources/packagers/boca/run/py2 +42 -42
  38. rbx/resources/packagers/boca/run/py3 +42 -42
  39. rbx/resources/packagers/moj/scripts/c/compile.sh +19 -0
  40. rbx/resources/packagers/moj/scripts/c/prep.sh +5 -0
  41. rbx/resources/packagers/moj/scripts/c/run.sh +16 -0
  42. rbx/resources/packagers/moj/scripts/compare.sh +32 -6
  43. rbx/resources/packagers/moj/scripts/cpp/compile.sh +19 -0
  44. rbx/resources/packagers/moj/scripts/cpp/prep.sh +5 -0
  45. rbx/resources/packagers/moj/scripts/cpp/run.sh +16 -0
  46. rbx/resources/packagers/moj/scripts/interactor_prep.sh +14 -0
  47. rbx/resources/packagers/moj/scripts/interactor_run.sh +38 -0
  48. rbx/resources/packagers/moj/scripts/java/compile.sh +12 -0
  49. rbx/resources/packagers/moj/scripts/java/prep.sh +8 -0
  50. rbx/resources/packagers/moj/scripts/java/run.sh +17 -0
  51. rbx/resources/packagers/moj/scripts/py2/compile.sh +7 -0
  52. rbx/resources/packagers/moj/scripts/py2/prep.sh +5 -0
  53. rbx/resources/packagers/moj/scripts/py2/run.sh +16 -0
  54. rbx/resources/packagers/moj/scripts/py3/compile.sh +7 -0
  55. rbx/resources/packagers/moj/scripts/py3/prep.sh +5 -0
  56. rbx/resources/packagers/moj/scripts/py3/run.sh +16 -0
  57. {rbx_cp-0.5.46.dist-info → rbx_cp-0.5.48.dist-info}/METADATA +1 -1
  58. {rbx_cp-0.5.46.dist-info → rbx_cp-0.5.48.dist-info}/RECORD +61 -33
  59. rbx/resources/packagers/boca/compare +0 -53
  60. {rbx_cp-0.5.46.dist-info → rbx_cp-0.5.48.dist-info}/LICENSE +0 -0
  61. {rbx_cp-0.5.46.dist-info → rbx_cp-0.5.48.dist-info}/WHEEL +0 -0
  62. {rbx_cp-0.5.46.dist-info → rbx_cp-0.5.48.dist-info}/entry_points.txt +0 -0
@@ -0,0 +1,207 @@
1
+ #!/bin/bash
2
+ # ////////////////////////////////////////////////////////////////////////////////
3
+ # //BOCA Online Contest Administrator
4
+ # // Copyright (C) 2003-2014 by BOCA System (bocasystem@gmail.com)
5
+ # //
6
+ # // This program is free software: you can redistribute it and/or modify
7
+ # // it under the terms of the GNU General Public License as published by
8
+ # // the Free Software Foundation, either version 3 of the License, or
9
+ # // (at your option) any later version.
10
+ # //
11
+ # // This program is distributed in the hope that it will be useful,
12
+ # // but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ # // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
+ # // GNU General Public License for more details.
15
+ # // You should have received a copy of the GNU General Public License
16
+ # // along with this program. If not, see <http://www.gnu.org/licenses/>.
17
+ # ////////////////////////////////////////////////////////////////////////////////
18
+ #Last modified: 21/aug/2014 by cassio@ime.usp.br
19
+ #
20
+ # parameters are:
21
+ # $1 exe_file
22
+ # $2 input_file
23
+ # $3 timelimit (limit to run all the repetitions, by default only one repetition)
24
+ # $4 number_of_repetitions_to_run (optional, can be used for better tuning the timelimit)
25
+ # $5 maximum allowed memory (in MBytes)
26
+ # $6 maximum allowed output size (in KBytes)
27
+ #
28
+ # the output of the submission should be directed to the standard output
29
+ #
30
+ # the return code show what happened (according to safeexec):
31
+ # 0 ok
32
+ # 1 compile error
33
+ # 2 runtime error
34
+ # 3 timelimit exceeded
35
+ # 4 internal error
36
+ # 5 parameter error
37
+ # 6 internal error
38
+ # 7 memory limit exceeded
39
+ # 8 security threat
40
+ # 9 runtime error
41
+ # other_codes are unknown to boca: in this case BOCA will present the
42
+ # last line of standard output to the judge
43
+
44
+ umask 0022
45
+ id -u bocajail >/dev/null 2>/dev/null
46
+ if [ $? == 0 ]; then
47
+ bocau=$(id -u bocajail)
48
+ bocag=$(id -g bocajail)
49
+ chown bocajail.nogroup .
50
+ else
51
+ bocau=$(id -u nobody)
52
+ bocag=$(id -g nobody)
53
+ chown nobody.nogroup .
54
+ fi
55
+ if [ "$bocau" == "" -o "$bocag" == "" ]; then
56
+ echo "error finding user to run script"
57
+ exit 43
58
+ fi
59
+
60
+ # this script makes use of safeexec to execute the code with less privilegies
61
+ # make sure that directories below are correct.
62
+ sf=$(which safeexec)
63
+ [ -x "$sf" ] || sf=/usr/bin/safeexec
64
+
65
+ if [ "$1" == "" -o "$2" == "" -o "$3" == "" ]; then
66
+ echo "parameter problem"
67
+ exit 43
68
+ fi
69
+ if [ ! -x "$1" ]; then
70
+ echo "$1 not found (or is not in the current dir) or it's not executable"
71
+ exit 44
72
+ fi
73
+ if [ ! -r "$2" ]; then
74
+ echo "$2 not found (or is not in the current dir) or it's not readable"
75
+ exit 45
76
+ fi
77
+ if [ ! -x "$sf" ]; then
78
+ echo "$sf not found or it's not executable"
79
+ exit 46
80
+ fi
81
+
82
+ time=$3
83
+ if [ "$time" -gt "0" ]; then
84
+ let "ttime = $time + 30"
85
+ else
86
+ time=1
87
+ ttime=30
88
+ fi
89
+
90
+ nruns=1
91
+ if [ "$4" != "" ]; then
92
+ if [ "$4" -gt "0" ]; then
93
+ nruns=$4
94
+ fi
95
+ fi
96
+ maxm=512000
97
+ if [ "$5" != "" ]; then
98
+ if [ "$5" -gt "0" ]; then
99
+ maxm=${5}000
100
+ fi
101
+ fi
102
+ maxf=1024
103
+ if [ "$6" != "" ]; then
104
+ if [ "$6" -gt "0" ]; then
105
+ maxf=${6}
106
+ fi
107
+ fi
108
+
109
+ cp "$2" stdin0 2>/dev/null
110
+ cp "$1" run.exe 2>/dev/null
111
+ cp ../interactor.exe interactor.exe 2>/dev/null
112
+
113
+ file run.exe | grep -iq "statically linked"
114
+ if [ "$?" != "0" ]; then
115
+ echo "Aborting because $1 is not statically linked"
116
+ exit 47
117
+ fi
118
+
119
+ cdir=$(pwd)
120
+ echo "Current directory is $cdir -- chrooting on it" >&2
121
+
122
+ ### START OF BOCA RUN COMMAND
123
+ cat <<EOF >runit.sh
124
+ #!/bin/bash
125
+ mkfifo fifo.in fifo.out
126
+
127
+ echo "Running solution as \$@" >&2
128
+
129
+ "\$@" >fifo.out <fifo.in 2>/dev/null &
130
+ SFPID=\$!
131
+
132
+ ./interactor.exe "stdin0" "stdout0" <fifo.out >fifo.in 2>stderr0 &
133
+ INTPID=\$!
134
+
135
+ wait \$SFPID
136
+ ECSF=\$?
137
+
138
+ wait \$INTPID
139
+ ECINT=\$?
140
+
141
+ rm -rf fifo.in fifo.out
142
+
143
+ echo "interactor \$INTPID -> \$ECINT" >&2
144
+ echo "solution \$SFPID -> \$ECSF" >&2
145
+
146
+ echo "interactor exitcode \$ECINT" >&2
147
+ echo "solution exitcode \$ECSF" >&2
148
+
149
+ ret=0
150
+ if [[ \$ECINT -ge 1 ]] && [[ \$ECINT -le 4 ]]; then
151
+ echo "testlib exitcode \$ECINT" >stdout0
152
+ ret=0
153
+ elif [[ \$ECSF -ne 0 ]]; then
154
+ ret=\$ECSF
155
+ elif [[ \$ECINT -ne 0 ]]; then
156
+ ret=9
157
+ fi
158
+
159
+ exit \$ret
160
+ EOF
161
+
162
+ chmod 755 runit.sh
163
+
164
+ ret=0
165
+ echo $cdir | grep -q "/bocajail"
166
+ if [ $? -eq 0 ]; then
167
+ cdir=$(echo $cdir | sed "s/.*\/bocajail//")
168
+ cat <<EOF >runch.sh
169
+ #!/bin/bash
170
+ cd "$cdir"
171
+ [ -f /proc/cpuinfo ] || /bin/mount -t proc proc /proc
172
+ [ -d /sys/kernel ] || /bin/mount -t sysfs sysfs /sys
173
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
174
+ retval=\$?
175
+ echo \$retval > runch.exitcode
176
+ if [ ! -d /bocajail ]; then
177
+ /bin/umount /proc 2>/dev/null
178
+ /bin/umount /sys 2>/dev/null
179
+ fi
180
+ EOF
181
+ chmod 755 runch.sh
182
+ chroot /bocajail $cdir/runch.sh
183
+ if [ -r runch.exitcode ]; then
184
+ ret=$(cat runch.exitcode)
185
+ fi
186
+ if [ "$ret" == "" ]; then
187
+ echo "Execution error - check autojudging"
188
+ exit 49
189
+ fi
190
+ else
191
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
192
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
193
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
194
+
195
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
196
+ ret=$?
197
+ fi
198
+ ### END OF BOCA RUN COMMAND
199
+
200
+ if [ $ret -gt 10 ]; then
201
+ echo "execution error with code $ret" >&2
202
+ ret=0
203
+ fi
204
+ if [ -f stdout0 ]; then
205
+ cat stdout0
206
+ fi
207
+ exit $ret
@@ -0,0 +1,207 @@
1
+ #!/bin/bash
2
+ # ////////////////////////////////////////////////////////////////////////////////
3
+ # //BOCA Online Contest Administrator
4
+ # // Copyright (C) 2003-2014 by BOCA System (bocasystem@gmail.com)
5
+ # //
6
+ # // This program is free software: you can redistribute it and/or modify
7
+ # // it under the terms of the GNU General Public License as published by
8
+ # // the Free Software Foundation, either version 3 of the License, or
9
+ # // (at your option) any later version.
10
+ # //
11
+ # // This program is distributed in the hope that it will be useful,
12
+ # // but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ # // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
+ # // GNU General Public License for more details.
15
+ # // You should have received a copy of the GNU General Public License
16
+ # // along with this program. If not, see <http://www.gnu.org/licenses/>.
17
+ # ////////////////////////////////////////////////////////////////////////////////
18
+ #Last modified: 21/aug/2014 by cassio@ime.usp.br
19
+ #
20
+ # parameters are:
21
+ # $1 exe_file
22
+ # $2 input_file
23
+ # $3 timelimit (limit to run all the repetitions, by default only one repetition)
24
+ # $4 number_of_repetitions_to_run (optional, can be used for better tuning the timelimit)
25
+ # $5 maximum allowed memory (in MBytes)
26
+ # $6 maximum allowed output size (in KBytes)
27
+ #
28
+ # the output of the submission should be directed to the standard output
29
+ #
30
+ # the return code show what happened (according to safeexec):
31
+ # 0 ok
32
+ # 1 compile error
33
+ # 2 runtime error
34
+ # 3 timelimit exceeded
35
+ # 4 internal error
36
+ # 5 parameter error
37
+ # 6 internal error
38
+ # 7 memory limit exceeded
39
+ # 8 security threat
40
+ # 9 runtime error
41
+ # other_codes are unknown to boca: in this case BOCA will present the
42
+ # last line of standard output to the judge
43
+
44
+ umask 0022
45
+ id -u bocajail >/dev/null 2>/dev/null
46
+ if [ $? == 0 ]; then
47
+ bocau=$(id -u bocajail)
48
+ bocag=$(id -g bocajail)
49
+ chown bocajail.nogroup .
50
+ else
51
+ bocau=$(id -u nobody)
52
+ bocag=$(id -g nobody)
53
+ chown nobody.nogroup .
54
+ fi
55
+ if [ "$bocau" == "" -o "$bocag" == "" ]; then
56
+ echo "error finding user to run script"
57
+ exit 43
58
+ fi
59
+
60
+ # this script makes use of safeexec to execute the code with less privilegies
61
+ # make sure that directories below are correct.
62
+ sf=$(which safeexec)
63
+ [ -x "$sf" ] || sf=/usr/bin/safeexec
64
+
65
+ if [ "$1" == "" -o "$2" == "" -o "$3" == "" ]; then
66
+ echo "parameter problem"
67
+ exit 43
68
+ fi
69
+ if [ ! -x "$1" ]; then
70
+ echo "$1 not found (or is not in the current dir) or it's not executable"
71
+ exit 44
72
+ fi
73
+ if [ ! -r "$2" ]; then
74
+ echo "$2 not found (or is not in the current dir) or it's not readable"
75
+ exit 45
76
+ fi
77
+ if [ ! -x "$sf" ]; then
78
+ echo "$sf not found or it's not executable"
79
+ exit 46
80
+ fi
81
+
82
+ time=$3
83
+ if [ "$time" -gt "0" ]; then
84
+ let "ttime = $time + 30"
85
+ else
86
+ time=1
87
+ ttime=30
88
+ fi
89
+
90
+ nruns=1
91
+ if [ "$4" != "" ]; then
92
+ if [ "$4" -gt "0" ]; then
93
+ nruns=$4
94
+ fi
95
+ fi
96
+ maxm=512000
97
+ if [ "$5" != "" ]; then
98
+ if [ "$5" -gt "0" ]; then
99
+ maxm=${5}000
100
+ fi
101
+ fi
102
+ maxf=1024
103
+ if [ "$6" != "" ]; then
104
+ if [ "$6" -gt "0" ]; then
105
+ maxf=${6}
106
+ fi
107
+ fi
108
+
109
+ cp "$2" stdin0 2>/dev/null
110
+ cp "$1" run.exe 2>/dev/null
111
+ cp ../interactor.exe interactor.exe 2>/dev/null
112
+
113
+ file run.exe | grep -iq "statically linked"
114
+ if [ "$?" != "0" ]; then
115
+ echo "Aborting because $1 is not statically linked"
116
+ exit 47
117
+ fi
118
+
119
+ cdir=$(pwd)
120
+ echo "Current directory is $cdir -- chrooting on it" >&2
121
+
122
+ ### START OF BOCA RUN COMMAND
123
+ cat <<EOF >runit.sh
124
+ #!/bin/bash
125
+ mkfifo fifo.in fifo.out
126
+
127
+ echo "Running solution as \$@" >&2
128
+
129
+ "\$@" >fifo.out <fifo.in 2>/dev/null &
130
+ SFPID=\$!
131
+
132
+ ./interactor.exe "stdin0" "stdout0" <fifo.out >fifo.in 2>stderr0 &
133
+ INTPID=\$!
134
+
135
+ wait \$SFPID
136
+ ECSF=\$?
137
+
138
+ wait \$INTPID
139
+ ECINT=\$?
140
+
141
+ rm -rf fifo.in fifo.out
142
+
143
+ echo "interactor \$INTPID -> \$ECINT" >&2
144
+ echo "solution \$SFPID -> \$ECSF" >&2
145
+
146
+ echo "interactor exitcode \$ECINT" >&2
147
+ echo "solution exitcode \$ECSF" >&2
148
+
149
+ ret=0
150
+ if [[ \$ECINT -ge 1 ]] && [[ \$ECINT -le 4 ]]; then
151
+ echo "testlib exitcode \$ECINT" >stdout0
152
+ ret=0
153
+ elif [[ \$ECSF -ne 0 ]]; then
154
+ ret=\$ECSF
155
+ elif [[ \$ECINT -ne 0 ]]; then
156
+ ret=9
157
+ fi
158
+
159
+ exit \$ret
160
+ EOF
161
+
162
+ chmod 755 runit.sh
163
+
164
+ ret=0
165
+ echo $cdir | grep -q "/bocajail"
166
+ if [ $? -eq 0 ]; then
167
+ cdir=$(echo $cdir | sed "s/.*\/bocajail//")
168
+ cat <<EOF >runch.sh
169
+ #!/bin/bash
170
+ cd "$cdir"
171
+ [ -f /proc/cpuinfo ] || /bin/mount -t proc proc /proc
172
+ [ -d /sys/kernel ] || /bin/mount -t sysfs sysfs /sys
173
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
174
+ retval=\$?
175
+ echo \$retval > runch.exitcode
176
+ if [ ! -d /bocajail ]; then
177
+ /bin/umount /proc 2>/dev/null
178
+ /bin/umount /sys 2>/dev/null
179
+ fi
180
+ EOF
181
+ chmod 755 runch.sh
182
+ chroot /bocajail $cdir/runch.sh
183
+ if [ -r runch.exitcode ]; then
184
+ ret=$(cat runch.exitcode)
185
+ fi
186
+ if [ "$ret" == "" ]; then
187
+ echo "Execution error - check autojudging"
188
+ exit 49
189
+ fi
190
+ else
191
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
192
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
193
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
194
+
195
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
196
+ ret=$?
197
+ fi
198
+ ### END OF BOCA RUN COMMAND
199
+
200
+ if [ $ret -gt 10 ]; then
201
+ echo "execution error with code $ret" >&2
202
+ ret=0
203
+ fi
204
+ if [ -f stdout0 ]; then
205
+ cat stdout0
206
+ fi
207
+ exit $ret
@@ -0,0 +1,207 @@
1
+ #!/bin/bash
2
+ # ////////////////////////////////////////////////////////////////////////////////
3
+ # //BOCA Online Contest Administrator
4
+ # // Copyright (C) 2003-2014 by BOCA System (bocasystem@gmail.com)
5
+ # //
6
+ # // This program is free software: you can redistribute it and/or modify
7
+ # // it under the terms of the GNU General Public License as published by
8
+ # // the Free Software Foundation, either version 3 of the License, or
9
+ # // (at your option) any later version.
10
+ # //
11
+ # // This program is distributed in the hope that it will be useful,
12
+ # // but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ # // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
+ # // GNU General Public License for more details.
15
+ # // You should have received a copy of the GNU General Public License
16
+ # // along with this program. If not, see <http://www.gnu.org/licenses/>.
17
+ # ////////////////////////////////////////////////////////////////////////////////
18
+ #Last modified: 21/aug/2014 by cassio@ime.usp.br
19
+ #
20
+ # parameters are:
21
+ # $1 exe_file
22
+ # $2 input_file
23
+ # $3 timelimit (limit to run all the repetitions, by default only one repetition)
24
+ # $4 number_of_repetitions_to_run (optional, can be used for better tuning the timelimit)
25
+ # $5 maximum allowed memory (in MBytes)
26
+ # $6 maximum allowed output size (in KBytes)
27
+ #
28
+ # the output of the submission should be directed to the standard output
29
+ #
30
+ # the return code show what happened (according to safeexec):
31
+ # 0 ok
32
+ # 1 compile error
33
+ # 2 runtime error
34
+ # 3 timelimit exceeded
35
+ # 4 internal error
36
+ # 5 parameter error
37
+ # 6 internal error
38
+ # 7 memory limit exceeded
39
+ # 8 security threat
40
+ # 9 runtime error
41
+ # other_codes are unknown to boca: in this case BOCA will present the
42
+ # last line of standard output to the judge
43
+
44
+ umask 0022
45
+ id -u bocajail >/dev/null 2>/dev/null
46
+ if [ $? == 0 ]; then
47
+ bocau=$(id -u bocajail)
48
+ bocag=$(id -g bocajail)
49
+ chown bocajail.nogroup .
50
+ else
51
+ bocau=$(id -u nobody)
52
+ bocag=$(id -g nobody)
53
+ chown nobody.nogroup .
54
+ fi
55
+ if [ "$bocau" == "" -o "$bocag" == "" ]; then
56
+ echo "error finding user to run script"
57
+ exit 43
58
+ fi
59
+
60
+ # this script makes use of safeexec to execute the code with less privilegies
61
+ # make sure that directories below are correct.
62
+ sf=$(which safeexec)
63
+ [ -x "$sf" ] || sf=/usr/bin/safeexec
64
+
65
+ if [ "$1" == "" -o "$2" == "" -o "$3" == "" ]; then
66
+ echo "parameter problem"
67
+ exit 43
68
+ fi
69
+ if [ ! -x "$1" ]; then
70
+ echo "$1 not found (or is not in the current dir) or it's not executable"
71
+ exit 44
72
+ fi
73
+ if [ ! -r "$2" ]; then
74
+ echo "$2 not found (or is not in the current dir) or it's not readable"
75
+ exit 45
76
+ fi
77
+ if [ ! -x "$sf" ]; then
78
+ echo "$sf not found or it's not executable"
79
+ exit 46
80
+ fi
81
+
82
+ time=$3
83
+ if [ "$time" -gt "0" ]; then
84
+ let "ttime = $time + 30"
85
+ else
86
+ time=1
87
+ ttime=30
88
+ fi
89
+
90
+ nruns=1
91
+ if [ "$4" != "" ]; then
92
+ if [ "$4" -gt "0" ]; then
93
+ nruns=$4
94
+ fi
95
+ fi
96
+ maxm=512000
97
+ if [ "$5" != "" ]; then
98
+ if [ "$5" -gt "0" ]; then
99
+ maxm=${5}000
100
+ fi
101
+ fi
102
+ maxf=1024
103
+ if [ "$6" != "" ]; then
104
+ if [ "$6" -gt "0" ]; then
105
+ maxf=${6}
106
+ fi
107
+ fi
108
+
109
+ cp "$2" stdin0 2>/dev/null
110
+ cp "$1" run.exe 2>/dev/null
111
+ cp ../interactor.exe interactor.exe 2>/dev/null
112
+
113
+ file run.exe | grep -iq "statically linked"
114
+ if [ "$?" != "0" ]; then
115
+ echo "Aborting because $1 is not statically linked"
116
+ exit 47
117
+ fi
118
+
119
+ cdir=$(pwd)
120
+ echo "Current directory is $cdir -- chrooting on it" >&2
121
+
122
+ ### START OF BOCA RUN COMMAND
123
+ cat <<EOF >runit.sh
124
+ #!/bin/bash
125
+ mkfifo fifo.in fifo.out
126
+
127
+ echo "Running solution as \$@" >&2
128
+
129
+ "\$@" >fifo.out <fifo.in 2>/dev/null &
130
+ SFPID=\$!
131
+
132
+ ./interactor.exe "stdin0" "stdout0" <fifo.out >fifo.in 2>stderr0 &
133
+ INTPID=\$!
134
+
135
+ wait \$SFPID
136
+ ECSF=\$?
137
+
138
+ wait \$INTPID
139
+ ECINT=\$?
140
+
141
+ rm -rf fifo.in fifo.out
142
+
143
+ echo "interactor \$INTPID -> \$ECINT" >&2
144
+ echo "solution \$SFPID -> \$ECSF" >&2
145
+
146
+ echo "interactor exitcode \$ECINT" >&2
147
+ echo "solution exitcode \$ECSF" >&2
148
+
149
+ ret=0
150
+ if [[ \$ECINT -ge 1 ]] && [[ \$ECINT -le 4 ]]; then
151
+ echo "testlib exitcode \$ECINT" >stdout0
152
+ ret=0
153
+ elif [[ \$ECSF -ne 0 ]]; then
154
+ ret=\$ECSF
155
+ elif [[ \$ECINT -ne 0 ]]; then
156
+ ret=9
157
+ fi
158
+
159
+ exit \$ret
160
+ EOF
161
+
162
+ chmod 755 runit.sh
163
+
164
+ ret=0
165
+ echo $cdir | grep -q "/bocajail"
166
+ if [ $? -eq 0 ]; then
167
+ cdir=$(echo $cdir | sed "s/.*\/bocajail//")
168
+ cat <<EOF >runch.sh
169
+ #!/bin/bash
170
+ cd "$cdir"
171
+ [ -f /proc/cpuinfo ] || /bin/mount -t proc proc /proc
172
+ [ -d /sys/kernel ] || /bin/mount -t sysfs sysfs /sys
173
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
174
+ retval=\$?
175
+ echo \$retval > runch.exitcode
176
+ if [ ! -d /bocajail ]; then
177
+ /bin/umount /proc 2>/dev/null
178
+ /bin/umount /sys 2>/dev/null
179
+ fi
180
+ EOF
181
+ chmod 755 runch.sh
182
+ chroot /bocajail $cdir/runch.sh
183
+ if [ -r runch.exitcode ]; then
184
+ ret=$(cat runch.exitcode)
185
+ fi
186
+ if [ "$ret" == "" ]; then
187
+ echo "Execution error - check autojudging"
188
+ exit 49
189
+ fi
190
+ else
191
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
192
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
193
+ echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2
194
+
195
+ "$sf" -F10 -f$maxf -r$nruns -n0 -C. -U$bocau -G$bocag -d$maxm -m$maxm -t$time -T$ttime -ostdout0 -estderr0 -- ./runit.sh ./run.exe
196
+ ret=$?
197
+ fi
198
+ ### END OF BOCA RUN COMMAND
199
+
200
+ if [ $ret -gt 10 ]; then
201
+ echo "execution error with code $ret" >&2
202
+ ret=0
203
+ fi
204
+ if [ -f stdout0 ]; then
205
+ cat stdout0
206
+ fi
207
+ exit $ret