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=81cbaf898ad869a1e86b287b30148e0e783698ed;hp=ce2954906b287afb9c8cefbf525e793888559451;hb=837fdc4c1b81b0032be8cf1c06e0a13f4e153133;hpb=c793253e5f2ad3ca9d60e96e07a5d87fa344ec31 diff --git a/lib/Config/Any/JSON.pm b/lib/Config/Any/JSON.pm index ce29549..81cbaf8 100644 --- a/lib/Config/Any/JSON.pm +++ b/lib/Config/Any/JSON.pm @@ -45,33 +45,54 @@ 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::XS; }; - unless( $@ ) { - return JSON::XS::decode_json( $content ); + if ( eval { require Cpanel::JSON::XS } ) { + my $decoder = Cpanel::JSON::XS->new->utf8->relaxed; + return $decoder->decode( $content ); } - - eval { require JSON::Syck; }; - unless( $@ ) { - return JSON::Syck::Load( $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; - eval { JSON->VERSION( 2 ); }; - return $@ ? JSON::jsonToObj( $content ) : JSON::from_json( $content ); + if ( eval { JSON->VERSION( 2 ) } ) { + return JSON::decode_json( $content ); + } + else { + return JSON::jsonToObj( $content ); + } } =head2 requires_any_of( ) -Specifies that this modules requires one of, L, L or -L in order to work. +Specifies that this modules requires one of, L, L, +L or L in order to work. =cut -sub requires_any_of { 'JSON::XS', 'JSON::Syck', 'JSON' } +sub requires_any_of { 'JSON::DWIW', 'JSON::XS', 'JSON::Syck', 'JSON::PP', 'JSON' } =head1 AUTHOR @@ -79,7 +100,7 @@ Brian Cassidy Ebricas@cpan.orgE =head1 COPYRIGHT AND LICENSE -Copyright 2006-2009 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. @@ -92,11 +113,13 @@ it under the same terms as Perl itself. =item * L -=item * L +=item * L + +=item * L =item * L -=item * L +=item * L =back