lots of Config::Any fixes, brought in C::Any testsuite (refactored, partly, from...
[p5sagit/Config-Any.git] / lib / Config / Any / JSON.pm
1 package Config::Any::JSON;\r
2 \r
3 use strict;\r
4 use warnings;\r
5 \r
6 =head1 NAME\r
7 \r
8 Config::Any::JSON - Load JSON config files\r
9 \r
10 =head1 DESCRIPTION\r
11 \r
12 Loads 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
28 return an array of valid extensions (C<json>, C<jsn>).\r
29 \r
30 =cut\r
31 \r
32 sub extensions {\r
33     return qw( json jsn );\r
34 }\r
35 \r
36 =head2 load( $file )\r
37 \r
38 Attempts to load C<$file> as a JSON file.\r
39 \r
40 =cut\r
41 \r
42 sub 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
71 Copyright 2006 by Brian Cassidy\r
72 \r
73 This library is free software; you can redistribute it and/or modify\r
74 it 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
92 1;