X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FConfig-Any.git;a=blobdiff_plain;f=lib%2FConfig%2FAny%2FJSON.pm;h=17055f3accec940937df29b61d6b784d6b690a52;hp=3213128d43e47050a3c731005b4ef6b3c8861c9d;hb=d60679ba40498138c7dd83aa5a735e76ffdc3714;hpb=72628dc786ef43d546023d6f17a86c3f5edeb21a diff --git a/lib/Config/Any/JSON.pm b/lib/Config/Any/JSON.pm index 3213128..17055f3 100644 --- a/lib/Config/Any/JSON.pm +++ b/lib/Config/Any/JSON.pm @@ -3,6 +3,8 @@ package Config::Any::JSON; use strict; use warnings; +use base 'Config::Any::Base'; + =head1 NAME Config::Any::JSON - Load JSON config files @@ -43,56 +45,95 @@ sub load { my $class = shift; my $file = shift; - open( my $fh, $file ) or die $!; + open( my $fh, '<', $file ) or die $!; + binmode $fh; my $content = do { local $/; <$fh> }; close $fh; - eval { require JSON::Syck; }; - if ( $@ ) { - require JSON; - return JSON::jsonToObj( $content ); + if ( eval { require Cpanel::JSON::XS } ) { + my $decoder = Cpanel::JSON::XS->new->utf8->relaxed; + return $decoder->decode( $content ); + } + elsif ( eval { require JSON::MaybeXS } ) { + my $decoder = JSON::MaybeXS::JSON()->new->utf8->relaxed; + return $decoder->decode( $content ); + } + elsif ( eval { require JSON::DWIW } ) { + my $decoder = JSON::DWIW->new; + my ( $data, $error ) = $decoder->from_json( $content ); + die $error if $error; + return $data; + } + elsif ( eval { require JSON::XS } ) { + my $decoder = JSON::XS->new->utf8->relaxed; + return $decoder->decode( $content ); + } + elsif ( eval { require JSON::Syck } ) { + require Encode; + return JSON::Syck::Load( Encode::decode('UTF-8', $content ) ); + } + elsif ( eval { require JSON::PP; JSON::PP->VERSION( 2 ); } ) { + my $decoder = JSON::PP->new->utf8->relaxed; + return $decoder->decode( $content ); + } + require JSON; + if ( eval { JSON->VERSION( 2 ) } ) { + return JSON::decode_json( $content ); } else { - return JSON::Syck::Load( $content ); + return JSON::jsonToObj( $content ); } } -=head2 is_supported( ) +=head2 requires_any_of( ) -Returns true if either L or L is available. +Specifies that this modules requires one of, L, +L, L, L, L, L or +L in order to work. =cut -sub is_supported { - eval { require JSON::Syck; }; - return 1 unless $@; - eval { require JSON; }; - return $@ ? 0 : 1; -} +sub requires_any_of { qw( + Cpanel::JSON::XS + JSON::MaybeXS + JSON::DWIW + JSON::XS + JSON::Syck + JSON::PP + JSON +) } =head1 AUTHOR -Brian Cassidy Ebricas@cpan.orgE +Brian Cassidy =head1 COPYRIGHT AND LICENSE -Copyright 2007 by Brian Cassidy +Copyright 2006-2016 by Brian Cassidy This library is free software; you can redistribute it and/or modify -it under the same terms as Perl itself. +it under the same terms as Perl itself. =head1 SEE ALSO -=over 4 +=over 4 =item * L =item * L -=item * L +=item * L + +=item * L + +=item * L + +=item * L =item * L +=item * L + =back =cut