From fec1f158eac3f2562ff871129d3d845d9ffc33f4 Mon Sep 17 00:00:00 2001 From: ydah Date: Mon, 10 Jun 2024 00:21:33 +0900 Subject: [PATCH] Refactor `report_unused_terms` --- lib/lrama/states_reporter.rb | 36 ++++++++++++------------------------ 1 file changed, 12 insertions(+), 24 deletions(-) diff --git a/lib/lrama/states_reporter.rb b/lib/lrama/states_reporter.rb index c6022737..c23932d6 100644 --- a/lib/lrama/states_reporter.rb +++ b/lib/lrama/states_reporter.rb @@ -26,37 +26,25 @@ def _report(io, grammar: false, terms: false, states: false, itemsets: false, lo end def report_unused_terms(io) - results = [] - terms = [] - used_symbols = [] - - terms = @states.symbols.select(&:term?) - - @states.states.each do |state| - state.reduces.select do |reduce| - used_symbols << reduce.look_ahead.flatten if !reduce.look_ahead.nil? + look_aheads = @states.states.each do |state| + state.reduces.flat_map do |reduce| + reduce.look_ahead unless reduce.look_ahead.nil? end end - @states.states.each do |state| - used_symbols << state.shifts.map(&:next_sym).select(&:term?).flatten - end - - used_symbols = used_symbols.flatten - - results = terms.select do |term| - !used_symbols.include?(term) + next_terms = @states.states.flat_map do |state| + state.shifts.map(&:next_sym).select(&:term?) end - if !results.empty? - io << "#{results.count} Unused Terms\n\n" + unused_symbols = @states.terms.select do |term| + !(look_aheads + next_terms).include?(term) end - results.each_with_index do |term, index| - io << sprintf("%5d %s\n", index, term.id.s_value) - end - - if !results.empty? + unless unused_symbols.empty? + io << "#{unused_symbols.count} Unused Terms\n\n" + unused_symbols.each_with_index do |term, index| + io << sprintf("%5d %s\n", index, term.id.s_value) + end io << "\n\n" end end