Provided by: libdata-stream-bulk-perl_0.11-1.1_all
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.