diff options
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | lib/erb.rb | 34 | ||||
-rw-r--r-- | test/erb/test_erb.rb | 4 | ||||
-rw-r--r-- | version.h | 2 |
4 files changed, 12 insertions, 35 deletions
@@ -1,3 +1,10 @@ +Tue Feb 24 02:44:39 2009 Masatoshi SEKI <m_seki@mva.biglobe.ne.jp> + + * lib/erb.rb (PercentScanner): remove PercentScanner. fixed % after + %> bug. [ruby-dev:37751] [Bug #997] + + * test/erb/test_erb.rb: ditto + Tue Feb 24 02:35:29 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> * hash.c (rb_hash_s_create): set nil as the value if assoc length diff --git a/lib/erb.rb b/lib/erb.rb index f1661f98cb..1ed3c60060 100644 --- a/lib/erb.rb +++ b/lib/erb.rb @@ -426,40 +426,6 @@ class ERB end Scanner.regist_scanner(SimpleScanner2, nil, false) - class PercentScanner < Scanner # :nodoc: - def scan(&blk) - stag_reg = /(.*?)(^%%|^%|<%%|<%=|<%#|<%|\z)/m - etag_reg = /(.*?)(%%>|%>|\z)/m - scanner = StringScanner.new(@src) - while ! scanner.eos? - scanner.scan(@stag ? etag_reg : stag_reg) - yield(scanner[1]) - - elem = scanner[2] - if elem == '%%' - yield('%') - inline_scan(scanner.scan(/.*?(\n|\z)/), &blk) - elsif elem == '%' - yield(PercentLine.new(scanner.scan(/.*?(\n|\z)/).chomp)) - else - yield(elem) - end - end - end - - def inline_scan(line) - stag_reg = /(.*?)(<%%|<%=|<%#|<%|\z)/m - etag_reg = /(.*?)(%%>|%>|\z)/m - scanner = StringScanner.new(line) - while ! scanner.eos? - scanner.scan(@stag ? etag_reg : stag_reg) - yield(scanner[1]) - yield(scanner[2]) - end - end - end - Scanner.regist_scanner(PercentScanner, nil, true) - class ExplicitScanner < Scanner # :nodoc: def scan stag_reg = /(.*?)(^[ \t]*<%-|<%%|<%=|<%#|<%-|<%|\z)/m diff --git a/test/erb/test_erb.rb b/test/erb/test_erb.rb index 935998493f..4f2f5bec19 100644 --- a/test/erb/test_erb.rb +++ b/test/erb/test_erb.rb @@ -410,6 +410,10 @@ EOS assert_equal(ans, ERB.new(src, nil, '-').result) assert_equal(ans, ERB.new(src, nil, '-%').result) end + + def test_percent_after_etag + assert_equal("1%", @erb.new("<%= 1 %>%", nil, "%").result) + end end class TestERBCoreWOStrScan < TestERBCore @@ -2,7 +2,7 @@ #define RUBY_RELEASE_DATE "2009-02-24" #define RUBY_VERSION_CODE 187 #define RUBY_RELEASE_CODE 20090224 -#define RUBY_PATCHLEVEL 140 +#define RUBY_PATCHLEVEL 141 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 8 |