NAME
Mojo::Promise::Role::Any - Fulfill with the first fulfilled promise
SYNOPSIS
use Mojo::Promise;
my $any_promise = Mojo::Promise
->with_roles( '+Any' )
->any( @promises );
DESCRIPTION
NOTE: Mojolicious 8.73 adds any()
as a stable feature, so you don't need this role.
Make a new promise that fulfills with the first fulfilled promise, and rejects otherwise. The result is a flat list of the arguments for the fulfilled promise (and not an anonymous array of values).
This should be the Perl expression of the same idea in bluebirdjs (http://bluebirdjs.com/docs/api/promise.any.html).
This is handy, for instance, for asking for several servers to provide the same resource and taking the first one that responds.
- any( @promises )
-
Takes a lists of promises (or thenables) and returns another promise that fulfills when any promise fulfills (and it ignores the others after that).
If none of the promises fulfill, the any promise rejects.
If you pass no promises, the any promise rejects.
SEE ALSO
Mojolicious, Mojo::Promise, Role::Tiny
http://bluebirdjs.com/docs/api/promise.any.html
SOURCE AVAILABILITY
This source is in Github:
https://github.com/briandfoy/mojo-promise-role-higherorder
AUTHOR
brian d foy, <briandfoy@pobox.com>
COPYRIGHT AND LICENSE
Copyright © 2018-2024, brian d foy, All Rights Reserved.
You may redistribute this under the terms of the Artistic License 2.0.