X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=gruntmaster-compile;h=af72ff81f211197c9d15bf5ab3480c509de94566;hp=d6425e905316ef1f563470aff219e88dabef384d;hb=c88da74dc640492d03acd18721be8b250bf82a2d;hpb=9c1ab9145b96eba0eff66a8679e0d5665a115eda diff --git a/gruntmaster-compile b/gruntmaster-compile index d6425e9..af72ff8 100755 --- a/gruntmaster-compile +++ b/gruntmaster-compile @@ -9,8 +9,8 @@ my ($format, $name) = @ARGV; my $basename = fileparse $name, qr/\..*/; 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 -Wall -Wextra -O2 -o/, $basename, $name when 'CPP'; + exec 'gcc', qw/-DONLINE_JUDGE -std=gnu11 -Wall -Wextra -lm -O2 -o/, $basename, $name when 'C'; + exec 'g++', qw/-DONLINE_JUDGE -std=gnu++11 -Wall -Wextra -lm -O2 -o/, $basename, $name when 'CPP'; when ('MONO') { system 'gmcs', '-d:ONLINE_JUDGE', $name and die "gmcs failed: errno=$! return=$?"; rename "$basename.exe", $basename; @@ -18,8 +18,9 @@ given ($format){ } exec 'gmcs', '-d:ONLINE_JUDGE', $name when 'MONO'; when ('JAVA') { + unlink $_ for <*.class>; system 'javac', $name and die "javac failed: errno=$! return=$?"; - system 'jar', 'cfe', $basename, $basename, "$basename.class" and die "jar failed: errno=$! return=$?"; + system 'jar', 'cfe', $basename, $basename, <*.class> and die "jar failed: errno=$! return=$?"; chmod 0755, $basename; exit } @@ -27,6 +28,12 @@ given ($format){ 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'; + when ('SBCL') { + system 'sbcl', '--noinform', '--eval', qq/(compile-file "$name")/, '--quit' and die "sbcl failed: errno=$! return=$?"; + rename "$basename.fasl", $basename; + chmod 0755, $basename; + exit + } when ([qw/PERL PYTHON/]){ open IN, '<', $name;