Description:
quick fix for ruby
right now, ruby will do just minimal checking...
consider using rubinius for running ruby
Commit status:
[Not Reviewed]
References:
Diff options:
Comments:
0 Commit comments
0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
r155:f8b072255536 - - 1 file changed: 4 inserted, 3 deleted
@@ -6,49 +6,49 | |||||
|
6 | # |
|
6 | # |
|
7 | # Standard Compile Script |
|
7 | # Standard Compile Script |
|
8 | # |
|
8 | # |
|
9 | # Supported compilers: |
|
9 | # Supported compilers: |
|
10 | # gcc, g++, and fpc. |
|
10 | # gcc, g++, and fpc. |
|
11 | # |
|
11 | # |
|
12 | ############################## |
|
12 | ############################## |
|
13 |
|
13 | ||
|
14 | def talk(str='') |
|
14 | def talk(str='') |
|
15 | if ENV['TALKATIVE']!=nil |
|
15 | if ENV['TALKATIVE']!=nil |
|
16 | puts str |
|
16 | puts str |
|
17 | end |
|
17 | end |
|
18 | if ENV['GRADER_LOGGING']!=nil |
|
18 | if ENV['GRADER_LOGGING']!=nil |
|
19 | log_fname = ENV['GRADER_LOGGING'] |
|
19 | log_fname = ENV['GRADER_LOGGING'] |
|
20 | fp = File.open(log_fname,"a") |
|
20 | fp = File.open(log_fname,"a") |
|
21 | fp.puts("run: #{Time.new.strftime("%H:%M")} #{str}") |
|
21 | fp.puts("run: #{Time.new.strftime("%H:%M")} #{str}") |
|
22 | fp.close |
|
22 | fp.close |
|
23 | end |
|
23 | end |
|
24 | end |
|
24 | end |
|
25 |
|
25 | ||
|
26 | C_COMPILER = "/usr/bin/gcc" |
|
26 | C_COMPILER = "/usr/bin/gcc" |
|
27 | CPLUSPLUS_COMPILER = "/usr/bin/g++" |
|
27 | CPLUSPLUS_COMPILER = "/usr/bin/g++" |
|
28 | PASCAL_COMPILER = "/usr/bin/fpc" |
|
28 | PASCAL_COMPILER = "/usr/bin/fpc" |
|
29 | JAVA_COMPILER = "/usr/bin/javac" |
|
29 | JAVA_COMPILER = "/usr/bin/javac" |
|
30 |
- RUBY_INTERPRETER = "/ |
|
30 | + RUBY_INTERPRETER = "/usr/bin/ruby" |
|
31 | PYTHON_INTERPRETER = "/usr/bin/python" |
|
31 | PYTHON_INTERPRETER = "/usr/bin/python" |
|
32 | PYTHON_CHECKER = "/usr/bin/pyflakes" |
|
32 | PYTHON_CHECKER = "/usr/bin/pyflakes" |
|
33 |
|
33 | ||
|
34 | C_OPTIONS = "-O2 -s -static -std=c99 -DCONTEST -lm -Wall" |
|
34 | C_OPTIONS = "-O2 -s -static -std=c99 -DCONTEST -lm -Wall" |
|
35 | CPLUSPLUS_OPTIONS = "-O2 -s -static -DCONTEST -lm -Wall" |
|
35 | CPLUSPLUS_OPTIONS = "-O2 -s -static -DCONTEST -lm -Wall" |
|
36 | PASCAL_OPTIONS = "-O1 -XS -dCONTEST" |
|
36 | PASCAL_OPTIONS = "-O1 -XS -dCONTEST" |
|
37 | JAVA_OPTIONS = "" |
|
37 | JAVA_OPTIONS = "" |
|
38 | PYTHON_OPTIONS = "" |
|
38 | PYTHON_OPTIONS = "" |
|
39 |
|
39 | ||
|
40 | # Check for the correct number of arguments. Otherwise, print usage. |
|
40 | # Check for the correct number of arguments. Otherwise, print usage. |
|
41 | if ARGV.length == 0 or ARGV.length > 4 |
|
41 | if ARGV.length == 0 or ARGV.length > 4 |
|
42 | puts "Usage: compile <language> [<source-file>] [<output-file>] [<message-file>]" |
|
42 | puts "Usage: compile <language> [<source-file>] [<output-file>] [<message-file>]" |
|
43 | puts |
|
43 | puts |
|
44 | puts "<source-file> is defaulted to \"source\"." |
|
44 | puts "<source-file> is defaulted to \"source\"." |
|
45 | puts "<output-file> is defaulted to \"a.out\"." |
|
45 | puts "<output-file> is defaulted to \"a.out\"." |
|
46 | puts "<message-file> is defaulted to \"compiler_message\"." |
|
46 | puts "<message-file> is defaulted to \"compiler_message\"." |
|
47 | puts |
|
47 | puts |
|
48 | exit(127) |
|
48 | exit(127) |
|
49 | end |
|
49 | end |
|
50 |
|
50 | ||
|
51 | PARAMS = { |
|
51 | PARAMS = { |
|
52 | :source_file => [1,'source'], |
|
52 | :source_file => [1,'source'], |
|
53 | :output_file => [2,'a.out'], |
|
53 | :output_file => [2,'a.out'], |
|
54 | :message_file => [3,'compiler_message'] |
|
54 | :message_file => [3,'compiler_message'] |
@@ -100,57 +100,58 | |||||
|
100 |
|
100 | ||
|
101 | when "pas" |
|
101 | when "pas" |
|
102 | command = "#{PASCAL_COMPILER} #{params[:source_file]} -ooutpas #{PASCAL_OPTIONS} > #{params[:message_file]}" |
|
102 | command = "#{PASCAL_COMPILER} #{params[:source_file]} -ooutpas #{PASCAL_OPTIONS} > #{params[:message_file]}" |
|
103 | system(command) |
|
103 | system(command) |
|
104 | FileUtils.mv("output", params[:output_file]) |
|
104 | FileUtils.mv("output", params[:output_file]) |
|
105 |
|
105 | ||
|
106 | when "java" |
|
106 | when "java" |
|
107 | #rename the file to the public class name |
|
107 | #rename the file to the public class name |
|
108 |
|
108 | ||
|
109 | #get the class name |
|
109 | #get the class name |
|
110 | classname = 'DUMMY' |
|
110 | classname = 'DUMMY' |
|
111 | File.foreach(params[:source_file]) do |line| |
|
111 | File.foreach(params[:source_file]) do |line| |
|
112 | md = /\s*public\s*class\s*(\w*)/.match(line) |
|
112 | md = /\s*public\s*class\s*(\w*)/.match(line) |
|
113 | classname=md[1] if md |
|
113 | classname=md[1] if md |
|
114 | end |
|
114 | end |
|
115 | system("cp #{params[:source_file]} #{classname}.java") |
|
115 | system("cp #{params[:source_file]} #{classname}.java") |
|
116 | command = "#{JAVA_COMPILER} #{classname}.java 2> #{params[:message_file]}" |
|
116 | command = "#{JAVA_COMPILER} #{classname}.java 2> #{params[:message_file]}" |
|
117 | system(command) |
|
117 | system(command) |
|
118 | if File.exists?(classname + ".class") |
|
118 | if File.exists?(classname + ".class") |
|
119 | File.open(params[:output_file],"w") {|file| file.write("#!/bin/sh\n/usr/bin/java #{classname}\n")} |
|
119 | File.open(params[:output_file],"w") {|file| file.write("#!/bin/sh\n/usr/bin/java #{classname}\n")} |
|
120 | File.chmod(0755, params[:output_file]) |
|
120 | File.chmod(0755, params[:output_file]) |
|
121 | end |
|
121 | end |
|
122 |
|
122 | ||
|
123 | when "ruby" |
|
123 | when "ruby" |
|
124 | - command = "#{RUBY_INTERPRETER} -c #{params[:source_file]} > #{params[:message_file]}" |
|
124 | + command = "#{RUBY_INTERPRETER} -c #{params[:source_file]} 2> #{params[:message_file]}" |
|
125 | - system(command) |
|
125 | + if system(command) |
|
126 | File.open(params[:output_file],"w") do |out_file| |
|
126 | File.open(params[:output_file],"w") do |out_file| |
|
127 | out_file.puts "#!#{RUBY_INTERPRETER}" |
|
127 | out_file.puts "#!#{RUBY_INTERPRETER}" |
|
128 | File.open(params[:source_file],"r").each do |line| |
|
128 | File.open(params[:source_file],"r").each do |line| |
|
129 | out_file.print line |
|
129 | out_file.print line |
|
130 | end |
|
130 | end |
|
131 | end |
|
131 | end |
|
132 | File.chmod(0755, params[:output_file]) |
|
132 | File.chmod(0755, params[:output_file]) |
|
|
133 | + end | ||
|
133 |
|
134 | ||
|
134 | when "python" |
|
135 | when "python" |
|
135 | command = "#{PYTHON_CHECKER} #{params[:source_file]} > #{params[:message_file]}" |
|
136 | command = "#{PYTHON_CHECKER} #{params[:source_file]} > #{params[:message_file]}" |
|
136 | if system(command) |
|
137 | if system(command) |
|
137 | #compile to python bytecode |
|
138 | #compile to python bytecode |
|
138 | command = "#{PYTHON_INTERPRETER} -m py_compile #{params[:source_file]}" |
|
139 | command = "#{PYTHON_INTERPRETER} -m py_compile #{params[:source_file]}" |
|
139 | puts "compile: #{command}" |
|
140 | puts "compile: #{command}" |
|
140 | system(command) |
|
141 | system(command) |
|
141 | puts "pwd: " + Dir.pwd |
|
142 | puts "pwd: " + Dir.pwd |
|
142 | Dir.new('.').each {|file| puts file} |
|
143 | Dir.new('.').each {|file| puts file} |
|
143 | File.open(params[:output_file],"w") do |out_file| |
|
144 | File.open(params[:output_file],"w") do |out_file| |
|
144 | out_file.puts "#!#{PYTHON_INTERPRETER} #{params[:source_file]}c" |
|
145 | out_file.puts "#!#{PYTHON_INTERPRETER} #{params[:source_file]}c" |
|
145 | end |
|
146 | end |
|
146 | File.chmod(0755, params[:output_file]) |
|
147 | File.chmod(0755, params[:output_file]) |
|
147 | end |
|
148 | end |
|
148 |
|
149 | ||
|
149 | else |
|
150 | else |
|
150 | talk("ERROR: Invalid language specified!") |
|
151 | talk("ERROR: Invalid language specified!") |
|
151 | open(params[:message_file],"w") do |f| |
|
152 | open(params[:message_file],"w") do |f| |
|
152 | f.puts "ERROR: Invalid language specified!" |
|
153 | f.puts "ERROR: Invalid language specified!" |
|
153 | end |
|
154 | end |
|
154 | exit(127) |
|
155 | exit(127) |
|
155 | end |
|
156 | end |
|
156 |
|
157 |
You need to be logged in to leave comments.
Login now