Provided by: libjson-maybexs-perl_1.001000-1_all 

NAME
JSON::MaybeXS - use Cpanel::JSON::XS with a fallback to JSON::PP
SYNOPSIS
use JSON::MaybeXS;
my $data_structure = decode_json($json_input);
my $json_output = encode_json($data_structure);
my $json = JSON->new;
my $json_with_args = JSON::MaybeXS->new(utf8 => 1); # or { utf8 => 1 }
DESCRIPTION
This module tries to load Cpanel::JSON::XS, and if that fails instead tries to load JSON::PP. If neither
is available, an exception will be thrown.
It then exports the "encode_json" and "decode_json" functions from the loaded module, along with a "JSON"
constant that returns the class name for calling "new" on.
If you're writing fresh code rather than replacing JSON.pm usage, you might want to pass options as
constructor args rather than calling mutators, so we provide our own "new" method that supports that.
EXPORTS
All of "encode_json", "decode_json" and "JSON" are exported by default.
To import only some symbols, specify them on the "use" line:
use JSON::MaybeXS qw(encode_json decode_json); # functions only
use JSON::MaybeXS qw(JSON); # JSON constant only
encode_json
This is the "encode_json" function provided by the selected implementation module, and takes a perl data
stucture which is serialised to JSON text.
my $json_text = encode_json($data_structure);
decode_json
This is the "decode_json" function provided by the selected implementation module, and takes a string of
JSON text to deserialise to a perl data structure.
my $data_structure = decode_json($json_text);
JSON
The "JSON" constant returns the selected implementation module's name for use as a class name - so:
my $json_obj = JSON->new; # returns a Cpanel::JSON::XS or JSON::PP object
and that object can then be used normally:
my $data_structure = $json_obj->decode($json_text); # etc.
CONSTRUCTOR
new
With JSON::PP and Cpanel::JSON::XS you are required to call mutators to set options, i.e.
my $json = $class->new->utf8(1)->pretty(1);
Since this is a trifle irritating and noticeably un-perlish, we also offer:
my $json = JSON::MaybeXS->new(utf8 => 1, pretty => 1);
which works equivalently to the above (and in the usual tradition will accept a hashref instead of a
hash, should you so desire).
AUTHOR
mst - Matt S. Trout (cpan:MSTROUT) <mst@shadowcat.co.uk>
CONTRIBUTORS
None yet. Well volunteered? :)
COPYRIGHT
Copyright (c) 2013 the "JSON::MaybeXS" "AUTHOR" and "CONTRIBUTORS" as listed above.
LICENSE
This library is free software and may be distributed under the same terms as perl itself.
perl v5.18.1 2013-12-11 JSON::MaybeXS(3pm)