76e921f7fc788ab65d17dac7a89b01f00a15ec75
5 use Gruntmaster
::Page
::Submit
;
7 use IO
::Prompter
[ -style
=> 'bold', '-stdio', '-verbatim' ];
8 use File
::Slurp qw
/read_file/;
9 use Term
::ANSIColor qw
/RED RESET/;
10 use Getopt
::Long qw
/:config require_order/;
12 ##################################################
21 my ($meta, $name, $prefix) = @_;
22 my $filename = prompt
'$prefix filename', -complete
=> 'filenames';
23 $meta->{files
}{$name}{content
} = read_file
$filename;
24 $meta->{files
}{$name}{format
} = prompt
'$prefix format', -menu
=> Gruntmaster
::Page
::Submit
::FORMATS
;
25 $meta->{files
}{$name}{name
} = prompt
"$prefix filename [$filename]", -default => $filename;
30 my $name = prompt
'Problem name';
31 my $private = prompt
('Private?', '-yn') eq 'y';
32 my $author = prompt
'Problem author (full name)';
33 my $owner = prompt
'Problem owner (username)';
34 my $level = prompt
'Problem level', -menu
=> "beginner\neasy\nmedium\nhard";
35 my $statement = read_file prompt
'File with problem statement', -complete
=> 'filenames';
37 my $generator = prompt
'Generator', -menu
=> "File\nRun\nUndef";
38 my $runner = prompt
'Runner', -menu
=> "File\nVerifier\nInteractive";
39 my $judge = prompt
'Judge', -menu
=> "Absolute\nPoints";
40 my $testcnt = prompt
'Test count', '-i';
42 my $timeout = prompt
'Time limit (seconds)', '-n';
43 my $olimit = prompt
'Output limit (bytes)', '-i';
44 say 'Memory limits are broken, so I won\'t ask you for one';
46 prompt_file \
%meta, gen
=> '[Generator::Run] Generator' if $generator eq 'Run';
48 if ($runner eq 'File') {
49 $meta{tests
}[$_ - 1] = prompt
"[Runner::File] Score for test ${_} [10]", '-i', -default => 10 for 1 .. $testcnt;
52 prompt_file \
%meta, ver
=> '[Runner::Verifier] Verifier' if $runner eq 'Verifier';
54 if ($runner eq 'Interactive') {
55 say RED
, 'WARNING: Runner::Interactive is experimental', RESET
;
56 prompt_file \
%meta, int => '[Runner::Interactive] Interactive verifier';
59 insert_problem
$id => (
62 statement
=> $statement,
65 generator
=> $generator,
69 ($private ?
(private
=> $private) : ()),
70 (defined $timeout ?
(timeout
=> $timeout) : ()),
71 (defined $olimit ?
(olimit
=> $olimit) : ()));
72 set_problem_meta
$id => \
%meta;
73 PUBLISH genpage
=> $contest ?
"ct/$contest/pb/index.html" : 'pb/index.html';
74 PUBLISH genpage
=> $contest ?
"ct/$contest/pb/$id.html" : "pb/$id.html";
79 GetOptions
( 'file!' => \
$file );
80 my ($id, %values) = @ARGV;
81 %values = map { $_ => scalar read_file
$values{$_} } keys %values if $file;
82 edit_problem
$id => %values;
83 PUBLISH genpage
=> 'pb/index.html';
84 PUBLISH genpage
=> "pb/$id.html";
94 PUBLISH genpage
=> $contest ?
"ct/$contest/pb/index.html" : 'pb/index.html';
98 local $_ = shift or goto &cmd_list
;
101 ##################################################
103 GetOptions
( 'contest=s' => \
$contest );
104 local $Gruntmaster::Data
::contest
= $contest;
105 my $cmd = 'cmd_' . shift;
106 cmd_help
unless exists $main::{$cmd};
108 $cmd->(@ARGV) if exists $main::{$cmd};
117 gruntmaster-problem - shell interface to Gruntmaster 6000 problems
121 gruntmaster-problem [--contest=mycontest] add problem_id
122 gruntmaster-problem [--contest=mycontest] list
123 gruntmaster-problem [--contest=mycontest] rm problem_id
124 gruntmaster-problem [--contest=mycontest] show problem_id
125 gruntmaster-problem [--contest=mycontest] set [--file] problem_id key value
129 gruntmaster-problem is a tool for managing problems.
131 Select the contest with the optional argument I<--contest>.
137 Prints the list of problems in the selected contest.
141 Prints detailed information about problem I<id>.
145 Adds a new problem with id I<id>.
149 Removes the problem with id I<id>.
151 =item B<set> I<id> I<key> I<value>
153 Sets the I<key> configuration option of problem I<id> to I<value>.
155 =item B<set> --file I<id> I<key> I<file>
157 Sets the I<key> configuration option of problem I<id> to the contents of the file I<file>.
163 Marius Gavrilescu E<lt>marius@ieval.roE<gt>
165 =head1 COPYRIGHT AND LICENSE
167 Copyright (C) 2014 by Marius Gavrilescu
169 This library is free software: you can redistribute it and/or modify
170 it under the terms of the GNU Affero General Public License as published by
171 the Free Software Foundation, either version 3 of the License, or
172 (at your option) any later version.
This page took 0.032928 seconds and 3 git commands to generate.