verilog: fix string literal regular expression #5187
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What are the reasons/motivation for this change?
Fix the bug reported in #5160, where a closing quote on a string literal failed to terminate the string when preceded by an escaped backslash.
Originally posted by @mmicko in #5160 (comment)
Explain how this is achieved.
Properly escape the backslash in the regular expression in
verilog_lexer.l
.If applicable, please suggest to reviewers how they can test the change.
See the included regression test
tests/verilog/bug5160.v
, or @mmicko's test case in the original report.With this fix applied, both cases work properly. Before the fix, parsing would fail with a spurious syntax error.