NAME
    Text::ZPL - Encode and decode ZeroMQ Property Language

SYNOPSIS
      # Decode ZPL to a HASH:
      my $data = decode_zpl( $zpl_text );
      # Encode a HASH to ZPL text:
      my $zpl = encode_zpl( $data );

DESCRIPTION
    An implementation of the "ZeroMQ Property Language", a simple ASCII
    configuration file format; see <http://rfc.zeromq.org/spec:4> for
    details.

    Exports two functions by default: "decode_zpl" and "encode_zpl". This
    module uses Exporter::Tiny to export functions, which allows for
    flexible import options; see the Exporter::Tiny documentation for
    details.

    As a simple example, a "ZPL" file as such:

      # This is my conf.
      # There are many like it, but this one is mine.
      confname = "My Config"

      context
          iothreads = 1

      main
          publisher
              bind = tcp://eth0:5550
              bind = tcp://eth0:5551
          subscriber
              connect = tcp://192.168.0.10:5555

    ... results in a structure like:

      {
        confname => "My Config",
        context => { iothreads => '1' },
        main => {
          subscriber => {
            connect => 'tcp://192.168.0.10:5555'
          },
          publisher => {
            bind => [ 'tcp://eth0:5550', 'tcp://eth0:5551' ]
          }
        }
      }

  decode_zpl
    Given a string of "ZPL"-encoded text, returns an appropriate Perl
    "HASH"; an exception is thrown if invalid input is encountered.

    (See Text::ZPL::Stream for a streaming interface.)

  encode_zpl
    Given a Perl "HASH", returns an appropriate "ZPL"-encoded text string;
    an exception is thrown if the data given cannot be represented in "ZPL"
    (see "CAVEATS").

   TO_ZPL
    A blessed object can provide a TO_ZPL method that will supply a plain
    "HASH" or "ARRAY" (but see "CAVEATS") to the encoder:

      # Shallow-clone this object's backing hash, for example:
      sub TO_ZPL {
        my $self = shift;
        +{ %$self }
      }

  CAVEATS
    Not all Perl data structures can be represented in ZPL; specifically,
    deeply-nested structures in an "ARRAY" will throw an exception:

      # Simple list is OK:
      encode_zpl(+{ list => [ 1 .. 3 ] });
      #  -> list: 1
      #     list: 2
      #     list: 3
      # Deeply nested is not representable:
      encode_zpl(+{
        list => [
          'abc',
          list2 => [1 .. 3]
        ],
      });
      #  -> dies

    Encoding skips empty lists ("ARRAY" references).

    (The spec is unclear on all this; issues welcome via RT or GitHub!)

SEE ALSO
    Text::ZPL::Stream

AUTHOR
    Jon Portnoy <avenj@cobaltirc.org>