Rename Rule to RuleSet

This commit is contained in:
Josh Holtrop 2022-05-30 15:49:12 -04:00
parent 164a4854fb
commit a0af8b0d7c
3 changed files with 17 additions and 17 deletions

View File

@ -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

View File

@ -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

View File

@ -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