Commit | Line | Data |
f0e3c221 |
1 | package Config::Any::Perl; |
2 | |
3 | use strict; |
4 | use warnings; |
5 | |
dcfb1d1d |
6 | use base 'Config::Any::Base'; |
1febe9e7 |
7 | use File::Spec; |
273db69d |
8 | use Cwd (); |
dcfb1d1d |
9 | |
f0e3c221 |
10 | =head1 NAME |
11 | |
12 | Config::Any::Perl - Load Perl config files |
13 | |
14 | =head1 DESCRIPTION |
15 | |
16 | Loads Perl files. Example: |
17 | |
18 | { |
19 | name => 'TestApp', |
20 | 'Controller::Foo' => { |
21 | foo => 'bar' |
22 | }, |
23 | 'Model::Baz' => { |
24 | qux => 'xyzzy' |
25 | } |
26 | } |
27 | |
28 | =head1 METHODS |
29 | |
30 | =head2 extensions( ) |
31 | |
32 | return an array of valid extensions (C<pl>, C<perl>). |
33 | |
34 | =cut |
35 | |
36 | sub extensions { |
37 | return qw( pl perl ); |
38 | } |
39 | |
40 | =head2 load( $file ) |
41 | |
42 | Attempts to load C<$file> as a Perl file. |
43 | |
44 | =cut |
45 | |
46 | sub load { |
47 | my $class = shift; |
48 | my $file = shift; |
f07b7a17 |
49 | |
50 | my( $exception, $content ); |
77bb967e |
51 | { |
52 | local $@; |
273db69d |
53 | # previously this would load based on . being in @INC, and wouldn't |
54 | # trigger taint errors even if '.' probably should have been considered |
55 | # tainted. untaint for backwards compatibility. |
56 | my ($cwd) = Cwd::cwd() =~ /\A(.*)\z/s; |
57 | $content = do File::Spec->rel2abs($file, $cwd); |
c6341999 |
58 | $exception = $@ || $! |
59 | if !defined $content; |
83020fbd |
60 | } |
77bb967e |
61 | die $exception if $exception; |
83020fbd |
62 | |
77bb967e |
63 | return $content; |
f0e3c221 |
64 | } |
65 | |
66 | =head1 AUTHOR |
67 | |
a918b0b8 |
68 | Brian Cassidy E<lt>bricas@cpan.orgE<gt> |
f0e3c221 |
69 | |
70 | =head1 COPYRIGHT AND LICENSE |
71 | |
3d43e104 |
72 | Copyright 2006-2016 by Brian Cassidy |
f0e3c221 |
73 | |
74 | This library is free software; you can redistribute it and/or modify |
75 | it under the same terms as Perl itself. |
76 | |
77 | =head1 SEE ALSO |
78 | |
79 | =over 4 |
80 | |
81 | =item * L<Catalyst> |
82 | |
83 | =item * L<Config::Any> |
84 | |
85 | =back |
86 | |
87 | =cut |
88 | |
89 | 1; |