NAME
Tie::Scalar::Callback - a tied scalar which executes a callback everytime it is used
VERSION
version 0.05
SYNOPSIS
use Tie::Scalar::Callback;
# this coderef doubles the scalar's value everytime it's fetched
my $coderef = sub {
my ($self, $event, $val) = @_;
if ($event eq 'STORE')
{
$self->{val} = $val;
}
elsif ($event eq 'FETCH')
{
my $old_val = $self->{val};
$self->{val} *= 2;
return $old_val;
}
else # DESTROY
{
undef $self;
}
};
tie(my $doubler, 'Tie::Scalar::Callback', $coderef, 1);
print $doubler; 1
print $doubler; 2
print $doubler; 4
DESCRIPTION
Tie::Scalar::Callback
is a class for creating tied scalars which execute a callback everytime an event occurs on the scalar. There are three types of event:
STORE ($self, 'STORE', $value)
Called anytime a value is assigned to the scalar.
FETCH ($self, 'FETCH')
Called anytime the scalar's value is retrieved.
DESTROY ($self, 'DESTROY')
Called on object destruction.
See the synopsis for an example coderef which handles these events.
INTERNALS
Tie::Scalar::Callback
objects are just anonymous hashes. The coderef is stored in $self->{sub}
and the current value of the scalar in $self->{val}
.
ACKNOWLEDGEMENTS
Thanks to brian d foy for coming up with the idea for this module.
SEE ALSO
AUTHOR
David Farrell <dfarrell@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2016 by David Farrell.
This is free software, licensed under:
The (two-clause) FreeBSD License