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