# Data::Stream::Bulk::DoneFlag - phpMan

## NAME
    [Data::Stream::Bulk::DoneFlag] - Implement the "is_done" method in terms
    of a flag

## VERSION
    version 0.11

## SYNOPSIS
            package [Data::Stream::Bulk::Blah];
            use Moose;

            with qw([Data::Stream::Bulk::DoneFlag]);

            sub get_more {
                    if ( my @more = more() ) {
                            return \@more;
                    } else {
                            return;
                    }
            }

## DESCRIPTION
    This role implements the "[Data::Stream::Bulk]" core API in terms of one
    method ("get_more").

    As a convenience it calls "finished" when the stream is exhausted, so
    that cleanup may be done.

    This is used by classes like [Data::Stream::Bulk::DBI],
    [Data::Stream::Bulk::Callback].

## METHODS
    is_done
        Returns the state of the iterator.

    next
        As long as the iterator is not yet done, calls "get_more".

        If "get_more" returned a false value instead of an array reference
        then "done" is set, "finished" is called, and this "next" does
        nothing on subsequent calls.

    finished
        A noop by default. Can be overridden if so desired.

REQUIRED_METHODS
    get_more
        Returns the next block of data as an array ref, or a false value if
        no items are left.

## AUTHOR
    Yuval Kogman <<nothingmuch@woobling.org>>

## COPYRIGHT AND LICENSE
    This software is copyright (c) 2012 by Yuval Kogman.

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

