diff options
-rw-r--r-- | parse.y | 19 | ||||
-rw-r--r-- | test/ruby/test_syntax.rb | 18 | ||||
-rw-r--r-- | version.h | 6 |
3 files changed, 38 insertions, 5 deletions
@@ -6394,7 +6394,14 @@ parser_tokadd_string(struct parser_params *parser, switch (c) { case '\n': if (func & STR_FUNC_QWORDS) break; - if (func & STR_FUNC_EXPAND) continue; + if (func & STR_FUNC_EXPAND) { + if (!(func & STR_FUNC_INDENT) || (heredoc_indent < 0)) + continue; + if (c == term) { + c = '\\'; + goto terminate; + } + } tokadd('\\'); break; @@ -6475,6 +6482,7 @@ parser_tokadd_string(struct parser_params *parser, } tokadd(c); } + terminate: if (enc) *encp = enc; return c; } @@ -7019,7 +7027,13 @@ parser_here_document(struct parser_params *parser, rb_strterm_heredoc_t *here) return 0; } bol = was_bol(); - if (bol && whole_match_p(eos, len, indent)) { + /* `heredoc_line_indent == -1` means + * - "after an interpolation in the same line", or + * - "in a continuing line" + */ + if (bol && + (heredoc_line_indent != -1 || (heredoc_line_indent = 0)) && + whole_match_p(eos, len, indent)) { dispatch_heredoc_end(); heredoc_restore(&lex_strterm->u.heredoc); lex_strterm = 0; @@ -7090,6 +7104,7 @@ parser_here_document(struct parser_params *parser, rb_strterm_heredoc_t *here) goto restore; } if (c != '\n') { + if (c == '\\') heredoc_line_indent = -1; flush: str = STR_NEW3(tok(), toklen(), enc, func); flush_str: diff --git a/test/ruby/test_syntax.rb b/test/ruby/test_syntax.rb index 7e25d965df..b81ec9096d 100644 --- a/test/ruby/test_syntax.rb +++ b/test/ruby/test_syntax.rb @@ -678,6 +678,24 @@ e" assert_dedented_heredoc(expected, result) end + def test_dedented_heredoc_continued_line + result = " 1\\\n" " 2\n" + expected = "1\\\n" "2\n" + assert_dedented_heredoc(expected, result) + assert_syntax_error("#{<<~"begin;"}\n#{<<~'end;'}", /can't find string "TEXT"/) + begin; + <<-TEXT + \ + TEXT + end; + assert_syntax_error("#{<<~"begin;"}\n#{<<~'end;'}", /can't find string "TEXT"/) + begin; + <<~TEXT + \ + TEXT + end; + end + def test_lineno_after_heredoc bug7559 = '[ruby-dev:46737]' expected, _, actual = __LINE__, <<eom, __LINE__ @@ -1,10 +1,10 @@ #define RUBY_VERSION "2.5.4" -#define RUBY_RELEASE_DATE "2019-02-05" -#define RUBY_PATCHLEVEL 139 +#define RUBY_RELEASE_DATE "2019-02-11" +#define RUBY_PATCHLEVEL 140 #define RUBY_RELEASE_YEAR 2019 #define RUBY_RELEASE_MONTH 2 -#define RUBY_RELEASE_DAY 5 +#define RUBY_RELEASE_DAY 11 #include "ruby/version.h" |