The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    `IO::Async::JSONStream' - send or receive lines of JSON data in
    `IO::Async'

SYNOPSIS
     use IO::Async::JSONStream;

     use IO::Async::Loop;
     my $loop = IO::Async::Loop->new;

     my $jsonstream = IO::Async::JSONStream->new;
     $loop->add( $jsonstream );

     $jsonstream->connect(
        host    => "my.server",
        service => 12345,
     )->then( sub {
        $jsonstream->write_json( [ data => { goes => "here" } ] );
        $jsonstream->read_json
     })->on_done( sub {
        my ( $data ) = @_;

        print "Received the data $data\n";
     })->get;

DESCRIPTION
    This subclass of IO::Async::Stream implements a simple JSON-encoded data
    stream, sending and receiving Perl data structures by JSON-encoded lines
    of text.

EVENTS
    The following events are invoked, either using subclass methods or CODE
    references in parameters:

  on_json $data
    Invoked when a line of JSON-encoded data is received. It is passed the
    decoded data as a regular Perl data structure.

  on_json_error $error, $line
    Invoked when a line is received but JSON decoding fails. It is passed
    the failure exception from the JSON decoder and the line on which
    decoding failed.

PARAMETERS
    The following named parameters may be passed to `new' or `configure':

    on_json => CODE
    on_json_error => CODE
            CODE references for event handlers.

    eol => STRING
            Optional. Sets the string used for the line ending on the
            stream. Defaults to `\n' if not given.

METHODS
  $jsonstream->write_json( $data, %args )
    Writes a new line of JSON-encoded data from the given Perl data
    structure.

    Other arguments are passed to the `write' method. Returns a `Future'
    which will complete when the line is flushed.

  $jsonstream->read_json ==> $data
    Returns a Future that will yield the next line of JSON-encoded data to
    be read from the stream. This takes place instead of the `on_json'
    event.

    If a JSON decoding error occurs it will result in a failed Future with
    the operation name `json' and the line on which decoding failed as its
    argument.

TODO
    * Consider a true streaming mode, using `JSON''s incremental parsing
      ability.

AUTHOR
    Paul Evans <leonerd@leonerd.org.uk>