NAME
IO::ReStoreFH - store/restore file handles
VERSION
version 0.11
SYNOPSIS
use IO::ReStoreFH;
{
my $fhstore = IO::ReStoreFH->new( *STDOUT );
open( STDOUT, '>', 'file' );
} # STDOUT will be restored when $fhstore is destroyed
# or, one at-a-time
{
my $fhstore = IO::ReStoreFH->new;
$store->store( *STDOUT );
$store->store( $myfh );
open( STDOUT, '>', 'file' );
open( $myfh, '>', 'another file' );
} # STDOUT and $myfh will be restored when $fhstore is destroyed
DESCRIPTION
Redirecting and restoring I/O streams is straightforward but a chore, and can lead to strangely silent errors if you forget to restore STDOUT or STDERR.
IO::ReStoreFH helps keep track of the present state of filehandles and low-level file descriptors and restores them either explicitly or when the IO::ReStoreFH object goes out of scope.
It uses the standard Perl filehandle duplication methods (via open) for filehandles, and uses POSIX::dup and POSIX::dup2 for file descriptors.
File handles and descriptors are restored in the reverse order that they are stored.
INTERNALS
INTERFACE
- new
-
my $fhstore = IO::ReStoreFH->new; my $fhstore = IO::ReStoreFH->new( $fh1, $fh2, $fd, ... );
Create a new object and an optional list of Perl filehandles or integer file descriptors.
The passed handles and descriptors will be duplicated to be restored when the object is destroyed or the restore method is called.
- store
-
$fhstore->store( $fh ); $fhstore->store( $fd );
The passed handles and descriptors will be duplicated to be restored when the object is destroyed or the restore method is called.
- restore
-
$fhstore->restore;
Restore the stored file handles and descriptors, in the reverse order that they were stored. This is automatically called when the object is destroyed.
DIAGNOSTICS
$fh is not an open filehandle
-
The passed filehandle failed a check to ensure that it was an open filehandle. Make sure it's a) a real filehandle; b) it's open.
inexplicable error: unable to determine mode for $fh
-
IO::ReStoreFH was unable to get the access mode for the passed file handle. Are you sure that it's really a filehandle object?
error fdopening %s: %s
-
Perl open() was unable to duplicate the passed filehandle for the specified reason.
error dup'ing file descriptor %s: %s
-
POSIX::dup() was unable to duplicate the passed file descriptor for the specified reason.
$fh must be opened Perl filehandle or object or integer file descriptor
-
The passed
$fh
argument wasn't recognized as a Perl filehandle or a file descriptor. Please try again. error restoring file descriptor %d: %s
-
Attempting to restore the file descriptor failed for the specified reason.
error restoring file handle %s: %s
-
Attempting to restore the Perl file handle failed for the specified reason.
SUPPORT
Bugs
Please report any bugs or feature requests to bug-io-restorefh@rt.cpan.org or through the web interface at: https://rt.cpan.org/Public/Dist/Display.html?Name=IO-ReStoreFH
Source
Source is available at
https://gitlab.com/djerius/io-restorefh
and may be cloned from
https://gitlab.com/djerius/io-restorefh.git
AUTHOR
Diab Jerius <djerius@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2012 by Smithsonian Astrophysical Observatory.
This is free software, licensed under:
The GNU General Public License, Version 3, June 2007