in reply to localizing lexical without messing with tie ?
local doesn't remove the magic — the variable is still tied in the block — so
is roughly the same as{ local $tied = 'x'; ... }
{ my $restorer = localiser($tied, 'x'); ... }
given a function that creates an object that restores $tied on destruction.
use Sub::ScopeFinalizer qw( scope_finalizer ); sub localiser { my $var_ref = \$_[0]; my $saved = $$var_ref; $$var_ref = $_[1]; return scope_finalizer { $$var_ref = $saved }; }
(Sub::ScopeFinalizer is trivial to re-implement.)
Demonstration:
use strict; use warnings; use Sub::ScopeFinalizer qw( scope_finalizer ); { package Tied; use Tie::Scalar; our @ISA = qw( Tie::StdScalar ); sub FETCH { return ${ $_[0] }++ } } sub localiser { my $var_ref = \$_[0]; my $saved = $$var_ref; $$var_ref = $_[1]; return scope_finalizer { $$var_ref = $saved }; } { tie our $tied_pkg, 'Tied'; $tied_pkg = 'a'; print $tied_pkg; # a { local $tied_pkg = 'x'; print $tied_pkg; # x print $tied_pkg; # y print $tied_pkg; # z } print $tied_pkg; # b print $tied_pkg; # c print "\n"; } { tie my $tied_lex, 'Tied'; $tied_lex = 'a'; print $tied_lex; # a { my $restorer = localiser($tied_lex, 'x'); print $tied_lex; # x print $tied_lex; # y print $tied_lex; # z } print $tied_lex; # b print $tied_lex; # c print "\n"; }
axyzbc axyzbc
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: localizing lexical without messing with tie ?
by LanX (Saint) on Sep 08, 2010 at 16:31 UTC | |
by ikegami (Patriarch) on Sep 08, 2010 at 17:01 UTC | |
by LanX (Saint) on Sep 08, 2010 at 17:53 UTC | |
by ikegami (Patriarch) on Sep 09, 2010 at 03:03 UTC | |
by LanX (Saint) on Sep 09, 2010 at 11:31 UTC | |
|