NAME
Future::AsyncAwait - deferred subroutine syntax for futures
SYNOPSIS
use Future::AsyncAwait;
async sub do_a_thing
{
my $first = await do_first_thing();
my $second = await do_second_thing();
return combine_things( $first, $second );
}
do_a_thing()->get;
This module provides syntax for deferring and resuming subroutines
while waiting for Futures to complete.
WARNING: The actual semantics in this module are not yet implemented.
This is released purely to demonstrate the syntax parts of its
operation, to reserve the name on CPAN, and to provide something that
actually exists in order to look at it. Don't expect to be able to use
this module in any real code yet.
That said, the only part that isn't actually implemented currently is
the part that suspends and resumes subroutines while waiting for a
future to complete. The syntax parsing, as well as semantics for
immediate futures, are already defined and working now. So it is
already very slightly useful for writing simple functions that return
immediate futures.
Instead of writing
sub foo
{
...
return Future->done( @result );
}
you can now simply write
async sub
{
...
return @result;
}
with the added side-benefit that any exceptions thrown by the elided
code will be turned into an immediate-failed Future rather than making
the call itself propagate the exception, which is usually what you
wanted when dealing with futures.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>