NAME
    IO::Buffered - A simple buffer class for dealing with different data
    types

SYNOPSIS
      my $buf = new IO::Buffered(Split => qr/,/);
      $buf->write("record1,reco")
      $buf->write("rd2,record3");

      my @records = $buf->read(); # @records is now ("record1", "record2")
      @records = $buf->read_last(); # @records is now ("record3")

DESCRIPTION
    IO::Buffered provides a simple unified way of dealing with buffering.
    This is done by providing a set of buffering types each with an
    understanding of what they are buffering. All buffering types share a
    common set of function for working with the buffer.

    write($str,..)
        "write()" appends more data to the buffer if the buffer type allows
        it. Different types might have rules that prohibit the buffer for
        growing over a certain limit or mandates that only certain types of
        data be written to the buffer.

        In case of error the number of bytes written to the buffer is
        returned and the function croaks.

    read($alt_size)
        "read()" returns the number of ready records as defined by the
        buffer type or returns an empty array when no records are available.
        Read records will be cleared from the buffer. $alt_size defines
        alternative size of the next record in the buffer if the buffer type
        does not know how much data to buffer before returning the record.
        This is currently used by the HTTP buffer type when it is in
        HeaderOnly mode and needs to return the data part of a http request.

    read_last()
        "read_last()" returns the number of ready records as defined by the
        buffer type and the rest of the buffer as the last record. Or
        returns an empty array when no records are available. After
        "read_last" is called the buffer will be empty.

    flush($str, ...)
        "flush()" flushes the buffer if no input or replace the buffer with
        the input.

    buffer()
        "buffer()" returns a copy of the buffer.

    returns_last()
        "returns_last()" tells if the buffer type knows if it's dealing with
        a complete record or not. Or a call to <read_last()> is need to get
        all valid records. An example of this is the "Split" buffer type
        where record delimiter does not have to be at the end of every
        record:

          my $buffer = new IO::Buffered::Split(qr/\n/);
          $buffer->write("Hello\nHello");
          
  if($buffer->returns_last) {
              my @records = $buffer->read(); # @records would be ('Hello')
          } else {
              my @records = $buffer->read_last(); # @records is ('Hello', 'Hello')
          }

BUFFER TYPES
  Regexp
    The Regexp buffer type takes a regular expression as input and splits
    records based on that. Only the match defined in the () is returned and
    not the complete match.

    An example would be "qr/^(.+)\n/" that would work as line buffing:

      my $buf = IO::Buffered(Regexp => qr/^(.+)\n/);

    Read more here: IO::Buffered::Regexp

  Split
    Split is special case of the Regexp buffer type and is in essence just
    "/(.*?)$split/". Here only the non matching part of $split is returned.

    An example would be "qr/\n/" that also works as line buffering or
    "qr/\0/" for C strings.

      my $buf = IO::Buffered(Split => qr/\n/);

    Read more here: IO::Buffered::Split

  Size
    The Size buffering type reads the size from the data to determine where
    record boundaries are. Only the data is returned not the bytes that hold
    the length information. Size buffering takes two arguments, a pack
    template and a offset for the numbers of bytes to add to the length that
    was unpacked with the template.

    An example would be a template of "n" and a offset of 0 that could be
    used to handle DNS tcp requests. Offset defaults to 0 if not set.

      my $buf = IO::Buffered(Size => ["n", 0]);

    Read more here: IO::Buffered::Size

  FixedSize
    FixedSize buffering returns records in fixed size chunks.

    An example would to return 100 bytes at a time:

      my $buf = IO::Buffered(FixedSize => 100);

    Read more here: IO::Buffered::FixedSize

  Last
    Last buffering simple only returns one record when read_last is called.
    All calls to read will return an empty array.

    An example would be:

      my $buf = IO::Buffered(Last => 1);

    Read more here: IO::Buffered::Last

  HTTP
    HTTP buffering provides a simple buffering for HTTP traffic by looking
    for "Content-Length:" in the HTTP header. If one is found this will be
    used to split records. If not only the header will be returned.

    An example would be:

      my $buf = IO::Buffered(HTTP => 1);

    Read more here: IO::Buffered::HTTP

GENERIC OPTIONS
  MaxSize
    MaxSize provides a limit on how big a buffer can grow, when the limit is
    hit an exception is thrown.

    The default value for MaxSize is 0, meaning that there is no size limit
    on the buffer.

METHODS
    new()
        IO::Buffered simple provides a wrapper for the different buffering
        types. The argument given to the buffer type is simply given as
        first argument to the constructor of the buffer type, as show below:

          $buf = Buffered::IO(Split => qr/\n/);

          # is the same as

          $buf = Buffered::IO::Split(qr/\n/);

        Extra options are passed along as an array after first argument, as
        show below:

          $buf = Buffered::IO(Split => qr/\n/, MaxSize => 1000_000);

          # is the same as

          $buf = Buffered::IO::Split(qr/\n/, MaxSize => 1000_000);

        Buffered::IO recasts exceptions so there is no differences in using
        either interface.

    recroak()
        Helper function to rethrow croaks

AUTHOR
    Troels Liebe Bentsen <tlb@rapanden.dk>

COPYRIGHT
    Copyright(C) 2008 Troels Liebe Bentsen

    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.