———package
Config::Any::Perl;
use
strict;
use
warnings;
use
File::Spec;
use
Cwd ();
=head1 NAME
Config::Any::Perl - Load Perl config files
=head1 DESCRIPTION
Loads Perl files. Example:
{
name => 'TestApp',
'Controller::Foo' => {
foo => 'bar'
},
'Model::Baz' => {
qux => 'xyzzy'
}
}
=head1 METHODS
=head2 extensions( )
return an array of valid extensions (C<pl>, C<perl>).
=cut
sub
extensions {
return
qw( pl perl )
;
}
=head2 load( $file )
Attempts to load C<$file> as a Perl file.
=cut
sub
load {
my
$class
=
shift
;
my
$file
=
shift
;
my
(
$exception
,
$content
);
{
local
$@;
# previously this would load based on . being in @INC, and wouldn't
# trigger taint errors even if '.' probably should have been considered
# tainted. untaint for backwards compatibility.
my
(
$cwd
) = Cwd::cwd() =~ /\A(.*)\z/s;
$content
=
do
File::Spec->rel2abs(
$file
,
$cwd
);
$exception
= $@ || $!
if
!
defined
$content
;
}
die
$exception
if
$exception
;
return
$content
;
}
=head1 AUTHOR
Brian Cassidy <bricas@cpan.org>
=head1 COPYRIGHT AND LICENSE
Copyright 2006-2016 by Brian Cassidy
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=head1 SEE ALSO
=over 4
=item * L<Catalyst>
=item * L<Config::Any>
=back
=cut
1;