X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=lib%2FGruntmaster%2FDaemon%2FFormat.pm;h=8e895c08b95c91009f90b1af88a3ac4692697c7a;hp=948e25a9bb68bb2c554c16fd8de384d669ecae09;hb=89edda8249e7e8f538f73863efc28135804e629a;hpb=ddceb393c90f620dd194c22e5e85d8c9fe87ee34 diff --git a/lib/Gruntmaster/Daemon/Format.pm b/lib/Gruntmaster/Daemon/Format.pm index 948e25a..8e895c0 100644 --- a/lib/Gruntmaster/Daemon/Format.pm +++ b/lib/Gruntmaster/Daemon/Format.pm @@ -4,6 +4,7 @@ use 5.014000; use strict; use warnings; use parent qw/Exporter/; +no if $] > 5.017011, warnings => 'experimental::smartmatch'; use POSIX qw//; use File::Basename qw/fileparse/; @@ -23,8 +24,15 @@ our @EXPORT_OK = qw/mkrun/; sub command_and_args{ my ($format, $basename) = @_; - return "./$basename" if $format eq 'CPP'; - die + + given($format) { + "./$basename" when [qw/C CPP PASCAL/]; + "./$basename.exe" when 'MONO'; + "java $basename" when 'JAVA'; + "perl $basename" when 'PERL'; + "python $basename" when 'PYTHON'; + default { die "Don't know how to execute format $format" } + } } sub mkrun{ @@ -59,6 +67,7 @@ sub mkrun{ } } exec 'gruntmaster-exec', $args{mlimit} // 0, $args{olimit} // 0, command_and_args($format, $basename), exists $args{args} ? @{$args{args}} : (); + exit 42 } } }