NAME
File::FileUtil - various low-level subroutines that involve files
SYNOPSIS
use File::FileUtil
$data = smart_nl($data)
$data = File::FileUtil->fin( $file_name )
$success = File::FileUtil->fout($file_name, $data)
$result = File::FileUtil->hex_dump( $string );
$package = File::FileUtil->is_package_loaded($package)
$error = File::FileUtil->load_package($package)
$errors = File::FileUtil->pod_errors($package)
$file = File::FileUtil->fspec2fspec($from_fspec, $to_fspec $fspec_file, [$nofile])
$os_file = File::FileUtil->fspec2os($fspec, $file, [$no_file])
$fspec_file = File::FileUtil->os2fspec($fspec, $file, [$no_file])
$pm_file = File::FileUtil->fspec2pm( $fspec, $file )
$file = File::FileUtil->pm2file($pm_file)
$file = File::FileUtil->pm2require($pm_file)
@globed_files = File::FileUtil->fspec_glob($fspec, @files)
($file, $path) = File::FileUtil->find_in_path($fspec, $file, [\@path])
@INC = File::FileUtil->test_lib2inc()
@t_path = File::FileUtil->find_t_paths()
@t_path = File::FileUtil->find_t_roots()
$fh = File::FileUtil->pm2datah($pm_file)
$data = File::FileUtil->pm2data($pm_file)
@sub_modules = File::FileUtil->sub_modules($base_file, @dirs)
$module = File::FileUtil->is_module($module, @modules)
DESCRIPTION
The methods in the File::FileUtil
package are designed to support the Test::STDmaker
and the ExtUtils::SVDmaker
package. This is the focus and no other focus. Since File::FileUtil
is a separate package, the methods may be used elsewhere. In all likehood, any revisions will maintain backwards compatibility with previous revisions. However, support and the performance of the Test::STDmaker
and ExtUtils::SVDmaker
packages has priority over backwards compatibility.
Many of the methods in this package are use the File::Spec module submodules. The File::Spec uses the current operating system, as specified by the $^O to determine the proper File::Spec submodule to use. Thus, when using File::Spec method, only the submodule for the current operating system is loaded and the File::Spec method directed to the corresponding method of the File::Spec submodule.
Many methods in this package, manipulate file specifications for operating systems other then the current site operating system. The input variable $fspec tells the methods in this package the file specification for file names used as input to the methods. Thus, when using methods in this package up to two, the method may load up to two File::Spec submodules methods and neither of them is a submodule for the current site operating system.
Supported operating system file specifications are as follows:
MacOS
MSWin32
os2
VMS
epoc
Of course since, the variable $^O contains the file specification for the current site operating system, it may be used for the $fspec variable.
2167A Bundle
The File::FileUtil module was orginally developed to support the US DOD 2167A Bundle. The original functional interface modules in the US DOD 2167A bundle are shown in the below dependency tree
File::FileUtil
Test::STD::Scrub
Test::Tech
DataPort::FileType::FormDB DataPort::DataFile Test::STD::STDutil
Test::STDmaker ExtUtils::SVDmaker
Note the File::FileUtil, Test::STD::STDutil Test::STD::Scrub program modules breaks up the Test::TestUtil program module and Test::TestUtil has disappeared.
fin fout method
$data = File::FileUtil->fin( $file_name )
$success = File::FileUtil->fout($file_name, $data, \%options)
Different operating systems have different new line sequences. Microsoft uses \015\012 for text file, \012 for binary files, Macs \015 and Unix 012. Perl adapts to the operating system and uses \n as a logical new line. The \015 is the ASCII Carraige Return (CR) character and the \012 is the ASCII Line Feed character.
The fin method will translate any CR LF combination into the logical Perl \n character. Normally fout will use the Perl \n character. In other words fout uses the CR LF combination appropriate of the operating system and file type. However supplying the option {binary = 1}> directs fout to use binary mode and output the CR LF raw without any translation.
By using the fin and fout methods, text files may be freely exchanged between operating systems without any other processing. For example,
==> my $text = "=head1 Title Page\n\nSoftware Version Description\n\nfor\n\n";
==> File::FileUtil->fout( 'test.pm', $text, {binary => 1} );
==> File::FileUtil->fin( 'test.pm' );
=head1 Title Page\n\nSoftware Version Description\n\nfor\n\n
==> my $text = "=head1 Title Page\r\n\r\nSoftware Version Description\r\n\r\nfor\r\n\r\n";
==> File::FileUtil->fout( 'test.pm', $text, {binary => 1} );
==> File::FileUtil->fin( 'test.pm' );
find_in_path method
($file_absolute, $path) = File::FileUtil->find_in_path($fspec, $file_relative, [\@path])
The find_in_path method looks for the $file_relative in one of the directories in the @INC path or else the @path in the order listed. The file $file_relative may include relative directories. When find_in_path finds the file, it returns the abolute file $file_absolute and the directory $path where it found $file_relative. The input variable $fspec is the file specification for $file_relative.
For example, running on Microsoft windows with C:\Perl\Site\t in the @INC path, and the file Test\TestUtil\TestUtil.t present
==> File::FileUtil->find_in_path('Unix', 'Test/TestUtil/TestUtil.t')
C:\Perl\Site\t\Test\TestUtil\TestUtil.t
C:\Perl\Site\t
find_t_paths method
This method operates on the assumption that the test files are a subtree to a directory named t and the t directories are on the same level as the last directory of each directory tree specified in @INC. If this assumption is not true, this method most likely will not behave very well.
The find_t_paths method returns the directory trees in @INC with the last directory changed to t.
For example,
==> @INC
myperl/lib
perl/site/lib
perl/lib
=> File::FileUtil->find_t_paths()
myperl/t
perl/site/t
perl/t
find_t_roots method
This method operates on the assumption that the test files are a subtree to a directory named t and the t directories are on the same level as the last directory of each directory tree specified in @INC. If this assumption is not true, this method most likely will not behave very well.
The find_t_roots method returns the directory trees in @INC with last directory drooped.
For example,
==> @INC
myperl/lib
perl/site/lib
perl/lib
=> File::FileUtil->find_t_roots()
myperl
perl/site
perl
fspec_glob method
@globed_files = File::FileUtil->fspec_glob($fspec, @files)
The fspec_glob method BSD globs each of the files in @files where the file specification for each of the files is $fspec.
For example, running under the Microsoft operating system, that contains a directory Drivers with file Generators.pm Driver.pm IO.pm under the current directory
=> File::FileUtil->fspec_glob('Unix','Drivers/G*.pm')
Drivers\Generate.pm
=> File::FileUtil->fspec_glob('MSWin32','Drivers\\I*.pm')
Drivers\IO.pm
fspec2fspec method
$to_file = File::FileUtil->fspec2fspec($from_fspec, $to_fspec $from_file, $nofile)
THe fspec2fspec method translate the file specification for $from_file from the $from_fspec to the $to_fpsce. Supplying anything for $nofile, tells the fspec2fspec method that $from_file is a directory tree; otherwise, it is a file.
For example,
=> File::FileUtil->fspec2fspec( 'Unix', 'MSWin32', 'Test/TestUtil.pm')
Test\\TestUtil.pm
fspec2os method
$os_file = File::FileUtil->fspec2os($fspec, $file, $no_file)
The fspec2os method translates a file specification, $file, from the current operating system file specification to the $fspec file specification. Supplying anything for $nofile, tells the fspec2fspec method that $from_file is a directory tree; otherwise, it is a file.
For example, running under the Microsoft operating system:
==> File::FileUtil->fspec2os( 'Unix', 'Test/TestUtil.pm')
Test\\TestUtil.pm
fspec2pm method
$pm_file = File::FileUtil->fspec2pm( $fspec, $file )
The fspec2pm method translates a filespecification $file in the $fspce format to the Perl module formate.
For example,
==> File::FileUtil->fspec2pm('Unix', 'Test/TestUtil.pm')
File::FileUtil
hex_dump method
Sometimes the eyes need to see the actual bytes of a file content. The hex_dump method provides these eyes. For example,
==> $text
1..8 todo 2 5;
# OS : MSWin32
# Perl : 5.6.1
# Local Time : Thu Jun 19 23:49:54 2003
# GMT Time : Fri Jun 20 03:49:54 2003 GMT
# Number Storage: string
# Test::Tech : 1.06
# Test : 1.15
# Data::Dumper : 2.102
# =cut
# Pass test
ok 1
EOF
==> File::FileUtil->hex_dump( $text )
312e2e3820746f646f203220353b0a23204f5320
20202020202020202020203a204d5357696e3332
0a23205065726c202020202020202020203a2035
2e362e310a23204c6f63616c2054696d65202020
203a20546875204a756e2031392032333a34393a
353420323030330a2320474d542054696d652020
202020203a20467269204a756e2032302030333a
34393a3534203230303320474d540a23204e756d
6265722053746f726167653a20737472696e670a
2320546573743a3a54656368202020203a20312e
30360a232054657374202020202020202020203a
20312e31350a2320446174613a3a44756d706572
20203a20322e3130320a23203d637574200a2320
5061737320746573740a6f6b20310a
is_module method
$driver = Test::TestUtil->is_module($module, @modules)
The is_module method determines if $module is present in @modules. The detemination is case insensitive and only the leading characters are needed.
For example,
==> @drivers
(Driver
Generate
IO)
==> Test::TestUtil->is_driver('dri', @drivers )
Driver
is_package_loaded method
$package = File::FileUtil->is_package_loaded($package)
The is_package_loaded method determines if a package vocabulary is present.
For example, if File::Basename is not loaded
==> File::FileUtil->is_package_loaded('File::Basename')
''
load_package method
$error = File::FileUtil->load_package($package)
The load_package method loads attempts to load a package. The return is any $error that occurred during the load attempt. The load_package will check that the package vocabulary is present. Altough it is a Perl convention, the package name(s) in a package file do not have to be the same as the package file name. For these few cases, this method will load the packages in the file, but fail the package vocabulary test.
For example,
==> File::FileUtil->load_package( 'File::Basename' )
''
os2fspec method
$file = File::FileUtil->os2fspec($fspec, $os_file, $no_file)
The fspec2os method translates a file specification, $file, from the current operating system file specification to the $fspec file specification. Supplying anything for $nofile, tells the fspec2fspec method that $from_file is a directory tree; otherwise, it is a file.
For example, running under the Microsoft operating system:
==> File::FileUtil->os2fspec( 'Unix', 'Test\\TestUtil.pm')
Test/TestUtil.pm
pm2datah method
$fh = File::FileUtil->pm2datah($pm_file)
The pm2datah method will open the $pm_file and return a handle positioned at the first /[\012\015]__DATA__/ token occuring in the file. This function is very similar to the DATA file handle that Perl creates when loading a module file with the /[\012\015]__DATA__/ token. The differences is that pm2datah works whether or not the file module is loaded. The method does not close the file handle. Unlike the DATA file handle, which cannot be reused after the module data is read the first time, the pm2datah will always return an opened file handle, the first time, the second time, any time.
CAUTION:
If the /[\012\015]__DATA__/ token appears in the code section, say in a comment, or as a value assigned to a variable, the pm2datah method will misbehave.
For example,
==> my $fh = File::FileUtil->pm2datah('File::FileUtil::Drivers::Driver')
==> join '',<$fh>;
\=head1 Title Page
Software Version Description
for
${TITLE}
Revision: ${REVISION}
Version: ${VERSION}
Date: ${DATE}
Prepared for: ${END_USER}
Prepared by: ${AUTHOR}
Copyright: ${COPYRIGHT}
Classification: ${CLASSIFICATION}
\=cut
EOF
pm2data method
$data = File::FileUtil->pm2data($pm_file)
The pm2data uses the pm2datah to return all the data in a $pm_file form the __DATA__ token to the end of the file.
For example,
==> my $fh = File::FileUtil->pm2data('File::FileUtil::Drivers::Driver')
\=head1 Title Page
Software Version Description
for
${TITLE}
Revision: ${REVISION}
Version: ${VERSION}
Date: ${DATE}
Prepared for: ${END_USER}
Prepared by: ${AUTHOR}
Copyright: ${COPYRIGHT}
Classification: ${CLASSIFICATION}
\=cut
EOF
pm2file method
($file, $path) = File::FileUtil->pm2file($pm_file)
The pm2file method returns the absolute file and the directory in @INC for a the program module $pm_file.
For example, running on a Microsoft operating system, if File::FileUtil is in the C:\myperl\t directory, and C:\myperl\t is in the @INC path,
==> File::FileUtil->pm2file( 'File::FileUtil');
(C:\myperl\t\Test\TestUtil.pm
C:\myperl\t)
pod_errors method
$errors = File::FileUtil->pod_errors($package)
The pod_errors uses Pod::Checker to analyze a package and returns the number of $errors
For example,
==> File::FileUtil->pod_errors( 'File::Basename')
0
pm2require
$file = File::FileUtil->pm2require($pm_file)
The pm2require method returns the file suitable for use in a Perl require given the $pm_file file.
For example, running under Microsoft Windows
==> File::FileUtil->pm2require( 'File::FileUtil')
File\FileUtil.pm
smart_nl method
$data = File::FileUtil->smart_nl( $data )
Different operating systems have different new line sequences. Microsoft uses \015\012 for text file, \012 for binary files, Macs \015 and Unix 012. Perl adapts to the operating system and uses \n as a logical new line. The \015 is the ASCII Carraige Return (CR) character and the \012 is the ASCII Line Feed character.
The fin method will translate any CR LF combination into the logical Perl \n character. Normally fout will use the Perl \n character. In other words fout uses the CR LF combination appropriate of the operating system and file type. However supplying the option {binary = 1}> directs fout to use binary mode and output the CR LF raw without any translation.
Perl 5.6 introduced a built-in smart nl functionality as an IO discipline :crlf. See Programming Perl by Larry Wall, Tom Christiansen and Jon Orwant, page 754, Chapter 29: Functions, open function. For Perl 5.6 or above, the :crlf IO discipline my be preferable over the smart_nl method of this package.
An example of the smart_nl method follows:
==> $text
"line1\015\012line2\012\015line3\012line4\015"
==> File::FileUtil->smart_nl( $text )
"line1\nline2\nline3\nline4\n"
sub_modules method
@sub_modules = File::FileUtil->sub_modules($base_file, @dirs)
Placing sub modules in their own private directory provides a method to add a new sub_modules without changing the using module. The parent object finds all the available sub_modules by listing the modules in the sub_module directory using the sub_modules method.
The sub_modules method takes as its input a $base_file, a file in the parent directory, and a list of subdirectories, @dirs, relative to the $base_file. It returns the a list, @sub_modules, of *.pm file names stripped of the extension .pm in the identified directory.
For example, if the subdirectory Drivers to the file __FILE__ contains the files Driver.pm Generate.pm IO.pm, then
==> join ',', sort File::FileUtil->sub_modules( __FILE__, 'Drivers' );
'Driver, Generate, IO'
test_lib2inc method
@INC = File::FileUtil->test_lib2inc()
The test_lib2inc method walks up the directory tree from the current directory until it finds a directory named "t". It then pushs the parent to that directory, and a directory with "t" replaced by "lib" onto @INC. The test_lib2inc method returns the @INC before it is altered so that the using method may return @INC to before calling test_lib2inc.
For example,
==> @INC
perl/site/lib
perl/lib
==> cwd()
myperl/t/mymodule/mytests
=> @restore_inc = File::FileUtil->find_t_roots()
=> @INC
myperl/lib
myperl
perl/site/lib
perl/lib
=> @restore_inc
perl/site/lib
perl/lib
NOTES
AUTHOR
The holder of the copyright and maintainer is
<support@SoftwareDiamonds.com>
COPYRIGHT NOTICE
Copyrighted (c) 2002 Software Diamonds
All Rights Reserved
BINDING REQUIREMENTS NOTICE
Binding requirements are indexed with the pharse 'shall[dd]' where dd is an unique number for each header section. This conforms to standard federal government practices, 490A ("3.2.3.6" in STD490A). In accordance with the License, Software Diamonds is not liable for any requirement, binding or otherwise.
LICENSE
Software Diamonds permits the redistribution and use in source and binary forms, with or without modification, provided that the following conditions are met:
Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
SOFTWARE DIAMONDS, http::www.softwarediamonds.com, PROVIDES THIS SOFTWARE 'AS IS' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SOFTWARE DIAMONDS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING USE OF THIS SOFTWARE, EVEN IF ADVISED OF NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE POSSIBILITY OF SUCH DAMAGE.
SEE_ALSO:
Modules with end-user functional interfaces relating to US DOD 2167A automation are as follows:
- Test::STDmaker
- ExtUtils::SVDmaker
- DataPort::FileType::FormDB
- DataPort::DataFile
- Test::Tech
- Test
- Data::Dumper
- Test::STD::Scrub
- Test::STD::STDutil
- File::FileUtil
The design modules for Test::STDmaker have no other conceivable use then to support the Test::STDmaker functional interface. The Test::STDmaker design module are as follows:
- Test::STD::Check
- Test::STD::FileGen
- Test::STD::STD2167
- Test::STD::STDgen
- Test::STDtype::Demo
- Test::STDtype::STD
- Test::STDtype::Verify
Some US DOD 2167A Software Development Standard, DIDs and other related documents that complement the US DOD 2167A automation bundle are as follows:
- US DOD Software Development Standard
- US DOD Specification Practices
- Computer Operation Manual (COM) DID
- Computer Programming Manual (CPM) DID)
- Computer Resources Integrated Support Document (CRISD) DID
- Computer System Operator's Manual (CSOM) DID
- Database Design Description (DBDD) DID
- Engineering Change Proposal (ECP) DID
- Firmware support Manual (FSM) DID
- Interface Design Document (IDD) DID
- Interface Requirements Specification (IRS) DID
- Operation Concept Description (OCD) DID
- Specification Change Notice (SCN) DID
- Software Design Specification (SDD) DID
- Software Development Plan (SDP) DID
- Software Input and Output Manual (SIOM) DID
- Software Installation Plan (SIP) DID
- Software Programmer's Manual (SPM) DID
- Software Product Specification (SPS) DID
- Software Requirements Specification (SRS) DID
- System or Segment Design Document (SSDD) DID
- System or Subsystem Specification (SSS) DID
- Software Test Description (STD) DID
- Software Test Plan (STP) DID
- Software Test Report (STR) DID
- Software Transition Plan (STrP) DID
- Software User Manual (SUM) DID
- Software Version Description (SVD) DID
- Version Description Document (VDD) DID
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 1426:
=back doesn't take any parameters, but you said =back =for html <p><br> <!-- BLK ID="NOTICE" --> <!-- /BLK --> <p><br> <!-- BLK ID="OPT-IN" --> <!-- /BLK --> <p><br> <!-- BLK ID="EMAIL" --> <!-- /BLK --> <p><br> <!-- BLK ID="COPYRIGHT" --> <!-- /BLK --> <p><br> <!-- BLK ID="LOG_CGI" --> <!-- /BLK --> <p><br>