aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNobuyoshi Nakada <nobu@ruby-lang.org>2022-04-21 16:04:36 +0900
committerNobuyoshi Nakada <nobu@ruby-lang.org>2022-04-21 16:04:36 +0900
commit3ddf6ad4d2f6dae4caa00b8c407768c7062099a0 (patch)
tree077a624b7692f090bb9e35fb26738ca426870b54
parentee48c9cda6e918f8da4b23d3ff4fabf7357f4a95 (diff)
downloadruby-3ddf6ad4d2f6dae4caa00b8c407768c7062099a0.tar.gz
Private local variables should shadow outer variables [Bug #18629]
-rw-r--r--parse.y3
-rw-r--r--test/ruby/test_parse.rb4
2 files changed, 6 insertions, 1 deletions
diff --git a/parse.y b/parse.y
index c7ed2edea0..0bf717aa95 100644
--- a/parse.y
+++ b/parse.y
@@ -10994,9 +10994,9 @@ is_private_local_id(ID name)
static int
shadowing_lvar_0(struct parser_params *p, ID name)
{
- if (is_private_local_id(name)) return 1;
if (dyna_in_block(p)) {
if (dvar_curr(p, name)) {
+ if (is_private_local_id(name)) return 1;
yyerror0("duplicated argument name");
}
else if (dvar_defined(p, name) || local_id(p, name)) {
@@ -11009,6 +11009,7 @@ shadowing_lvar_0(struct parser_params *p, ID name)
}
else {
if (local_id(p, name)) {
+ if (is_private_local_id(name)) return 1;
yyerror0("duplicated argument name");
}
}
diff --git a/test/ruby/test_parse.rb b/test/ruby/test_parse.rb
index d697a29c1c..2841e20f6d 100644
--- a/test/ruby/test_parse.rb
+++ b/test/ruby/test_parse.rb
@@ -930,6 +930,10 @@ x = __ENCODING__
assert_no_warning(/shadowing outer local variable/) {eval("a=1; tap {|a|}")}
end
+ def test_shadowing_private_local_variable
+ assert_equal 1, eval("_ = 1; [[2]].each{ |(_)| }; _")
+ end
+
def test_unused_variable
o = Object.new
assert_warning(/assigned but unused variable/) {o.instance_eval("def foo; a=1; nil; end")}