summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-05-11 02:01:46 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-05-11 02:01:46 +0000
commit4a680e81f2a7521518890bc6f0dd94411efff7f7 (patch)
tree4054bda6c3039de7c7730def57a008b4842aa873
parent7829c32eaf4bfbd0bdd4a63cf13dd09929057c8c (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--ChangeLog5
-rw-r--r--parse.y9
-rw-r--r--test/ruby/test_syntax.rb5
-rw-r--r--version.h8
4 files changed, 21 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 2e3c25acfc..31978e57a8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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
diff --git a/parse.y b/parse.y
index d091a0e6ef..e374ccf3ca 100644
--- a/parse.y
+++ b/parse.y
@@ -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)
diff --git a/version.h b/version.h
index 50ee1b07af..1d5d988077 100644
--- a/version.h
+++ b/version.h
@@ -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"