Retry

Retry action

Name

Retry - Retry action

Synopsis

use Retry;

retry { action }, :4max, :2delay;

retry { say 'trying!'; die }, :max(-1), :delay({ constant @fib = 0, 1, *+* ... *; @fib[$++] });

Description

Retry is a module that exports retry sub which takes a Block to retry execute until success and return the result. or in case of Exception, rethrow after max retries.

max defaults to 4. sets the max number of retries. Use Inf, * or integer smaller 0 to retry forever.

delay defaults to 0.2. sets the delay between retries. The delay doubles with every retry. Use a Code object to provide your own stepping. Each call must return a Real.

Acknowledgements

Thanks to gfldex for improving the module by allowing passing Callable to delay, also allow using Inf and Whatever. and improving tests as well.

Author

Haytham Elganiny [email protected]

Copyright and License

Copyright 2020 Haytham Elganiny

This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.

Retry v0.0.5

Retry action

Authors

  • Haytham Elganiny

License

Artistic-2.0

Dependencies

Test::META

Test Dependencies

Provides

  • Retry

The Camelia image is copyright 2009 by Larry Wall. "Raku" is trademark of the Yet Another Society. All rights reserved.