1 package Gruntmaster
::Daemon
::Format
;
6 use parent qw
/Exporter/;
7 no if $] > 5.017011, warnings
=> 'experimental::smartmatch';
10 use File
::Basename qw
/fileparse/;
11 use File
::Slurp qw
/read_file write_file/;
12 use List
::MoreUtils qw
/natatime/;
13 use Log
::Log4perl qw
/get_logger/;
15 use String
::ShellQuote qw
/shell_quote/;
18 our $VERSION = "5999.000_004";
19 our @EXPORT_OK = qw
/prepare_files stopvms/;
21 ##################################################
27 return unless $ENV{GRUNTMASTER_VM
};
28 mkfifo
"$name.in", 0600;
29 mkfifo
"$name.out", 0600;
30 get_logger
->trace("Starting VM $name");
31 $vm{$name} = Expect
::Simple
->new({
32 Cmd
=> "$ENV{GRUNTMASTER_VM} $name",
34 DisconnectCmd
=> 'exit',
40 sub stopvms
{ %vm = () }
44 my $er = "exec-result-$vm";
46 my $cmd = ">$er " . shell_quote
'gruntmaster-exec', @args;
47 get_logger
->trace("Running in VM $vm: $cmd");
50 my $ret = fork // die 'Cannot fork';
55 exec 'gruntmaster-exec', @args;
59 die "gruntmaster-exec died\n" if -z
$er;
60 my ($excode, $exmsg) = read_file
$er;
62 chomp ($excode, $exmsg);
63 get_logger
->trace("Exec result: $excode $exmsg");
64 die [$excode, $exmsg] if $excode > 0;
68 my ($format, $basename) = @_;
71 "./$basename" when [qw
/C CPP GCCGO GOLANG HASKELL PASCAL
/];
72 "./$basename.exe" when 'MONO';
73 java
=> $basename when 'JAVA';
74 perl
=> $basename when 'PERL';
75 python
=> $basename when 'PYTHON';
76 default { die "Don't know how to execute format $format\n" }
83 local *__ANON__
= 'mkrun_runner';
84 my ($name, %args) = @_;
85 get_logger
->trace("Running $name...");
86 my $basename = fileparse
$name, qr/\.[^.]*/;
88 push @args, '--timeout', $args{timeout
} if $args{timeout
};
89 push @args, '--mlimit', $args{mlimit
} if $args{mlimit
};
90 push @args, '--olimit', $args{olimit
} if $args{olimit
};
91 my @fds = exists $args{fds
} ? @
{$args{fds
}} : ();
92 my $it = natatime
2, @fds;
93 while (my ($fd, $file) = $it->()) {
94 push @args, "--fd=$fd $file";
96 execlist
$basename, @args, command_and_args
($format, $basename);
101 my ($name, $format) = @_;
102 get_logger
->trace("Preparing file $name...");
105 execlist prog
=> '--fd=1 >>errors', '--fd=2 >>errors', 'gruntmaster-compile', $format, $name;
107 die "Compile error\n"
109 $Gruntmaster::Daemon
::errors
.= read_file
'errors';
110 $Gruntmaster::Daemon
::errors
.= "\n";
117 runvm
$_ for keys %{$meta->{files
}};
119 for my $file (values %{$meta->{files
}}) {
120 my ($format, $name, $content) = @
{$file}{qw
/format name content/};
122 $file->{run
} = mkrun
($format);
123 write_file
$name, $content;
124 prepare
$name, $format;
135 Gruntmaster::Daemon::Format - Utility functions for handling source files
139 use Gruntmaster::Daemon::Format qw/prepare_files/;
140 prepare_files { files => {
144 content => 'print "Hello, world!"'
155 Gruntmaster::Daemon::Format exports utility functions for handling source files.
159 =item B<prepare_files> I<$meta>
161 Compiles all the source files in C<< $meta->{files} >>.
167 Marius Gavrilescu E<lt>marius@ieval.roE<gt>
169 =head1 COPYRIGHT AND LICENSE
171 Copyright (C) 2014 by Marius Gavrilescu
173 This library is free software: you can redistribute it and/or modify
174 it under the terms of the GNU Affero General Public License as published by
175 the Free Software Foundation, either version 3 of the License, or
176 (at your option) any later version.