NAME

AnyEvent::Retry::Coro - AnyEvent::Retry for jobs that run in separate threads

VERSION

version 0.03

SYNOPSIS

use Coro;

my $r = AnyEvent::Retry::Coro->new(
    max_tries => 100, # eventually give up
    interval  => { Constant => { interval => 1 } }, # try every second
    try       => {
        die 'out of cake!' if $cake-- < 0;
        return do_science();
    },

);

my $neat_gun = $r->run; # keep on trying until you run out of cake

DESCRIPTION

This module makes AnyEvent::Retry work nicely with Coro. You don't need to provide success or failure callbacks anymore, and your task to retry just needs die or return a result.

METHODS

run

This runs the task, blocking the thread until a result is available. If your task encounters an error, this will die. If it's sucessful, it returns the result.

wait

Allows you to run the task without blocking:

$r->start;
...; # do anything
my $result = $r->wait; # block here

run is implemented exactly like the above.

AUTHOR

Jonathan Rockway <jrockway@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2010 by Jonathan Rockway.

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