diff options
-rw-r--r-- | pp.c | 4 | ||||
-rw-r--r-- | t/op/bless.t | 18 |
2 files changed, 15 insertions, 7 deletions
@@ -563,9 +563,7 @@ PP(pp_bless) STRLEN len; char *ptr; - if (ssv && SvGMAGICAL(ssv)) - mg_get(ssv); - if (SvROK(ssv)) + if (ssv && !SvGMAGICAL(ssv) && !SvAMAGIC(ssv) && SvROK(ssv)) Perl_croak(aTHX_ "Attempt to bless into a reference"); ptr = SvPV(ssv,len); if (ckWARN(WARN_MISC) && len == 0) diff --git a/t/op/bless.t b/t/op/bless.t index ccabcb869c..46bf6c311e 100644 --- a/t/op/bless.t +++ b/t/op/bless.t @@ -1,6 +1,6 @@ #!./perl -print "1..29\n"; +print "1..31\n"; BEGIN { chdir 't' if -d 't'; @@ -28,7 +28,7 @@ $b1 = bless [], "B"; print expected($b1, "B", "ARRAY"), "ok 2\n"; $c1 = bless \(map "$_", "test"), "C"; print expected($c1, "C", "SCALAR"), "ok 3\n"; -$test = "foo"; $d1 = bless \*test, "D"; +our $test = "foo"; $d1 = bless \*test, "D"; print expected($d1, "D", "GLOB"), "ok 4\n"; $e1 = bless sub { 1 }, "E"; print expected($e1, "E", "CODE"), "ok 5\n"; @@ -44,7 +44,7 @@ print expected($a1, "A", "HASH"), "ok 9\n"; # reblessing does modify object -my $a2 = bless $a1, "A2"; +bless $a1, "A2"; print expected($a1, "A2", "HASH"), "ok 10\n"; # local and my @@ -52,7 +52,7 @@ print expected($a1, "A2", "HASH"), "ok 10\n"; local $a1 = bless $a1, "A3"; # should rebless outer $a1 local $b1 = bless [], "B3"; my $c1 = bless $c1, "C3"; # should rebless outer $c1 - $test2 = ""; my $d1 = bless \*test2, "D3"; + our $test2 = ""; my $d1 = bless \*test2, "D3"; print expected($a1, "A3", "HASH"), "ok 11\n"; print expected($b1, "B3", "ARRAY"), "ok 12\n"; print expected($c1, "C3", "SCALAR"), "ok 13\n"; @@ -115,3 +115,13 @@ print expected(bless([]), 'main', "ARRAY"), "ok 22\n"; $a1 = bless {}, "A4"; $b1 = eval { bless {}, $a1 }; print $@ ? "ok 29\n" : "not ok 29\t# $b1\n"; + +# class is an overloaded ref +{ + package H4; + use overload '""' => sub { "C4" }; +} +$h1 = bless {}, "H4"; +$c4 = eval { bless \$test, $h1 }; +print expected($c4, 'C4', "SCALAR"), "ok 30\n"; +print $@ ? "not ok 31\t# $@" : "ok 31\n"; |