Rename Rule to RuleSet
This commit is contained in:
parent
164a4854fb
commit
a0af8b0d7c
@ -13,7 +13,7 @@ require_relative "propane/parser/item_set"
|
|||||||
require_relative "propane/regex"
|
require_relative "propane/regex"
|
||||||
require_relative "propane/regex/nfa"
|
require_relative "propane/regex/nfa"
|
||||||
require_relative "propane/regex/unit"
|
require_relative "propane/regex/unit"
|
||||||
require_relative "propane/rule"
|
require_relative "propane/rule_set"
|
||||||
require_relative "propane/token"
|
require_relative "propane/token"
|
||||||
require_relative "propane/version"
|
require_relative "propane/version"
|
||||||
|
|
||||||
@ -36,7 +36,7 @@ class Propane
|
|||||||
|
|
||||||
def initialize(input)
|
def initialize(input)
|
||||||
@tokens = {}
|
@tokens = {}
|
||||||
@rules = {}
|
@rule_sets = {}
|
||||||
input = input.gsub("\r\n", "\n")
|
input = input.gsub("\r\n", "\n")
|
||||||
while !input.empty?
|
while !input.empty?
|
||||||
parse_grammar(input)
|
parse_grammar(input)
|
||||||
@ -46,7 +46,7 @@ class Propane
|
|||||||
def generate(output_file, log_file)
|
def generate(output_file, log_file)
|
||||||
expand_rules
|
expand_rules
|
||||||
lexer = Lexer.new(@tokens)
|
lexer = Lexer.new(@tokens)
|
||||||
parser = Parser.new(@tokens, @rules)
|
parser = Parser.new(@tokens, @rule_sets)
|
||||||
classname = @classname || File.basename(output_file).sub(%r{[^a-zA-Z0-9].*}, "").capitalize
|
classname = @classname || File.basename(output_file).sub(%r{[^a-zA-Z0-9].*}, "").capitalize
|
||||||
erb = ERB.new(File.read(File.join(File.dirname(File.expand_path(__FILE__)), "../assets/parser.d.erb")), trim_mode: "<>")
|
erb = ERB.new(File.read(File.join(File.dirname(File.expand_path(__FILE__)), "../assets/parser.d.erb")), trim_mode: "<>")
|
||||||
result = erb.result(binding.clone)
|
result = erb.result(binding.clone)
|
||||||
@ -85,8 +85,8 @@ class Propane
|
|||||||
elsif input.slice!(/\A(\S+)\s*:\s*\[(.*?)\] <<\n(.*?)^>>\n/m)
|
elsif input.slice!(/\A(\S+)\s*:\s*\[(.*?)\] <<\n(.*?)^>>\n/m)
|
||||||
rule_name, components, code = $1, $2, $3
|
rule_name, components, code = $1, $2, $3
|
||||||
components = components.strip.split(/\s+/)
|
components = components.strip.split(/\s+/)
|
||||||
@rules[rule_name] ||= Rule.new(rule_name, @rules.size)
|
@rule_sets[rule_name] ||= RuleSet.new(rule_name, @rule_sets.size)
|
||||||
@rules[rule_name].add_pattern(components, code)
|
@rule_sets[rule_name].add_pattern(components, code)
|
||||||
else
|
else
|
||||||
if input.size > 25
|
if input.size > 25
|
||||||
input = input.slice(0..20) + "..."
|
input = input.slice(0..20) + "..."
|
||||||
@ -96,21 +96,21 @@ class Propane
|
|||||||
end
|
end
|
||||||
|
|
||||||
def expand_rules
|
def expand_rules
|
||||||
@rules.each do |rule_name, rule|
|
@rule_sets.each do |rule_name, rule_set|
|
||||||
if @tokens.include?(rule_name)
|
if @tokens.include?(rule_name)
|
||||||
raise Error.new("Rule name collides with token name #{rule_name}")
|
raise Error.new("Rule name collides with token name #{rule_name}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
unless @rules["Start"]
|
unless @rule_sets["Start"]
|
||||||
raise Error.new("Start rule not found")
|
raise Error.new("Start rule not found")
|
||||||
end
|
end
|
||||||
@rules.each do |rule_name, rule|
|
@rule_sets.each do |rule_name, rule_set|
|
||||||
rule.patterns.each do |rule|
|
rule_set.patterns.each do |rule|
|
||||||
rule.components.map! do |component|
|
rule.components.map! do |component|
|
||||||
if @tokens[component]
|
if @tokens[component]
|
||||||
@tokens[component]
|
@tokens[component]
|
||||||
elsif @rules[component]
|
elsif @rule_sets[component]
|
||||||
@rules[component]
|
@rule_sets[component]
|
||||||
else
|
else
|
||||||
raise Error.new("Symbol #{component} not found")
|
raise Error.new("Symbol #{component} not found")
|
||||||
end
|
end
|
||||||
|
@ -28,7 +28,7 @@ class Propane
|
|||||||
end
|
end
|
||||||
|
|
||||||
def closed_items
|
def closed_items
|
||||||
if @pattern.components[@position].is_a?(Rule)
|
if @pattern.components[@position].is_a?(RuleSet)
|
||||||
@pattern.components[@position].patterns.map do |pattern|
|
@pattern.components[@position].patterns.map do |pattern|
|
||||||
Item.new(pattern, 0)
|
Item.new(pattern, 0)
|
||||||
end
|
end
|
||||||
@ -60,7 +60,7 @@ class Propane
|
|||||||
if @position == @pattern.components.size
|
if @position == @pattern.components.size
|
||||||
parts << "."
|
parts << "."
|
||||||
end
|
end
|
||||||
"#{@pattern.rule.name} -> #{parts.join(" ")}"
|
"#{@pattern.rule_set.name} -> #{parts.join(" ")}"
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -1,17 +1,17 @@
|
|||||||
class Propane
|
class Propane
|
||||||
|
|
||||||
class Rule
|
class RuleSet
|
||||||
|
|
||||||
class Pattern
|
class Pattern
|
||||||
|
|
||||||
attr_reader :rule
|
attr_reader :rule_set
|
||||||
|
|
||||||
attr_reader :components
|
attr_reader :components
|
||||||
|
|
||||||
attr_reader :code
|
attr_reader :code
|
||||||
|
|
||||||
def initialize(rule, components, code)
|
def initialize(rule_set, components, code)
|
||||||
@rule = rule
|
@rule_set = rule_set
|
||||||
@components = components
|
@components = components
|
||||||
@code = code
|
@code = code
|
||||||
end
|
end
|
Loading…
x
Reference in New Issue
Block a user