X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=samples%2Ftag.pl;h=0e39930d2f7c03eda3ba55ad5e4bbb1d47998039;hb=HEAD;hp=9020121a1ce6143eb3b3e6d6b775d1fd14599550;hpb=bac4fc46c2d48ce5db75de6c88e0983aeeedf865;p=perl%2Fmodules%2FScope-Upper.git diff --git a/samples/tag.pl b/samples/tag.pl index 9020121..0e39930 100644 --- a/samples/tag.pl +++ b/samples/tag.pl @@ -1,42 +1,65 @@ #!perl -package X; - use strict; use warnings; use blib; -use Scope::Upper qw/reap localize localize_elem/; +package Scope; + +use Scope::Upper qw; -sub desc { shift->{desc} } +sub new { + my ($class, $name) = @_; -sub set_tag { - my ($desc) = @_; + localize '$tag' => bless({ name => $name }, $class) => UP; - # First localize $x so that it gets destroyed last - localize '$x' => bless({ desc => $desc }, __PACKAGE__) => 1; + reap { print Scope->tag->name, ": end\n" } UP; +} - reap sub { - my $pkg = caller; - my $x = do { no strict 'refs'; ${$pkg.'::x'} }; # Get the $x in the scope - print $x->desc . ": done\n"; - } => 1; +# Get the tag stored in the caller namespace +sub tag { + my $l = 0; + my $pkg = __PACKAGE__; + $pkg = caller $l++ while $pkg eq __PACKAGE__; + no strict 'refs'; + ${$pkg . '::tag'}; +} + +sub name { shift->{name} } + +# Locally capture warnings and reprint them with the name prefixed +sub catch { localize_elem '%SIG', '__WARN__' => sub { - my $pkg = caller; - my $x = do { no strict 'refs'; ${$pkg.'::x'} }; # Get the $x in the scope - CORE::warn($x->desc . ': ' . join('', @_)); - } => 1; + print Scope->tag->name, ': ', @_; + } => UP; } -package main; +# Locally clear @INC +sub private { + for (reverse 0 .. $#INC) { + # First UP is the for loop, second is the sub boundary + localize_delete '@INC', $_ => UP UP; + } +} -use strict; -use warnings; +package UserLand; { - X::set_tag('pie'); - # $x is now a X object - warn 'what'; # warns "pie: what" -} # "pie: done" is printed + Scope->new("top"); # initializes $UserLand::tag + + { + Scope->catch; + my $one = 1 + undef; # prints "top: Use of uninitialized value..." + + { + Scope->private; + eval { delete $INC{"Cwd.pm"}; require Cwd }; # blib loads Cwd + print $@; # prints "Can't locate Cwd.pm in @INC (@INC contains:) at..." + } + + require Cwd; # loads Cwd.pm + } + +} # prints "top: done"