X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=gruntmaster-compile;h=40336515102fcad52396a40ea8b59f32c4f70507;hp=bc9c4f5d252ea4f88b8ef26d33b6ce1d99efae49;hb=837911b376705e31b1affbe5679f92e072d2601e;hpb=69c2540886d549bcd11b375cdaeb83ec4646f619 diff --git a/gruntmaster-compile b/gruntmaster-compile index bc9c4f5..4033651 100755 --- a/gruntmaster-compile +++ b/gruntmaster-compile @@ -3,8 +3,11 @@ use v5.14; no if $] > 5.017011, warnings => 'experimental::smartmatch'; use File::Copy qw/copy/; +use File::Basename qw/fileparse/; + +my ($format, $name) = @ARGV; +my $basename = fileparse $name, qr/\..*/; -my ($format, $basename, $name) = @ARGV; my $ret = fork // die $!; if ($ret) { $SIG{ALRM} = sub {kill KILL => $ret}; @@ -15,13 +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'; - exec 'fpc', qw/-dONLINE_JUDGE -O2 -n/, $name when 'PASCAL'; - copy $name, $basename when ['PERL', 'PYTHON'] + 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'; + + 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 @@ -49,7 +77,7 @@ Compile commands for each format: =item CPP - g++ -DONLINE_JUDGE -std=gnu11 -fabi-version=6 -Wall -Wextra -O2 -o $output $input + g++ -DONLINE_JUDGE -std=gnu++11 -fabi-version=6 -Wall -Wextra -O2 -o $output $input =item MONO @@ -61,7 +89,19 @@ Compile commands for each format: =item PASCAL - fpc -dONLINE_JUDGE -O2 -n $input + fpc -dONLINE_JUDGE -O2 $input + +=item GOLANG + + go build -compiler gc $input + +=item GCCGO + + go build -compiler gccgo $input + +=item HASKELL + + ghc -DONLINE_JUDGE -Wall -O2 -o $output $input =item PERL