diff options
| author | cassio <cassiopc@gmail.com> | 2013-07-02 05:46:45 +0000 |
|---|---|---|
| committer | cassio <cassiopc@gmail.com> | 2013-07-02 05:46:45 +0000 |
| commit | be2491b093b1f0ca430bede679ecbb670041e483 (patch) | |
| tree | fe2da63d1811cb93e4352a43a113ace37b9f6017 /old/Java.run | |
| parent | a9aa438ea0558eb0044cf1e54a9190ddb41b65e5 (diff) | |
| download | boca-be2491b093b1f0ca430bede679ecbb670041e483.tar.gz boca-be2491b093b1f0ca430bede679ecbb670041e483.zip | |
restructuring of boca's git
Diffstat (limited to 'old/Java.run')
| -rwxr-xr-x | old/Java.run | 160 |
1 files changed, 160 insertions, 0 deletions
diff --git a/old/Java.run b/old/Java.run new file mode 100755 index 0000000..7708811 --- /dev/null +++ b/old/Java.run @@ -0,0 +1,160 @@ +#!/bin/bash +#////////////////////////////////////////////////////////////////////////////////////////// +#//BOCA Online Contest Administrator. Copyright (c) 2003- Cassio Polpo de Campos. +#//It may be distributed under the terms of the Q Public License version 1.0. A copy of the +#//license can be found with this software or at http://www.opensource.org/licenses/qtpl.php +#// +#//THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +#//INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +#//PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER +#//OR HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR +#//CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR +#//PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING +#//OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +#/////////////////////////////////////////////////////////////////////////////////////////// +#Last modified: 17/oct/2011 by cassio@ime.usp.br +# +# parameters are: +# $1 base_filename +# $2 source_file +# $3 input_file +# $4 languagename +# $5 problemname +# $6 timelimit +# +# the output of the submission should be directed to the standard output +# +# the return code show what happened: +# 0 ok +# 1 compile error +# 2 runtime error +# 3 timelimit exceeded +# 4 internal error +# 5 parameter error +# 6 internal error +# 7 memory limit exceeded +# 8 security threat +# 9 runtime error +# other_codes are unknown to boca: in this case BOCA will present the +# last line of standard output to the judge + +umask 0022 +id -u bocajail >/dev/null 2>/dev/null +if [ $? == 0 ]; then + bocau=`id -u bocajail` + bocag=`id -g bocajail` + chown bocajail.nogroup . +else + bocau=`id -u nobody` + bocag=`id -g nobody` + chown nobody.nogroup . +fi +if [ "$bocau" == "" -o "$bocag" == "" ]; then + echo "error finding user to run script" + exit 43 +fi + +export CLASSPATH=.:$CLASSPATH + +# this script makes use of safeexec to execute the code with less privilegies +# make sure that directories below are correct. +sf=`which safeexec` +[ -x "$sf" ] || sf=/usr/bin/safeexec +java=`which java` +[ -x "$java" ] || java=/usr/java/bin/java +javac=`which javac` +[ -x "$javac" ] || javac=/usr/java/bin/javac + +if [ "$1" == "" -o "$2" == "" -o "$3" == "" ]; then + echo "parameter problem" + exit 43 +fi +if [ ! -r $2 ]; then + echo "$2 not found or it's not readable" + exit 44 +fi +if [ ! -r $3 ]; then + echo "$3 not found or it's not readable" + exit 45 +fi +if [ ! -x $sf ]; then + echo "$sf not found or it's not executable" + exit 46 +fi +if [ ! -x $java ]; then + echo "$java not found or it's not executable" + exit 47 +fi +if [ ! -x $javac ]; then + echo "$javac not found or it's not executable" + exit 47 +fi + +prefix=$1 +name=$2 +input=$3 + +# setting up the timelimit according to the problem +# note that problems should spelling the same as inside BOCA +if [ "$6" == "" ]; then +time=5 +else +time=$6 +fi +let ttime=$time+30 + +$javac "$name" +ret=$? +if [ "$ret" != "0" ]; then + echo "Compilation Error: $ret" + exit 1 +else + if [ ! -f "$prefix.class" ]; then + echo "Class file $prefix.class not generated - possible name mismatch" + exit 48 + fi + cdir=`pwd` + echo "Current directory is $cdir" >&2 + echo $cdir | grep -q "/bocajail" + if [ $? == 0 ]; then + cdir=`echo $cdir | sed "s/.*\/bocajail//"` + cat <<EOF > runit.sh +#!/bin/bash +[ -f /proc/cpuinfo ] || /bin/mount -t proc proc /proc +#/bin/mount --bind /dev /dev +[ -d /sys/kernel ] || /bin/mount -t sysfs sysfs /sys +cd $cdir +$sf -t$time -T$ttime -i$input -F256 -u256 -ostdout0 -estderr0 -U$bocau -G$bocag -n0 -C. -f20000 -d1000000 -m1000000 -- $java -Xmx512M -Xms512M $prefix +echo \$? > runit.retcode +/bin/umount /proc 2>/dev/null +#/bin/umount /dev +/bin/umount /sys 2>/dev/null +EOF + chmod 755 runit.sh + chroot /bocajail $cdir/runit.sh + ret=`cat runit.retcode` + if [ "$ret" == "" ]; then + echo "Execution error - check autojudging" + exit 49 + fi + if [ $ret -gt 10 ]; then + echo "> > > > > > > Nonzero return code - possible runtime error - GUESSING IT IS RUNTIME ERROR! < < < < < < < <" + exit 9 + fi + else + echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2 + echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2 + echo "CODE NOT BEING CHROOTED. DO NOT RUN THIS ON THE MAIN SERVER" >&2 +# $java $prefix < $input + $sf -t$time -T$ttime -i$input -F256 -u256 -U$bocau -G$bocag -ostdout0 -estderr0 -n0 -C. -d900000000 -m900000000 -- $java -Xmx512M -Xms512M $prefix + ret=$? + fi + if [ $ret -gt 10 ]; then + echo "> > > > > > > Nonzero return code - possible runtime error - GUESSING IT IS RUNTIME ERROR! < < < < < < < <" + ret=9 + fi +fi +if [ -f stdout0 ]; then + cat stdout0 +fi +exit $ret |