summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTSUYUSATO Kitsune <make.just.on@gmail.com>2023-12-11 12:44:33 +0900
committergit <svn-admin@ruby-lang.org>2023-12-11 13:36:37 +0000
commit48cb70fee95dcdcf5f9eef2ef40c3adfecc214fa (patch)
tree3b983fdf0c2800ad5d567bb22814b91752c77888
parenta860e3605c53e708d3cb06e2080ff73b58de4b22 (diff)
[ruby/prism] Fix parsing unterminated empty string `"`
Fix https://github.com/ruby/prism/pull/2034 https://github.com/ruby/prism/commit/8280e577fa
-rw-r--r--prism/prism.c3
-rw-r--r--test/prism/errors_test.rb9
2 files changed, 11 insertions, 1 deletions
diff --git a/prism/prism.c b/prism/prism.c
index 9ca542ba30..1b5d82b4bb 100644
--- a/prism/prism.c
+++ b/prism/prism.c
@@ -13520,7 +13520,8 @@ parse_strings(pm_parser_t *parser, pm_node_t *current) {
pm_token_t opening = parser->current;
parser_lex(parser);
- if (accept1(parser, PM_TOKEN_STRING_END)) {
+ if (match2(parser, PM_TOKEN_STRING_END, PM_TOKEN_EOF)) {
+ expect1(parser, PM_TOKEN_STRING_END, PM_ERR_STRING_LITERAL_TERM);
// If we get here, then we have an end immediately after a
// start. In that case we'll create an empty content token and
// return an uninterpolated string.
diff --git a/test/prism/errors_test.rb b/test/prism/errors_test.rb
index 7744bd8b88..816df4667e 100644
--- a/test/prism/errors_test.rb
+++ b/test/prism/errors_test.rb
@@ -164,6 +164,15 @@ module Prism
assert_equal expr.closing, ""
end
+ def test_unterminated_empty_string
+ expr = expression('"')
+ assert_errors expr, '"', [
+ ["expected a closing delimiter for the string literal", 1..1]
+ ]
+ assert_equal expr.unescaped, ""
+ assert_equal expr.closing, ""
+ end
+
def test_incomplete_instance_var_string
assert_errors expression('%@#@@#'), '%@#@@#', [
["incomplete instance variable", 4..5],