summaryrefslogtreecommitdiff
path: root/t/lib/warnings/9uninit
diff options
context:
space:
mode:
authorFather Chrysostomos <sprout@cpan.org>2011-11-22 09:31:31 -0800
committerFather Chrysostomos <sprout@cpan.org>2011-11-22 09:32:57 -0800
commit73b42cee7a0466e4aa372ad35c8c09e0ad5e4a6f (patch)
tree4da18ec896d6f2c92680acd12f9dd127e7ee7b27 /t/lib/warnings/9uninit
parent50de2b3a27dc3b906062d35ae0f9733aa106baf3 (diff)
downloadperl-73b42cee7a0466e4aa372ad35c8c09e0ad5e4a6f.tar.gz
[perl #103766] Wrong $" warning in perl 5.14
This code: "@{[ $x ]}" was producing the warning: Use of uninitialized value $" in join or string at -e line 1. erroneously, as of commit 6d1f0892c. Commit 6d1f0892c was meant to fix bug #72090, which caused the varia- ble to be mentioned even for the > warning in this instance: $ ./perl -we '$a = @$a > 0' Use of uninitialized value $a in array dereference at -e line 1. Use of uninitialized value $a in numeric gt (>) at -e line 1. The fix for #72090 was wrong, because the loop that it modified loops through the kid ops, finding out how many candidates there are. If there is only one candidate left, it is used. Skipping ops that could be responsible for the undefined value just because we don’t want to mention their variables is the wrong approach, at least in that loop, as the blame will fall on whatever other op is left if there is only one. There is code further up to deal with the OP_RV2[AH]V case, that des- cends explicitly into the child ops. This commit tweaks that code to descend only for the top-level op, to allow @{ $x } to warn still about an uninitialised value used in array dereference. Where @{...} is an operand to the operator that is emitting the warning, we don’t descend. That is how #72090 should have been fixed to begin with, as it has no odd side effects. This bug (#103766) affects any other cases where there are two oper- ands and one is @{...} or %{...}: $ perl5.15.4 -e 'use warnings "uninitialized"; $y = 6; $y + @{ $x }' Use of uninitialized value $x in array dereference at -e line 1. Use of uninitialized value $y in addition (+) at -e line 1. $y is obviously not responsible there.
Diffstat (limited to 't/lib/warnings/9uninit')
-rw-r--r--t/lib/warnings/9uninit6
1 files changed, 6 insertions, 0 deletions
diff --git a/t/lib/warnings/9uninit b/t/lib/warnings/9uninit
index 6123fd03cb..12c1f84022 100644
--- a/t/lib/warnings/9uninit
+++ b/t/lib/warnings/9uninit
@@ -2031,3 +2031,9 @@ $a = @$a > 0;
EXPECT
Use of uninitialized value $a in array dereference at - line 3.
Use of uninitialized value in numeric gt (>) at - line 3.
+########
+# [perl #103766]
+use warnings 'uninitialized';
+"@{[ $x ]}";
+EXPECT
+Use of uninitialized value in join or string at - line 3.