#!/usr/bin/ruby # import_problem: # * creates a directory for a problem in the current directory, # * copy testdata in the old format and create standard testcase config file require 'erb' def input_filename(dir,i) "#{dir}/input-#{i}.txt" end def answer_filename(dir,i) "#{dir}/answer-#{i}.txt" end def copy_testcase(importing_test_dir,dir,i) system("cp #{importing_test_dir}/#{i}.in #{input_filename(dir,i)}") system("cp #{importing_test_dir}/#{i}.sol #{answer_filename(dir,i)}") end def process_options(options) i = 3 while ii+1 i += 1 end if ARGV[i]=='-m' options[:mem_limit] = ARGV[i+1].to_i if ARGV.length>i+1 i += 1 end i += 1 end end GRADER_DIR = File.dirname(__FILE__) # print usage if ARGV.length < 3 puts "using: import_problem prob_name importing_testcase_dir num_of_testcase [options] * creates a directory for a problem in the current directory, * copy testdata in the old format and create standard testcase config file * options: -t time-limit (in seconds) -m memory-limit (in megabytes)" exit(127) end # processing arguments problem = ARGV[0] testcase_dir = ARGV[1] num_testcases = ARGV[2].to_i options = {:time_limit => 1, :mem_limit => 16} process_options(options) # start working puts "creating directories" system("mkdir #{problem}") system("mkdir #{problem}/script") system("mkdir #{problem}/test_cases") #system("cp #{GRADER_DIR}/std-script/* #{problem}/script") puts "copying testcases" 1.upto(num_testcases) do |i| system("mkdir #{problem}/test_cases/#{i}") copy_testcase("#{testcase_dir}","#{problem}/test_cases/#{i}",i) end # generating all_tests.cfg puts "generating testcase config file" template = File.open(File.dirname(__FILE__) + "/all_tests.cfg.erb").read all_test_cfg = ERB.new(template) cfg_file = File.open("#{problem}/test_cases/all_tests.cfg","w") cfg_file.puts all_test_cfg.result cfg_file.close puts "done"