Description:
fix reimport bug when creating existing dirs
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r100:384e1befe70e - - 1 file changed: 18 inserted, 13 deleted

@@ -1,10 +1,9
1 #!/usr/bin/ruby
1 #!/usr/bin/ruby
2
2
3 require 'erb'
3 require 'erb'
4 - require 'ftools'
5 require 'fileutils'
4 require 'fileutils'
6 require File.join(File.dirname(__FILE__),'lib/import_helper')
5 require File.join(File.dirname(__FILE__),'lib/import_helper')
7
6
8 JUDGE_ENVIRONMENTS = [:grading, :exam]
7 JUDGE_ENVIRONMENTS = [:grading, :exam]
9 ENV_INFO = {
8 ENV_INFO = {
10 :grading => {
9 :grading => {
@@ -30,14 +29,14
30 File.basename((/(.*)\.in/.match(filename))[1])
29 File.basename((/(.*)\.in/.match(filename))[1])
31 end
30 end
32 build_testrun_info(num_testruns,filenames,raw_prefix)
31 build_testrun_info(num_testruns,filenames,raw_prefix)
33 end
32 end
34
33
35 def copy_testcase(importing_test_dir,fname,dir,i)
34 def copy_testcase(importing_test_dir,fname,dir,i)
36 - File.copy("#{importing_test_dir}/#{fname}.in", "#{input_filename(dir,i)}")
35 + FileUtils.cp("#{importing_test_dir}/#{fname}.in", "#{input_filename(dir,i)}")
37 - File.copy("#{importing_test_dir}/#{fname}.sol", "#{answer_filename(dir,i)}")
36 + FileUtils.cp("#{importing_test_dir}/#{fname}.sol", "#{answer_filename(dir,i)}")
38 end
37 end
39
38
40 def process_options(options)
39 def process_options(options)
41 i = 3
40 i = 3
42 while i<ARGV.length
41 while i<ARGV.length
43 if ARGV[i]=='-t'
42 if ARGV[i]=='-t'
@@ -98,12 +97,18
98 return n
97 return n
99 end
98 end
100 n += 1
99 n += 1
101 end while true
100 end while true
102 end
101 end
103
102
103 + def create_dir_if_not_exists(dir)
104 + if ! FileTest.exists? dir
105 + FileUtils.mkdir(dir)
106 + end
107 + end
108 +
104 def import_problem(ev_dir, problem, testcase_dir, num_testruns, raw_prefix, check_script, options)
109 def import_problem(ev_dir, problem, testcase_dir, num_testruns, raw_prefix, check_script, options)
105 testrun_info = build_testrun_info_from_dir(num_testruns, testcase_dir, raw_prefix)
110 testrun_info = build_testrun_info_from_dir(num_testruns, testcase_dir, raw_prefix)
106
111
107 if !(FileTest.exists? ev_dir)
112 if !(FileTest.exists? ev_dir)
108 puts "Testdata dir (#{ev_dir}) not found."
113 puts "Testdata dir (#{ev_dir}) not found."
109 return
114 return
@@ -111,15 +116,15
111
116
112 problem_dir = "#{ev_dir}/#{problem}"
117 problem_dir = "#{ev_dir}/#{problem}"
113
118
114 # start working
119 # start working
115 puts "creating directories"
120 puts "creating directories"
116
121
117 - File.makedirs("#{problem_dir}")
122 + create_dir_if_not_exists("#{problem_dir}")
118 - File.makedirs("#{problem_dir}/script")
123 + create_dir_if_not_exists("#{problem_dir}/script")
119 - File.makedirs("#{problem_dir}/test_cases")
124 + create_dir_if_not_exists("#{problem_dir}/test_cases")
120
125
121 puts "copying testcases"
126 puts "copying testcases"
122
127
123 tr_num = 0
128 tr_num = 0
124
129
125 num_testcases = 0
130 num_testcases = 0
@@ -130,13 +135,13
130
135
131 testrun.each do |testcase_info|
136 testrun.each do |testcase_info|
132 testcase_num, testcase_fname = testcase_info
137 testcase_num, testcase_fname = testcase_info
133
138
134 puts "copy #{testcase_fname} to #{testcase_num}"
139 puts "copy #{testcase_fname} to #{testcase_num}"
135
140
136 - File.makedirs("#{problem_dir}/test_cases/#{testcase_num}")
141 + create_dir_if_not_exists("#{problem_dir}/test_cases/#{testcase_num}")
137 copy_testcase("#{testcase_dir}",testcase_fname,"#{problem_dir}/test_cases/#{testcase_num}",testcase_num)
142 copy_testcase("#{testcase_dir}",testcase_fname,"#{problem_dir}/test_cases/#{testcase_num}",testcase_num)
138
143
139 num_testcases += 1
144 num_testcases += 1
140 end
145 end
141 end
146 end
142
147
@@ -161,20 +166,20
161 check_file = File.open("#{problem_dir}/script/check","w")
166 check_file = File.open("#{problem_dir}/script/check","w")
162 check_file.puts check_wrapper.result binding
167 check_file.puts check_wrapper.result binding
163 check_file.close
168 check_file.close
164
169
165 File.chmod(0755,"#{problem_dir}/script/check")
170 File.chmod(0755,"#{problem_dir}/script/check")
166
171
167 - File.copy("#{check_script_fname}", "#{problem_dir}/script/#{script_name}")
172 + FileUtils.cp("#{check_script_fname}", "#{problem_dir}/script/#{script_name}")
168 else
173 else
169 if File.exists?(SCRIPT_DIR + "/templates/check.#{check_script}")
174 if File.exists?(SCRIPT_DIR + "/templates/check.#{check_script}")
170 check_script_fname = SCRIPT_DIR + "/templates/check.#{check_script}"
175 check_script_fname = SCRIPT_DIR + "/templates/check.#{check_script}"
171 else
176 else
172 check_script_fname = check_script
177 check_script_fname = check_script
173 end
178 end
174 - File.copy("#{check_script_fname}", "#{problem_dir}/script/check")
179 + FileUtils.cp("#{check_script_fname}", "#{problem_dir}/script/check")
175 end
180 end
176
181
177 # generating test_request directory
182 # generating test_request directory
178 puts "generating test_request template"
183 puts "generating test_request template"
179 FileUtils.mkdir_p("#{ev_dir}/test_request/#{problem}/script")
184 FileUtils.mkdir_p("#{ev_dir}/test_request/#{problem}/script")
180 FileUtils.mkdir_p("#{ev_dir}/test_request/#{problem}/test_cases/1")
185 FileUtils.mkdir_p("#{ev_dir}/test_request/#{problem}/test_cases/1")
@@ -183,16 +188,16
183 test_request_all_test_cfg = ERB.new(template)
188 test_request_all_test_cfg = ERB.new(template)
184
189
185 cfg_file = File.open("#{ev_dir}/test_request/#{problem}/test_cases/all_tests.cfg","w")
190 cfg_file = File.open("#{ev_dir}/test_request/#{problem}/test_cases/all_tests.cfg","w")
186 cfg_file.puts test_request_all_test_cfg.result
191 cfg_file.puts test_request_all_test_cfg.result
187 cfg_file.close
192 cfg_file.close
188
193
189 - File.copy("#{SCRIPT_DIR}/templates/check_empty",
194 + FileUtils.cp("#{SCRIPT_DIR}/templates/check_empty",
190 - "#{ev_dir}/test_request/#{problem}/script/check")
195 + "#{ev_dir}/test_request/#{problem}/script/check")
191 - File.copy("#{SCRIPT_DIR}/templates/answer-1.txt",
196 + FileUtils.cp("#{SCRIPT_DIR}/templates/answer-1.txt",
192 - "#{ev_dir}/test_request/#{problem}/test_cases/1")
197 + "#{ev_dir}/test_request/#{problem}/test_cases/1")
193
198
194 puts "done"
199 puts "done"
195 end
200 end
196
201
197
202
198 SCRIPT_DIR = File.dirname(__FILE__)
203 SCRIPT_DIR = File.dirname(__FILE__)
You need to be logged in to leave comments. Login now