diff options
| author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-30 10:30:56 +0000 |
|---|---|---|
| committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-30 10:30:56 +0000 |
| commit | 5024abe0cf17fa479487bf9741b694e20986c085 (patch) | |
| tree | c33797956837abafcdc3b1f40a5265d16ff5f367 | |
| parent | 6aac76353a3a9d57a2ad26f93bb98d6b1a2cb8be (diff) | |
merge revision(s) 58545,58584: [Backport #13536]
ripper/lexer.rb: nested indented heredoc
* ext/ripper/lib/ripper/lexer.rb (on_heredoc_dedent): fix for
nested indedented here documents, where `Elem`s are nested too.
[ruby-core:80977] [Bug #13536]
ripper/lexer.rb: nested indented heredoc
* ext/ripper/lib/ripper/lexer.rb (on_heredoc_dedent): insert
stripped leading spaces as `on_ignored_sp` elements, so that the
original source can be reconsructed.
[ruby-core:80977] [Bug #13536]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@59214 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 9 | ||||
| -rw-r--r-- | ext/ripper/lib/ripper/lexer.rb | 11 | ||||
| -rw-r--r-- | test/ripper/test_lexer.rb | 35 | ||||
| -rw-r--r-- | test/ripper/test_scanner_events.rb | 1 | ||||
| -rw-r--r-- | version.h | 8 |
5 files changed, 58 insertions, 6 deletions
@@ -1,3 +1,12 @@ +Fri Jun 30 19:29:45 2017 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * ext/ripper/lib/ripper/lexer.rb (on_heredoc_dedent): fix for nested + indedented here documents, where Elems are nested too. [Bug #13536] + + * ext/ripper/lib/ripper/lexer.rb (on_heredoc_dedent): insert stripped + leading spaces as on_ignored_sp elements, so that the original source + can be reconsructed. [Bug #13536] + Mon May 1 06:36:57 2017 NAKAMURA Usaku <usa@ruby-lang.org> * parse.y (parser_parse_string): set the mark of term to `nd_func` diff --git a/ext/ripper/lib/ripper/lexer.rb b/ext/ripper/lib/ripper/lexer.rb index 69526340a7..e70db0b1d1 100644 --- a/ext/ripper/lib/ripper/lexer.rb +++ b/ext/ripper/lib/ripper/lexer.rb @@ -66,13 +66,20 @@ class Ripper private def on_heredoc_dedent(v, w) - @buf.last.each do |e| - if e.event == :on_tstring_content + ignored_sp = [] + heredoc = @buf.last + heredoc.each_with_index do |e, i| + if Elem === e and e.event == :on_tstring_content + tok = e.tok.dup if w > 0 and /\A\s/ =~ e.tok if (n = dedent_string(e.tok, w)) > 0 + ignored_sp << [i, Elem.new(e.pos.dup, :on_ignored_sp, tok[0, n])] e.pos[1] += n end end end + ignored_sp.reverse_each do |i, e| + heredoc[i, 0] = [e] + end v end diff --git a/test/ripper/test_lexer.rb b/test/ripper/test_lexer.rb new file mode 100644 index 0000000000..72b7f1b5fd --- /dev/null +++ b/test/ripper/test_lexer.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true +begin + require_relative 'dummyparser' + require 'test/unit' + ripper_test = true + module TestRipper; end +rescue LoadError +end + +class TestRipper::Lexer < Test::Unit::TestCase + def test_nested_dedent_heredoc + bug = '[ruby-core:80977] [Bug #13536]' + str = <<~'E' + <<~"D" + #{ + <<~"B" + this must be a valid ruby + B + } + D + E + assert_equal(str, Ripper.tokenize(str).join(""), bug) + + str = <<~'E' + <<~"D" + #{ + <<~"B" + this must be a valid ruby + B + } + D + E + assert_equal(str, Ripper.tokenize(str).join(""), bug) + end +end diff --git a/test/ripper/test_scanner_events.rb b/test/ripper/test_scanner_events.rb index 8c950041a2..9f185b2a7e 100644 --- a/test/ripper/test_scanner_events.rb +++ b/test/ripper/test_scanner_events.rb @@ -105,6 +105,7 @@ class TestRipper::ScannerEvents < Test::Unit::TestCase Ripper.lex("1r\n2i\n3ri\n4.2r\n5.6ri") assert_equal [[[1, 0], :on_heredoc_beg, "<<~EOS"], [[1, 6], :on_nl, "\n"], + [[2, 0], :on_ignored_sp, " "], [[2, 2], :on_tstring_content, "heredoc\n"], [[3, 0], :on_heredoc_end, "EOS"] ], @@ -1,10 +1,10 @@ #define RUBY_VERSION "2.3.5" -#define RUBY_RELEASE_DATE "2017-05-01" -#define RUBY_PATCHLEVEL 310 +#define RUBY_RELEASE_DATE "2017-06-30" +#define RUBY_PATCHLEVEL 311 #define RUBY_RELEASE_YEAR 2017 -#define RUBY_RELEASE_MONTH 5 -#define RUBY_RELEASE_DAY 1 +#define RUBY_RELEASE_MONTH 6 +#define RUBY_RELEASE_DAY 30 #include "ruby/version.h" |
