Provided by: libtest2-harness-perl_1.000155-1_all bug

NAME

       Test2::Harness::Util::File - Utility class for manipulating a file.

DESCRIPTION

       This is a utility class for file operations. This also serves as a base class for several
       file helpers.

SYNOPSIS

           use Test2::Harness::Util::File;

           my $f = Test2::Harness::Util::File->new(name => '/path/to/file');

           $f->write($content);

           my $fh = $f->open_file('<');

           # Read, throw exception if it cannot read
           my $content = $f->read();

           # Try to read, but do not throw an exception if it cannot be read.
           my $content_or_undef = $f->maybe_read();

           my $line1 = $f->read_line();
           my $line2 = $f->read_line();
           ...

ATTRIBUTES

       $filename = $f->name;
           Get the filename. Must also be provided during construction.

       $bool = $f->done;
           True if read_line() has read every line.

METHODS

       $decoded = $f->decode($encoded)
           This is a no-op, it returns the argument unchanged. This is called by "read" and
           "read_line". Subclasses can override this if the file contains encoded data.

       $encoded = $f->encode($decoded)
           This is a no-op, it returns the argument unchanged. This is called by "write".
           Subclasses can override this if the file contains encoded data.

       $bool = $f->exists()
           Check if the file exists

       $content = $f->maybe_read()
           This will read the file if it can and return the content (all lines joined together as
           a single string). If the file cannot be read, or does not exist this will return
           undef.

       $fh = $f->open_file()
       $fh = $f->open_file($mode)
           Open a handle to the file. If no $mode is provided '<' is used.

       $content = $f->read()
           This will read the file if it can and return the content (all lines joined together as
           a single string). If the file cannot be read, or does not exist this will throw an
           exception.

       $line = $f->read_line()
           Read a single line from the file, subsequent calls will read the next line and so on
           until the end of the file is reached. Reset with the "reset()" method.

       $f->reset()
           Reset the internal line iterator used by "read_line()".

       $f->write($content)
           This is an atomic-write. First $content will be written to a temporary file using '>'
           mode. Then the temporary file will be renamed to the desired file name. Under the hood
           this uses "write_file_atomic()" from Test2::Harness::Util.

SOURCE

       The source code repository for Test2-Harness can be found at
       http://github.com/Test-More/Test2-Harness/.

MAINTAINERS

       Chad Granum <exodist@cpan.org>

AUTHORS

       Chad Granum <exodist@cpan.org>

COPYRIGHT

       Copyright 2020 Chad Granum <exodist7@gmail.com>.

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

       See http://dev.perl.org/licenses/