From: Jarkko Hietaniemi Date: Thu, 25 Apr 2002 17:43:50 +0000 (+0000) Subject: More %{} overload tests. X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=41cb10058d4b3aa9d11d3b8991811c08c7fcc328;p=p5sagit%2Fp5-mst-13.2.git More %{} overload tests. p4raw-id: //depot/perl@16163 --- diff --git a/lib/overload.t b/lib/overload.t index cf49eac..4db647d 100644 --- a/lib/overload.t +++ b/lib/overload.t @@ -1066,5 +1066,23 @@ package main; my $utfvar = new utf8_o 200.2.1; test("$utfvar" eq 200.2.1); # 223 +# 224..226 -- more %{} tests. Hangs in 5.6.0, okay in later releases. +# Basically this example implements strong encapsulation: if Hderef::import() +# were to eval the overload code in the caller's namespace, the privatisation +# would be quite transparent. +package Hderef; +use overload '%{}' => sub { (caller(0))[0] eq 'Foo' ? $_[0] : die "zap" }; +package Foo; +@Foo::ISA = 'Hderef'; +sub new { bless {}, shift } +sub xet { @_ == 2 ? $_[0]->{$_[1]} : + @_ == 3 ? ($_[0]->{$_[1]} = $_[2]) : undef } +package main; +my $a = Foo->new; +$a->xet('b', 42); +print $a->xet('b') == 42 ? "ok 224\n" : "not ok 224\n"; +print defined eval { $a->{b} } ? "not ok 225\n" : "ok 225\n"; +print $@ =~ /zap/ ? "ok 226\n" : "not ok 226\n"; + # Last test is: -sub last {223} +sub last {226}