support Cpanel::JSON::XS and JSON::MaybeXS
[p5sagit/Config-Any.git] / lib / Config / Any / JSON.pm
index 950424f..81cbaf8 100644 (file)
@@ -45,30 +45,40 @@ 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;
 
-    if ( eval { require JSON::DWIW } ) {
+    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->relaxed;
+        my $decoder = JSON::XS->new->utf8->relaxed;
         return $decoder->decode( $content );
     }
     elsif ( eval { require JSON::Syck } ) {
-        return JSON::Syck::Load( $content );
+        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->relaxed;
+        my $decoder = JSON::PP->new->utf8->relaxed;
         return $decoder->decode( $content );
     }
     require JSON;
     if ( eval { JSON->VERSION( 2 ) } ) {
-        return JSON::from_json( $content );
+        return JSON::decode_json( $content );
     }
     else {
         return JSON::jsonToObj( $content );