NAME
JSON::Streaming::Writer - Generate JSON output in a streaming manner
SYNOPSIS
my $jsonw = JSON::Streaming::Writer->for_stream($fh)
$jsonw->start_object();
$jsonw->add_simple_property("someName" => "someValue");
$jsonw->add_simple_property("someNumber" => 5);
$jsonw->start_property("someObject");
$jsonw->start_object();
$jsonw->add_simple_property("someOtherName" => "someOtherValue");
$jsonw->add_simple_property("someOtherNumber" => 6);
$jsonw->end_object();
$jsonw->end_property();
$jsonw->start_property("someArray");
$jsonw->start_array();
$jsonw->add_simple_item("anotherStringValue");
$jsonw->add_simple_item(10);
$jsonw->start_object();
# No items; this object is empty
$jsonw->end_object();
$jsonw->end_array();
DESCRIPTION
Most JSON libraries work in terms of in-memory data structures. In Perl, JSON serializers often expect to be provided with a HASH or ARRAY ref containing all of the data you want to serialize.
This library allows you to generate syntactically-correct JSON without first assembling your complete data structure in memory. This allows large structures to be returned without requiring those structures to be memory-resident, and also allows parts of the output to be made available to a streaming-capable JSON parser while the rest of the output is being generated, which may improve performance of JSON-based network protocols.
RAW API
The raw API allows the caller precise control over the generated data structure by providing explicit methods for each fundamental JSON construct.
As a general rule, methods with names starting with start_
and end_
methods wrap a multi-step construct and must be used symmetrically, while methods with names starting with add_
stand alone and generate output in a single step.
The raw API methods are described below
start_object, end_object
These methods delimit a JSON object. start_object
can be called as the first method call on a writer object to produce a top-level object, or it can be called in any state where a value is expected to produce a nested object.
JSON objects contain properties, so only property-related methods may be used while in the context of an object.
start_array, end_array
These methods delimit a JSON array. start_array
can be called as the first method call on a writer object to produce a top-level array, or it can be called in any state where a value is expected to produce a nested array.
JSON arrays contain properties, so only value-producing methods may be used while in the context of an array.
start_property($name), end_property
These methods delimit a property or member of a JSON object. start_property
may be called only when in the context of an object. The $name
parameter, a string, gives the name that the generated property will have.
Only value-producing methods may be used while in the context of a property.
Since a property can contain only one value, only a single value-producing method may be called between a pair of start_property
and end_property
calls.
add_string($value)
Produces a JSON string with the given value.
add_number($value)
Produces a JSON number whose value is Perl's numeric interpretation of the given value.
add_boolean($value)
Produces a JSON boolean whose value is Perl's boolean interpretation of the given value.
add_null
Produces a JSON null
.
DWIM API
The DWIM API allows you to provide normal Perl data structures and have the library figure out a sensible JSON representation for them. You can mix use of the raw and DWIM APIs to allow you to exercise fine control where required but use a simpler API for normal cases.
add_value($value)
Produces a JSON value representing the given Perl value. This library can handle Perl strings, integers (i.e. scalars that have most recently been used as numbers), references to the values 0 and 1 representing booleans and undef
representing a JSON null
. It can also accept ARRAY and HASH refs that contain such values and produce JSON array and object values recursively, much like a non-streaming JSON producer library would do.
This method is a wrapper around the corresponding raw API calls, so the error messages it generates will often refer to the underlying raw API.
add_property($name, $value)
Produces a property inside a JSON object whose value is derived from the provided value using the same mappings as used by add_value
. This can only be used inside the context of an object, and is really just a wrapper around a start_property
, add_value
, end_property
sequence for convenience.
INTERNALS
Internally this library maintains a simple state stack that allows it to remember where it is without needing to remember the data it has already generated.
The state stack means that it will use more memory for deeper data structures.