The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Variable::Temp - Temporarily change the value of a variable.

VERSION

Version 0.04

SYNOPSIS

    use Variable::Temp 'temp';

    my $x = 1;
    say $x; # 1
    {
     temp $x = 2;
     say $x; # 2
    }
    say $x; # 1

DESCRIPTION

This module provides an utility routine that can be used to temporarily change the value of a scalar, array or hash variable, until the end of the current scope is reached where the original value of the variable is restored. It is similar to local, except that it can be applied onto lexicals as well as globals, and that it replaces values by copying the new value into the container variable instead of by aliasing.

FUNCTIONS

temp

    temp $var;
    temp $var = $value;

    temp @var;
    temp @var = \@value;

    temp %var;
    temp %var = \%value;

Temporarily replaces the value of the lexical or global variable $var by $value (respectively @var by @value, %var by %value), or by undef if $value is omitted (respectively empties @var and %var if the second argument is omitted), until the end of the current scope. Any subsequent assignments to this variable in the current (or any inferior) scope will not affect the original value which will be restored into the variable at scope end. Several temp calls can be made onto the same variable, and the restore are processed in reverse order.

Note that destructors associated with the variable will not be called when temp sets the temporary value, but only at the natural end of life of the variable. They will trigger after any destructor associated with the replacement value.

Due to a shortcoming in the handling of the \$ prototype, which was addressed in perl 5.14, the pseudo-statement temp $var = $value will cause compilation errors on perl 5.12.x and below. If you want your code to run on these versions of perl, you are encouraged to use "set_temp" instead.

set_temp

    set_temp $var;
    set_temp $var => $value;

    set_temp @var;
    set_temp @var => \@value;

    set_temp %var;
    set_temp %var => \%value;

A non-lvalue variant of "temp" that can be used with any version of perl.

EXPORT

The functions "temp" and "set_temp" are only exported on request by specifying their names in the module import list.

DEPENDENCIES

perl 5.6.

Exporter (core since perl 5).

Scope::Upper.

Variable::Magic 0.51.

SEE ALSO

Scope::Upper.

"local" in perlfunc.

AUTHOR

Vincent Pit, <perl at profvince.com>, http://www.profvince.com.

You can contact me by mail or on irc.perl.org (vincent).

BUGS

Please report any bugs or feature requests to bug-variable-temp at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Variable-Temp. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

    perldoc Variable::Temp

COPYRIGHT & LICENSE

Copyright 2015,2017 Vincent Pit, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.