From c093d46f4f217b0e8f6ba683f12a3c287ae60eec Mon Sep 17 00:00:00 2001 From: naruse Date: Sat, 11 Mar 2017 12:53:45 +0000 Subject: [PATCH] merge revision(s) 57198: [Backport #13073] parse.y: preserve cmdarg stack * parse.y (do_body): preserve cmdarg stack around do/end block. [ruby-core:78837] [Bug #13073] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_4@57837 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- parse.y | 2 +- test/ruby/test_syntax.rb | 9 +++++++++ version.h | 2 +- 3 files changed, 11 insertions(+), 2 deletions(-) diff --git a/parse.y b/parse.y index 85cbc37331..8a800bbd50 100644 --- a/parse.y +++ b/parse.y @@ -3762,7 +3762,7 @@ brace_body : {$$ = dyna_push();} ; do_body : {$$ = dyna_push();} - {$$ = cmdarg_stack >> 1; CMDARG_SET(0);} + {$$ = cmdarg_stack; CMDARG_SET(0);} opt_block_param compstmt { $$ = new_do_body($3, $4); diff --git a/test/ruby/test_syntax.rb b/test/ruby/test_syntax.rb index 3e6212e27c..f40f15316b 100644 --- a/test/ruby/test_syntax.rb +++ b/test/ruby/test_syntax.rb @@ -917,6 +917,15 @@ eom end end + def test_do_block_in_hash_brace + bug13073 = '[ruby-core:78837] [Bug #13073]' + assert_valid_syntax 'p :foo, {a: proc do end, b: proc do end}', bug13073 + assert_valid_syntax 'p :foo, {:a => proc do end, b: proc do end}', bug13073 + assert_valid_syntax 'p :foo, {"a": proc do end, b: proc do end}', bug13073 + assert_valid_syntax 'p :foo, {** proc do end, b: proc do end}', bug13073 + assert_valid_syntax 'p :foo, {proc do end => proc do end, b: proc do end}', bug13073 + end + def test_do_after_local_variable obj = Object.new def obj.m; yield; end diff --git a/version.h b/version.h index 2e2d074a4e..afefdc7510 100644 --- a/version.h +++ b/version.h @@ -1,6 +1,6 @@ #define RUBY_VERSION "2.4.0" #define RUBY_RELEASE_DATE "2017-03-11" -#define RUBY_PATCHLEVEL 5 +#define RUBY_PATCHLEVEL 6 #define RUBY_RELEASE_YEAR 2017 #define RUBY_RELEASE_MONTH 3