diff options
author | Father Chrysostomos <sprout@cpan.org> | 2011-11-06 01:35:38 -0800 |
---|---|---|
committer | Father Chrysostomos <sprout@cpan.org> | 2011-11-06 02:10:04 -0800 |
commit | 52a6327bb1a7bdbfce3ca5a5bdd9de4531dbaf69 (patch) | |
tree | 8791e2cf0e9c6977adc24b429c230d10da925552 | |
parent | a4a3cf7419a4f30455db08fefe2cac688567ac22 (diff) | |
download | perl-52a6327bb1a7bdbfce3ca5a5bdd9de4531dbaf69.tar.gz |
[perl #96326] *{$io} should not be semi-defined
gv_efullname4 produces undef if the GV points to no stash, instead of
using __ANON__, as it does when the stash has no name.
Instead of going through hoops to try and work around it elsewhere, fix
gv_efullname4.
This means that
$x = *$io;
$x .= "whate’er";
no longer produces an uninitialized warning. (The warning was rather
strange, as defined() returned true.)
This commit also gives the glob the name $__ANONIO__ (yes, with a dol-
lar sign). It may seem a little strange, but there is precedent in
other autovivified globs, such as those open() produces when it cannot
determine the variable name (e.g, open $t->{fh}).
-rw-r--r-- | gv.c | 6 | ||||
-rw-r--r-- | pp.c | 2 | ||||
-rw-r--r-- | sv.c | 14 | ||||
-rw-r--r-- | t/lib/warnings/pp_hot | 2 | ||||
-rw-r--r-- | t/op/gv.t | 12 |
5 files changed, 14 insertions, 22 deletions
@@ -2039,13 +2039,9 @@ Perl_gv_fullname4(pTHX_ SV *sv, const GV *gv, const char *prefix, bool keepmain) PERL_ARGS_ASSERT_GV_FULLNAME4; - if (!hv) { - SvOK_off(sv); - return; - } sv_setpv(sv, prefix ? prefix : ""); - if ((name = HvNAME(hv))) { + if (hv && (name = HvNAME(hv))) { const STRLEN len = HvNAMELEN(hv); if (keepmain || strnNE(name, "main", len)) { sv_catpvn_flags(sv,name,len,HvNAMEUTF8(hv)?SV_CATUTF8:SV_CATBYTES); @@ -165,7 +165,7 @@ S_rv2gv(pTHX_ SV *sv, const bool vivify_sv, const bool strict, sv = SvRV(sv); if (SvTYPE(sv) == SVt_PVIO) { GV * const gv = MUTABLE_GV(sv_newmortal()); - gv_init(gv, 0, "", 0, 0); + gv_init(gv, 0, "$__ANONIO__", 11, 0); GvIOp(gv) = MUTABLE_IO(sv); SvREFCNT_inc_void_NN(sv); sv = MUTABLE_SV(gv); @@ -2958,18 +2958,12 @@ Perl_sv_2pv_flags(pTHX_ register SV *const sv, STRLEN *const lp, const I32 flags gv_efullname3(buffer, gv, "*"); SvFLAGS(gv) |= wasfake; - if (SvPOK(buffer)) { - if (lp) { + assert(SvPOK(buffer)); + if (lp) { *lp = SvCUR(buffer); - } - if ( SvUTF8(buffer) ) SvUTF8_on(sv); - return SvPVX(buffer); - } - else { - if (lp) - *lp = 0; - return (char *)""; } + if ( SvUTF8(buffer) ) SvUTF8_on(sv); + return SvPVX(buffer); } if (lp) diff --git a/t/lib/warnings/pp_hot b/t/lib/warnings/pp_hot index a0b9b10139..e53832a371 100644 --- a/t/lib/warnings/pp_hot +++ b/t/lib/warnings/pp_hot @@ -116,7 +116,7 @@ my $fh = *STDOUT{IO}; close STDOUT or die "Can't close STDOUT"; print $fh "Shouldn't print anything, but shouldn't SEGV either\n"; EXPECT -print() on closed filehandle at - line 7. +print() on closed filehandle $__ANONIO__ at - line 7. ######## # pp_hot.c [pp_print] package foo; @@ -598,10 +598,11 @@ foreach my $type (qw(integer number string)) { # RT #60954 anonymous glob should be defined, and not coredump when # stringified. The behaviours are: # -# defined($glob) "$glob" -# 5.8.8 false "" with uninit warning -# 5.10.0 true (coredump) -# 5.12.0 true "" +# defined($glob) "$glob" $glob .= ... +# 5.8.8 false "" with uninit warning "" with uninit warning +# 5.10.0 true (coredump) (coredump) +# 5.1[24] true "" "" with uninit warning +# 5.16 true "*__ANON__::..." "*__ANON__::..." { my $io_ref = *STDOUT{IO}; @@ -613,7 +614,8 @@ foreach my $type (qw(integer number string)) { use warnings; my $str = "$glob"; is($warn, '', "RT #60954 anon glob stringification shouldn't warn"); - is($str, '', "RT #60954 anon glob stringification should be empty"); + is($str, '*__ANON__::$__ANONIO__', + "RT #60954/#96326 anon glob stringification"); } # [perl #71254] - Assigning a glob to a variable that has a current |