NAME
Reflex::Callback::Promise - Condvar-like non-callback adapter
VERSION
version 0.004
SYNOPSIS
Used within Reflex:
use Reflex::Timer;
use ExampleHelpers qw(eg_say);
my $pt = Reflex::Timer->new(
interval => 1 + rand(),
auto_repeat => 1,
);
while (my $event = $pt->wait()) {
eg_say("promise timer returned an event (@$event)");
}
Low-level usage:
use Reflex::Callback::Promise;
my $cb = Reflex::Callback::Promise->new();
$cb->deliver( greet => { name => "world" } );
my $event = $cb->wait();
print "event '$event->{name}': hello, $event->{arg}{name}\n";
DESCRIPTION
Reflex::Callback::Promise maps the generic Reflex::Callback interface to non-callback promises, which are kind of like condvars. In most cases, Reflex::Callbacks' cb_promise() or other syntactic sweeteners will be used instead of raw Reflex::Callback::Promise objects.
new
Reflex::Callback::Promise's constructor takes no parameters. It creates a promise queue that is populated by deliver() and drained by wait(). Furthermore, wait() will block as necessary until it can return an event. This requires the help of some form of concurrency, currently hardcoded to use POE.
A future version may delegate the POE dependency to a subclass.
wait
Reflex::Callback::Promise's wait() method retrieves the next pending event held in the object's queue. If the queue is empty, wait() will dispatch other events until some asynchronous code enqueues a new event in the promise's queue.
deliver
Reflex::Callback::Promise's deliver() enqueues events for the promise. As with other Reflex::Callback subclasses, this deliver() accepts two positional parameters: an event name (which IS used), and a hashref of named parameters to be passed to the callback.
Deliver doesn't return anything meaningful, since the code to handle the event isn't executed at the time of delivery.
SEE ALSO
Reflex Reflex::Callback Reflex::Callbacks
"ACKNOWLEDGEMENTS" in Reflex "ASSISTANCE" in Reflex "AUTHORS" in Reflex "BUGS" in Reflex "BUGS" in Reflex "CONTRIBUTORS" in Reflex "COPYRIGHT" in Reflex "LICENSE" in Reflex "TODO" in Reflex