NAME
Dezi::Queue - simple in-memory FIFO queue class
SYNOPSIS
use Dezi::Queue;
my $queue = Dezi::Queue->new;
$queue->put( 'foo' );
$queue->size; # returns number of items in queue (1)
$queue->peek; # returns 'foo' (next value for get())
$queue->get; # returns 'foo' locks it in queue (no one else can get it)
$queue->remove('foo'); # returns 'foo' and removes it from queue
$queue->clean; # removes all completed items from queue
DESCRIPTION
Dezi::Queue is basically a Perl array, but it defines an API that can be implemented using any kind of storage and logic you want. One example would be a database that tracks items to be evaluated, or a flat file list.
METHODS
See Dezi::Class.
BUILD
Overrides base method. Called internally by new().
put( item )
Add item to the queue. Default is to push() it to end of queue.
get
Returns the next item. Default is to shift() it from the front of the queue.
remove( item )
Removes item from the queue (unlocks it).
clean
Removes all locked items from the queue.
peek
Returns the next item value, but leaves it on the stack.
size
Returns the number of items currently in the queue.
AUTHOR
Peter Karman, <perl@peknet.com>
BUGS
Please report any bugs or feature requests to bug-swish-prog at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Dezi-App. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Dezi
You can also look for information at:
Mailing list
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
COPYRIGHT AND LICENSE
Copyright 2008-2009 by Peter Karman
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.