diff options
Diffstat (limited to 'Xerl/Tools/FileIO.pm')
| -rw-r--r-- | Xerl/Tools/FileIO.pm | 169 |
1 files changed, 0 insertions, 169 deletions
diff --git a/Xerl/Tools/FileIO.pm b/Xerl/Tools/FileIO.pm deleted file mode 100644 index 45eb64b..0000000 --- a/Xerl/Tools/FileIO.pm +++ /dev/null @@ -1,169 +0,0 @@ -# Xerl (c) 2005-2011, 2013-2015 by Paul Buetow -# -# E-Mail: xerl@dev.buetow.org WWW: https://xerl.buetow.org -# -# This is free software, you may use it and distribute it under the same -# terms as Perl itself. - -package Xerl::Tools::FileIO; - -use strict; -use warnings; - -use v5.14.0; - -use Xerl::Base; -use Xerl::Main::Global; - -sub dslurp { - my $self = $_[0]; - my $path = $self->get_path(); - - $path .= '/' unless $path =~ /\/$/; - opendir my $dir, $path or Xerl::Main::Global::ERROR( $!, $path, caller() ); - - my @dir = sort - map { $path . $_ } - grep { /^[^\.]/o } readdir($dir); - - @dir = map { s#.*/([^/]+\..+)$#$1#o; $_ } @dir - if $self->basename_exists(); - - closedir $dir; - $self->set_array( \@dir ); - - return undef; -} - -sub fslurp { - my $self = $_[0]; - my $path = _SECUREPATH( $self->get_path() ); - - unless ( -f $path ) { - Xerl::Main::Global::HTTP( 404, "Not found: $path" ); - return -1; - } - - open my $file, $path or Xerl::Main::Global::ERROR( $!, $path, caller() ); - flock $file, 2; - - my @slurp = <$file>; - - flock $file, 3; - close $file; - - $self->set_array( \@slurp ); - - return 0; -} - -sub exists { - my $self = $_[0]; - my $path = _SECUREPATH( $self->get_path() ); - - return -e $path; -} - -sub fwrite { - my $self = $_[0]; - $self->_fwrite(0); - - return undef; -} - -sub fwriteappend { - my $self = $_[0]; - $self->_fwrite(1); - - return undef; -} - -sub print { - my $self = $_[0]; - print @{ $self->get_array() }; - - return undef; -} - -sub reverse_array { - my $self = $_[0]; - - my @array = reverse @{ $self->get_array() }; - $self->set_array( \@array ); - - return undef; -} - -sub merge { - my ( $self, $other ) = @_; - - my @merged = ( @{ $self->get_array() }, @{ $other->get_array() } ); - my $fio = Xerl::Tools::FileIO->new(); - $fio->set_array( \@merged ); - - return $fio; -} - -sub shift { - my $self = $_[0]; - chomp( my $shift = shift @{ $self->get_array() } ); - - return $shift; -} - -sub pop { - my $self = $_[0]; - chomp( my $pop = pop @{ $self->get_array() } ); - - return $pop; -} - -sub str { - my $self = $_[0]; - return join '', @{ $self->get_array() }; -} - -sub _fwrite { - my $self = $_[0]; - my $append = $_[1]; - - my ( $path, $filename ) = - ( _SECUREPATH( $self->get_path() ), _SECUREPATH( $self->get_filename() ) ); - - my $path_ = ''; - for ( split /\//, $path ) { - $path_ .= $_ . '/'; - mkdir $path_ - or Xerl::Main::Global::ERROR( $!, $path_, caller() ) - unless -d $path_; - } - - my $f; - if ( $append == 0 ) { - open $f, ">$path$filename" - or Xerl::Main::Global::ERROR( $!, $path . $filename, caller() ); - - } - else { - open $f, ">>$path$filename" - or Xerl::Main::Global::ERROR( $!, $path . $filename, caller() ); - } - - flock $f, 2; - print $f @{ $self->get_array() }; - flock $f, 3; - close $f; - - return undef; -} - -use overload '+' => \&merge; - -sub _SECUREPATH($) { - my $path = $_[0]; - $path =~ s/\.\.+\/?//g; - - return $path; -} - -1; |
