NAME
File::PM2File - obsolete. User File::Where
SYNOPSIS
file_in_include() # obsolete. Replace with File::Where::where()
pm2file() # obsolete. Replace with File::Where::where_pm()
pm2require() # obsolete. Replace with File::Where::pm2require()
$File::PM2File::warn_obsolete = 1; # turns on obsolete warning
REQUIREMENTS
The File::PM2File subrouitnes shall not used.
The File::PM2File subroutines shall be replaced by the appropriate File::Where subroutine whenever a File::PM2File subroutine needs revision as follows:
File::PM2File::find_in_include() File::Where::where()
File::PM2File::pm2file File::Where::where_pm()
File::PM2File::pm2require File::Where::pm2require
NOTE: The subroutine File::Where::where is almost a direct drop in for File::PM2File::find_in_include(). The difference is in an array context File::Where::where() returns a third item where File::PM2File::find_in_include() only returns two. The first two items, though, are the same.
DEMONSTRATION
~~~~~~ Demonstration overview ~~~~~
Perl code begins with the prompt
=>
The selected results from executing the Perl Code follow on the next lines. For example,
=> 2 + 2
4
~~~~~~ The demonstration follows ~~~~~
=> use File::Spec;
=> use File::Package;
=> my $fp = 'File::Package';
=> my $uut = 'File::PM2File';
=> my $loaded = '';
=> # Use the test file as an example since no its absolue path
=> # Calculate the absolute file, relative file, and include directory
=> my $relative_file = File::Spec->catfile('t', 'File', 'PM2File.pm');
=> my $restore_dir = cwd();
=> chdir File::Spec->updir();
=> chdir File::Spec->updir();
=> my $include_dir = cwd();
=> chdir $restore_dir;
=> my $OS = $^O; # need to escape ^
=> unless ($OS) { # on some perls $^O is not defined
=> require Config;
=> $OS = $Config::Config{'osname'};
=> }
=> $include_dir =~ s=/=\\=g if( $^O eq 'MSWin32');
=> my $absolute_file = File::Spec->catfile($include_dir, 't', 'File', 'PM2File.pm');
=> $absolute_file =~ s=.t$=.pm=;
=> # Put base directory as the first in the @INC path
=> my @restore_inc = @INC;
=> unshift @INC, $include_dir;
=> my $errors = $fp->load_package( 'File::PM2File' )
''
=> $uut->pm2require( "$uut")
'File\PM2File.pm'
=> [my @actual = $uut->find_in_include( $relative_file )]
[
'E:\User\SoftwareDiamonds\installation\t\File\PM2File.pm',
'E:\User\SoftwareDiamonds\installation'
]
=> [@actual = $uut->pm2file( 't::File::PM2File' )]
[
'E:\User\SoftwareDiamonds\installation\t\File\PM2File.pm',
'E:\User\SoftwareDiamonds\installation',
't\File\PM2File.pm'
]
=> @INC = @restore_inc
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.