| File-Fu documentation | Contained in the File-Fu distribution. |
File::Fu::File::Temp - temporary files
use File::Fu; my $handle = File::Fu->temp_file;
The directory argument is required, followed by an optional template argument and/or flags. The template may contain some number of 'X' characters. If it does not, ten of them will be appended.
my $handle = File::Fu::File::Temp->new($dir, 'foo'); my $file = $handle->name;
By default, the file will be deleted when the handle goes out of scope. Optionally, it may be deleted immediately after creation or just not deleted.
my $handle = File::Fu::File::Temp->new($dir, 'foo', -secure); my $handle = File::Fu::File::Temp->new($dir, -noclean); # also $handle->noclean;
Delete the named file (if the OS supports it) immediately after opening.
Calling name() on this sort of handle throws an error.
Don't attempt to remove the file when the $handle goes out of scope.
my $file_obj = $handle->name;
Disable autocleanup.
$handle->nocleanup;
Called automatically when the handle goes out of scope.
$handle->DESTROY;
Eric Wilhelm @ <ewilhelm at cpan dot org>
http://scratchcomputing.com/
If you found this module on CPAN, please report any bugs or feature requests through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
If you pulled this development version from my /svn/, please contact me directly.
Copyright (C) 2008 Eric L. Wilhelm, All Rights Reserved.
Absolutely, positively NO WARRANTY, neither express or implied, is offered with this software. You use this software at your own risk. In case of loss, no person or entity owes you anything whatsoever. You have been warned.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| File-Fu documentation | Contained in the File-Fu distribution. |
package File::Fu::File::Temp; $VERSION = v0.0.7; use warnings; use strict; use Carp;
use File::Temp (); # XXX should be File::Fu::Handle; #use base 'File::Temp';
{ my %argmap = ( secure => [], nocleanup => [UNLINK => 0], ); sub new { my $proto = shift; my $class = ref($proto) || $proto; my ($dir, $send, $opt) = $class->_validate(\%argmap, @_); my ($self, $fn); if($opt->{secure}) { $self = File::Temp::tempfile(@$send); $class .= '::HasNoFileName'; } else { ($self, $fn) = File::Temp::tempfile(@$send); ${*$self} = $dir->file_class->new($fn); } %{*$self} = %$opt; bless($self, $class); return($self); }} # end subroutine new definition ########################################################################
sub _validate { my $class = shift; my %argmap = %{shift(@_)}; my ($dir, @opt) = @_; croak("invalid directory '$dir' ") unless(eval {$dir->can('e')} and $dir->e); my @send; my %opt; for(my $i = 0; $i < @opt; $i++) { ($opt[$i] =~ s/^-//) or next; my ($key) = splice(@opt, $i, 1); $i--; my $do = $argmap{$key} or croak("invalid argument '$key'"); push(@send, @$do); $opt{$key} = 1; } if(@opt) { my $template = shift(@opt); croak("invalid arguments '@opt'") if(@opt); $template .= $class->XXX unless($template =~ m/X/); # XXX File::Temp specific unshift(@send, $template); } $opt{auto_delete} = ! delete($opt{nocleanup}); push(@send, DIR => "$dir"); return($dir, \@send, \%opt); } # end subroutine _validate definition ########################################################################
sub name { my $self = shift; return(${*$self}); } # end subroutine name definition ########################################################################
sub nocleanup { my $self = shift; my %opt = %{*$self}; $opt{auto_delete} = 0; } # end subroutine nocleanup definition ########################################################################
sub DESTROY { my $self = shift; my %opt = %{*$self}; return if($opt{secure} or ! $opt{auto_delete}); $self->name->unlink; } # end subroutine DESTROY definition ######################################################################## use constant XXX => 'X'x10;
# vi:ts=2:sw=2:et:sta 1;