]> git.vpit.fr Git - perl/modules/Scope-Upper.git/commitdiff
Improved synopsys
authorVincent Pit <vince@profvince.com>
Fri, 16 Apr 2010 14:31:07 +0000 (16:31 +0200)
committerVincent Pit <vince@profvince.com>
Fri, 16 Apr 2010 14:31:07 +0000 (16:31 +0200)
lib/Scope/Upper.pm
samples/tag.pl
samples/try.pl

index 6e02d2cc7d83004c609b9ff98f89a3d683aea727..67cc80f25cacee55a60cd57b2e0e1130985f9e82 100644 (file)
@@ -20,50 +20,78 @@ BEGIN {
 
 =head1 SYNOPSIS
 
-    package X;
+L</reap>, L</localize>, L</localize_elem>, L</localize_delete> and L</WORDS> :
+
+    package Scope;
 
     use Scope::Upper qw/reap localize localize_elem localize_delete :words/;
 
-    sub desc { shift->{desc} }
+    sub new {
+     my ($class, $name) = @_;
+
+     localize '$tag' => bless({ name => $name }, $class) => UP;
 
-    sub set_tag {
-     my ($desc) = @_;
+     reap { print Scope->tag->name, ": end\n" } UP;
+    }
 
-     # First localize $x so that it gets destroyed last
-     localize '$x' => bless({ desc => $desc }, __PACKAGE__) => UP; # one scope up
+    # 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'};
+    }
 
-     reap sub {
-      my $pkg = caller;
-      my $x = do { no strict 'refs'; ${$pkg.'::x'} }; # Get the $x in the scope
-      print $x->desc . ": done\n";
-     } => SCOPE 1; # same as UP here
+    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('', @_));
-     } => UP CALLER 0; # same as UP here
+      print Scope->tag->name, ': ', @_;
+     } => UP;
+    }
 
-     # delete last @ARGV element
-     localize_delete '@ARGV', -1 => UP SUB HERE; # same as UP here
+    # 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;
+     }
     }
 
-    package Y;
+    ...
+
+    package UserLand;
 
     {
-     X::set_tag('pie');
-     # $x is now a X object, and @ARGV has one element less
-     warn 'what'; # warns "pie: what at ..."
-     ...
-    } # "pie: done" is printed
+     Scope->new("top");      # initializes $UserLand::tag
 
-    package Z;
+     {
+      Scope->catch;
+      my $one = 1 + undef;   # prints "top: Use of uninitialized value..."
+
+      {
+       Scope->private;
+       eval { require Cwd };
+       print $@;             # prints "Can't locate Cwd.pm in @INC (@INC contains:) at..."
+      }
+
+      require Cwd;           # loads Cwd.pm
+     }
+
+    }                        # prints "top: done"
+
+L</unwind> and L</want_at> :
+
+    package Try;
 
     use Scope::Upper qw/unwind want_at :words/;
 
     sub try (&) {
      my @result = shift->();
-     my $cx = SUB UP SUB;
+     my $cx = SUB UP; # Point to the sub above this one
      unwind +(want_at($cx) ? @result : scalar @result) => $cx;
     }
 
@@ -71,13 +99,15 @@ BEGIN {
 
     sub zap {
      try {
+      my @things = qw/a b c/;
       return @things; # returns to try() and then outside zap()
       # not reached
-     }
+     };
      # not reached
     }
 
-    my @what = zap(); # @what contains @things
+    my @stuff = zap(); # @stuff contains qw/a b c/
+    my $stuff = zap(); # $stuff contains 3
 
 =head1 DESCRIPTION
 
index e28aae00488b239c633161caba55de0b90db19c4..ca017dd8c0b36a1a757de9a1f907ad83f924bf7f 100644 (file)
@@ -1,48 +1,63 @@
 #!perl
 
-package X;
-
 use strict;
 use warnings;
 
-use blib;
+package Scope;
 
 use Scope::Upper qw/reap localize localize_elem localize_delete :words/;
 
-die 'run this script with some arguments!' unless @ARGV;
+sub new {
+ my ($class, $name) = @_;
+
+ localize '$tag' => bless({ name => $name }, $class) => UP;
 
-sub desc { shift->{desc} }
+ reap { print Scope->tag->name, ": end\n" } UP;
+}
 
-sub set_tag {
- my ($desc) = @_;
+# Get the tag stored in the caller namespace
+sub tag {
+ my $l   = 0;
+ my $pkg = __PACKAGE__;
+ $pkg    = caller $l++ while $pkg eq __PACKAGE__;
 
- # First localize $x so that it gets destroyed last
- localize '$x' => bless({ desc => $desc }, __PACKAGE__) => UP;
+ no strict 'refs';
+ ${$pkg . '::tag'};
+}
 
- reap sub {
-  my $pkg = caller;
-  my $x = do { no strict 'refs'; ${$pkg.'::x'} }; # Get the $x in the scope
-  print $x->desc . ": done\n";
- } => SCOPE 1; # same as UP here
+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('', @_));
- } => UP CALLER 0; # same as UP here
-
- # delete last @ARGV element
- localize_delete '@ARGV', -1 => UP SUB HERE; # same as UP here
+  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, and @ARGV has one element less
- warn 'what'; # warns "pie: what at ..."
- warn "\@ARGV contains [@ARGV]";
-} # "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 { require Cwd };
+   print $@;             # prints "Can't locate Cwd.pm in @INC (@INC contains:) at..."
+  }
+
+  require Cwd;           # loads Cwd.pm
+ }
+
+}                        # prints "top: done"
index 305a0ec3bef65ec86220ecd60386bd0adf11d595..7e1cb2a7d3019c91881b40ec0add369a4f773512 100644 (file)
@@ -9,7 +9,7 @@ use Scope::Upper qw/unwind want_at :words/;
 
 sub try (&) {
  my @result = shift->();
- my $cx = SUB UP SUB;
+ my $cx = SUB UP; # Point to the sub above this one
  unwind +(want_at($cx) ? @result : scalar @result) => $cx;
 }
 
@@ -21,7 +21,7 @@ sub zap {
  print "NOT REACHED\n";
 }
 
-my @what = zap(); # @what contains qw/a b c/
-my $what = zap(); # $what contains 3
+my @stuff = zap(); # @stuff contains qw/a b c/
+my $stuff = zap(); # $stuff contains 3
 
-print "zap() returns @what in list context and $what in scalar context\n";
+print "zap() returns @stuff in list context and $stuff in scalar context\n";