Skip to content

Commit

Permalink
Support error_on_expect_mismatch declaration in Racc grammar file
Browse files Browse the repository at this point in the history
`expect` warns the difference between expected S/R conflicts count
and actual count however racc command exits with success.
racc command will exit with failure if `error_on_expect_mismatch` declaration
is specified therefore build process of racc user will also fail.
  • Loading branch information
yui-knk committed May 17, 2024
1 parent 0c0f585 commit 8f4ad92
Show file tree
Hide file tree
Showing 6 changed files with 28 additions and 0 deletions.
3 changes: 3 additions & 0 deletions bin/racc
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,9 @@ def main
end

profiler.report
if states.should_error_on_expect_mismatch?
raise Racc::CompileError, "#{states.grammar.n_expected_srconflicts} shift/reduce conflicts are expected but #{states.n_srconflicts} shift/reduce conflicts exist"
end
rescue Racc::Error, Errno::ENOENT, Errno::EPERM => err
raise if $DEBUG or debug_flags.any?
lineno = err.message.slice(/\A\d+:/).to_s
Expand Down
2 changes: 2 additions & 0 deletions lib/racc/grammar.rb
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ def initialize(debug_flags = DebugFlags.new)
@rules = [] # :: [Rule]
@start = nil
@n_expected_srconflicts = nil
@error_on_expect_mismatch = nil
@prec_table = []
@prec_table_closed = false
@closed = false
Expand All @@ -36,6 +37,7 @@ def initialize(debug_flags = DebugFlags.new)
attr_reader :start
attr_reader :symboltable
attr_accessor :n_expected_srconflicts
attr_accessor :error_on_expect_mismatch

def [](x)
@rules[x]
Expand Down
4 changes: 4 additions & 0 deletions lib/racc/grammarfileparser.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,9 @@ module Racc
raise CompileError, "`expect' seen twice"
end
@grammar.n_expected_srconflicts = num
}\
| seq(:ERROR_ON_EXPECT_MISMATCH) {|*|
@grammar.error_on_expect_mismatch = true
}

g.convdef = seq(:symbol, :STRING) {|sym, code|
Expand Down Expand Up @@ -493,6 +496,7 @@ def next_line
'options' => :OPTION,
'start' => :START,
'expect' => :EXPECT,
'error_on_expect_mismatch' => :ERROR_ON_EXPECT_MISMATCH,
'class' => :CLASS,
'rule' => :RULE,
'end' => :END
Expand Down
4 changes: 4 additions & 0 deletions lib/racc/state.rb
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ def should_report_srconflict?
(n_srconflicts() != @grammar.n_expected_srconflicts)
end

def should_error_on_expect_mismatch?
should_report_srconflict? && @grammar.error_on_expect_mismatch
end

def srconflict_exist?
n_srconflicts() != 0
end
Expand Down
8 changes: 8 additions & 0 deletions test/assets/error_on_expect_mismatch.y
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
class E
expect 0
error_on_expect_mismatch
rule
list: inlist inlist
inlist:
| A
end
7 changes: 7 additions & 0 deletions test/test_racc_command.rb
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,13 @@ def test_expect_y
assert_debugfile 'expect.y', [1,0,0,0,1]
end

def test_error_on_expect_mismatch
assert_raise_with_message(Test::Unit::AssertionFailedError, /0 shift\/reduce conflicts are expected but 1 shift\/reduce conflicts exist/) {
assert_compile 'error_on_expect_mismatch.y'
}
assert_debugfile 'error_on_expect_mismatch.y', [1,0,0,0,0]
end

def test_nullbug1_y
assert_compile 'nullbug1.y'
assert_debugfile 'nullbug1.y', [0,0,0,0]
Expand Down

0 comments on commit 8f4ad92

Please sign in to comment.