added a simple cache to the perl parser so it can load the same file twice (RT #28812)
[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; };
51 if( $@ ) {
52 require JSON;
53 JSON->import;
54 return jsonToObj( $content );
55 }
56 else {
57 return JSON::Syck::Load( $content );
58 }
59}
60
61=head1 AUTHOR
62
63=over 4
64
65=item * Brian Cassidy E<lt>bricas@cpan.orgE<gt>
66
67=back
68
69=head1 COPYRIGHT AND LICENSE
70
71Copyright 2006 by Brian Cassidy
72
73This library is free software; you can redistribute it and/or modify
74it under the same terms as Perl itself.
75
76=head1 SEE ALSO
77
78=over 4
79
80=item * L<Catalyst>
81
82=item * L<Config::Any>
83
84=item * L<JSON>
85
86=item * L<JSON::Syck>
87
88=back
89
90=cut
91
921;