X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=gruntmaster-compile;h=40336515102fcad52396a40ea8b59f32c4f70507;hp=b4c2ab12e78a8d440cc3ace415e80eba25c496f5;hb=837911b376705e31b1affbe5679f92e072d2601e;hpb=498646e00c11ecb137eac12e4eab92b7f8a3fb98 diff --git a/gruntmaster-compile b/gruntmaster-compile index b4c2ab1..4033651 100755 --- a/gruntmaster-compile +++ b/gruntmaster-compile @@ -18,16 +18,38 @@ if ($ret) { given ($format){ exec 'gcc', qw/-DONLINE_JUDGE -std=gnu11 -Wall -Wextra -O2 -o/, $basename, $name when 'C'; exec 'g++', qw/-DONLINE_JUDGE -std=gnu++11 -fabi-version=6 -Wall -Wextra -O2 -o/, $basename, $name when 'CPP'; + when ('MONO') { + system 'gmcs', '-d:ONLINE_JUDGE', $name and die "gmcs failed: errno=$! return=$?"; + rename "$basename.exe", $basename; + chmod 0755, $basename; + } exec 'gmcs', '-d:ONLINE_JUDGE', $name when 'MONO'; - exec 'javac', $name when 'JAVA'; + when ('JAVA') { + system 'javac', $name and die "javac failed: errno=$! return=$?"; + system 'jar', 'cfe', $basename, $basename, "$basename.class" and die "jar failed: errno=$! return=$?"; + chmod 0755, $basename; + exit + } exec 'fpc', qw/-dONLINE_JUDGE -O2/, $name when 'PASCAL'; exec 'go', qw/build -compiler gc/, $name when 'GOLANG'; exec 'go', qw/build -compiler gccgo/, $name, when 'GCCGO'; exec 'ghc', qw/-DONLINE_JUDGE -Wall -O2 -o/, $basename, $name when 'HASKELL'; - copy $name, $basename when ['PERL', 'PYTHON'] + + when ([qw/PERL PYTHON/]){ + open IN, '<', $name; + open OUT, '>', $basename; + print OUT "#!/usr/bin/perl\n" if $_ eq 'PERL'; + print OUT "#!/usr/bin/python\n" if $_ eq 'PYTHON'; + print OUT while ; + close OUT; + close IN; + chmod 0755, $basename; + exit + } } } +exit 1; __END__ =encoding utf-8