summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-03-11 12:53:45 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-03-11 12:53:45 +0000
commitc093d46f4f217b0e8f6ba683f12a3c287ae60eec (patch)
treea6ba6bfa880609c48eeb665860d805d0ee84e63f
parent927c116d0c098a28082a22b15d7daa26ed560591 (diff)
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
-rw-r--r--parse.y2
-rw-r--r--test/ruby/test_syntax.rb9
-rw-r--r--version.h2
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 : {$<vars>$ = dyna_push();}
;
do_body : {$<vars>$ = dyna_push();}
- {$<val>$ = cmdarg_stack >> 1; CMDARG_SET(0);}
+ {$<val>$ = 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