lots of Config::Any fixes, brought in C::Any testsuite (refactored, partly, from...
[p5sagit/Config-Any.git] / lib / Config / Any / JSON.pm
CommitLineData
c80a0905 1package Config::Any::JSON;\r
2\r
3use strict;\r
4use warnings;\r
5\r
6=head1 NAME\r
7\r
8Config::Any::JSON - Load JSON config files\r
9\r
10=head1 DESCRIPTION\r
11\r
12Loads JSON files. Example:\r
13\r
14 {\r
15 "name": "TestApp",\r
16 "Controller::Foo": {\r
17 "foo": "bar"\r
18 },\r
19 "Model::Baz": {\r
20 "qux": "xyzzy"\r
21 }\r
22 }\r
23\r
24=head1 METHODS\r
25\r
26=head2 extensions( )\r
27\r
28return an array of valid extensions (C<json>, C<jsn>).\r
29\r
30=cut\r
31\r
32sub extensions {\r
33 return qw( json jsn );\r
34}\r
35\r
36=head2 load( $file )\r
37\r
38Attempts to load C<$file> as a JSON file.\r
39\r
40=cut\r
41\r
42sub load {\r
43 my $class = shift;\r
44 my $file = shift;\r
45\r
46 open( my $fh, $file ) or die $!;\r
47 my $content = do { local $/; <$fh> };\r
48 close $fh;\r
49\r
50 eval { require JSON::Syck; };\r
51 if( $@ ) {\r
52 require JSON;\r
53 JSON->import;\r
54 return jsonToObj( $content );\r
55 }\r
56 else {\r
57 return JSON::Syck::Load( $content );\r
58 }\r
59}\r
60\r
61=head1 AUTHOR\r
62\r
63=over 4 \r
64\r
65=item * Brian Cassidy E<lt>bricas@cpan.orgE<gt>\r
66\r
67=back\r
68\r
69=head1 COPYRIGHT AND LICENSE\r
70\r
71Copyright 2006 by Brian Cassidy\r
72\r
73This library is free software; you can redistribute it and/or modify\r
74it under the same terms as Perl itself. \r
75\r
76=head1 SEE ALSO\r
77\r
78=over 4 \r
79\r
80=item * L<Catalyst>\r
81\r
82=item * L<Config::Any>\r
83\r
84=item * L<JSON>\r
85\r
86=item * L<JSON::Syck>\r
87\r
88=back\r
89\r
90=cut\r
91\r
921;