diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-05-11 02:01:46 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-05-11 02:01:46 +0000 |
commit | 4a680e81f2a7521518890bc6f0dd94411efff7f7 (patch) | |
tree | 4054bda6c3039de7c7730def57a008b4842aa873 | |
parent | 7829c32eaf4bfbd0bdd4a63cf13dd09929057c8c (diff) |
merge revision(s) 50402: [Backport #11107]
* parse.y (lambda): push and reset cmdarg_stack in lambda body.
[ruby-core:69017] [Bug #11107]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@50468 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | parse.y | 9 | ||||
-rw-r--r-- | test/ruby/test_syntax.rb | 5 | ||||
-rw-r--r-- | version.h | 8 |
4 files changed, 21 insertions, 6 deletions
@@ -1,3 +1,8 @@ +Mon May 11 10:59:53 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * parse.y (lambda): push and reset cmdarg_stack in lambda body. + [ruby-core:69017] [Bug #11107] + Tue Apr 28 14:15:49 2015 Nobuyoshi Nakada <nobu@ruby-lang.org> * lib/fileutils.rb (FileUtils#mv): show the exact target path in @@ -3467,14 +3467,19 @@ lambda : { { $<num>$ = ruby_sourceline; } + { + $<val>$ = cmdarg_stack; + cmdarg_stack = 0; + } lambda_body { lpar_beg = $<num>2; + cmdarg_stack = $<val>5; /*%%%*/ - $$ = NEW_LAMBDA($3, $5); + $$ = NEW_LAMBDA($3, $6); nd_set_line($$, $<num>4); /*% - $$ = dispatch2(lambda, $3, $5); + $$ = dispatch2(lambda, $3, $6); %*/ dyna_pop($<vars>1); } diff --git a/test/ruby/test_syntax.rb b/test/ruby/test_syntax.rb index 692763ef98..342186170f 100644 --- a/test/ruby/test_syntax.rb +++ b/test/ruby/test_syntax.rb @@ -266,6 +266,11 @@ WARN assert_valid_syntax("bar def foo; self.each do end end", bug9308) end + def test_do_block_in_lambda + bug11107 = '[ruby-core:69017] [Bug #11107]' + assert_valid_syntax('p ->() do a() do end end', bug11107) + end + def test_reserved_method_no_args bug6403 = '[ruby-dev:45626]' assert_valid_syntax("def self; :foo; end", __FILE__, bug6403) @@ -1,10 +1,10 @@ #define RUBY_VERSION "2.1.7" -#define RUBY_RELEASE_DATE "2015-04-28" -#define RUBY_PATCHLEVEL 340 +#define RUBY_RELEASE_DATE "2015-05-11" +#define RUBY_PATCHLEVEL 341 #define RUBY_RELEASE_YEAR 2015 -#define RUBY_RELEASE_MONTH 4 -#define RUBY_RELEASE_DAY 28 +#define RUBY_RELEASE_MONTH 5 +#define RUBY_RELEASE_DAY 11 #include "ruby/version.h" |