2010-07-25 17:54:09 +02:00
|
|
|
SRC_DIR = "src"
|
|
|
|
LIB_DIR = "lib"
|
|
|
|
BIN_DIR = "bin"
|
|
|
|
|
2010-08-15 19:38:15 +02:00
|
|
|
PEGJS = "#{BIN_DIR}/pegjs"
|
|
|
|
|
|
|
|
SRC_FILES = Dir["#{SRC_DIR}/**/*.js"]
|
|
|
|
|
|
|
|
PEGJS_SRC_FILE = "#{SRC_DIR}/peg.js"
|
|
|
|
PEGJS_OUT_FILE = "#{LIB_DIR}/peg.js"
|
|
|
|
|
|
|
|
PARSER_SRC_FILE = "#{SRC_DIR}/parser.pegjs"
|
|
|
|
PARSER_OUT_FILE = "#{SRC_DIR}/parser.js"
|
|
|
|
|
2010-11-14 17:11:36 +01:00
|
|
|
PEGJS_VERSION = File.read("VERSION").strip
|
|
|
|
|
|
|
|
def preprocess(input, base_dir, version)
|
2010-07-25 17:54:09 +02:00
|
|
|
input.split("\n").map do |line|
|
|
|
|
if line =~ /^\s*\/\/\s*@include\s*"([^"]*)"\s*$/
|
|
|
|
included_file = "#{base_dir}/#$1"
|
|
|
|
if !File.exist?(included_file)
|
|
|
|
abort "Included file \"#{included_file}\" does not exist."
|
|
|
|
end
|
2010-11-14 17:11:36 +01:00
|
|
|
preprocess(File.read(included_file), base_dir, version)
|
2010-07-25 17:54:09 +02:00
|
|
|
else
|
|
|
|
line
|
|
|
|
end
|
2010-11-14 17:11:36 +01:00
|
|
|
end.join("\n").gsub("@VERSION", version)
|
2010-07-25 17:54:09 +02:00
|
|
|
end
|
|
|
|
|
2010-08-15 19:38:15 +02:00
|
|
|
file PARSER_OUT_FILE => PARSER_SRC_FILE do
|
2010-09-28 16:44:04 +02:00
|
|
|
system "#{PEGJS} --export-var PEG.parser #{PARSER_SRC_FILE} #{PARSER_OUT_FILE}"
|
2010-07-25 17:54:09 +02:00
|
|
|
end
|
|
|
|
|
2010-08-15 19:38:15 +02:00
|
|
|
file PEGJS_OUT_FILE => SRC_FILES do
|
|
|
|
File.open(PEGJS_OUT_FILE, "w") do |f|
|
2010-11-14 17:11:36 +01:00
|
|
|
f.write(preprocess(File.read(PEGJS_SRC_FILE), SRC_DIR, PEGJS_VERSION))
|
2010-07-25 17:54:09 +02:00
|
|
|
end
|
2010-03-13 15:18:57 +01:00
|
|
|
end
|
2010-07-25 17:54:09 +02:00
|
|
|
|
2010-08-15 19:38:15 +02:00
|
|
|
desc "Generate the grammar parser"
|
|
|
|
task :parser => PARSER_OUT_FILE
|
|
|
|
|
|
|
|
desc "Build the peg.js file"
|
|
|
|
task :build => PEGJS_OUT_FILE
|
|
|
|
|
2010-07-25 17:54:09 +02:00
|
|
|
task :default => :build
|