Update PREREQ_PM
[gruntmaster-daemon.git] / lib / Gruntmaster / Daemon / Format.pm
index 948e25a9bb68bb2c554c16fd8de384d669ecae09..137b64cfe6603732c0d93eecc38d647711a62cea 100644 (file)
@@ -4,17 +4,14 @@ 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/;
 use Gruntmaster::Daemon::Constants qw/TLE OLE DIED NZX/;
-use Log::Log4perl qw/get_logger/;
 use Time::HiRes qw/alarm/;
 use List::MoreUtils qw/natatime/;
 use IPC::Signal qw/sig_name sig_num/;
-use IPC::Open3 qw/open3/;
-use File::Spec::Functions qw/devnull/;
-use Fcntl qw/F_GETFD F_SETFD FD_CLOEXEC/;
 
 our $VERSION = '0.001';
 our @EXPORT_OK = qw/mkrun/;
@@ -23,8 +20,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 +63,7 @@ sub mkrun{
                                }
                        }
                        exec 'gruntmaster-exec', $args{mlimit} // 0, $args{olimit} // 0, command_and_args($format, $basename), exists $args{args} ? @{$args{args}} : ();
+                       exit 42
                }
        }
 }
This page took 0.010562 seconds and 4 git commands to generate.