#retry #tor #arti #async

retry-error

An error type for an operation that can fail more than once

22 releases

new 0.6.2 Jan 7, 2025
0.6.1 Dec 2, 2024
0.6.0 Sep 30, 2024
0.5.3 Jun 5, 2024
0.0.0 Jun 24, 2021

#1789 in Rust patterns

Download history 1305/week @ 2024-09-17 1829/week @ 2024-09-24 1491/week @ 2024-10-01 949/week @ 2024-10-08 1045/week @ 2024-10-15 1333/week @ 2024-10-22 1876/week @ 2024-10-29 1528/week @ 2024-11-05 1745/week @ 2024-11-12 2208/week @ 2024-11-19 2270/week @ 2024-11-26 2222/week @ 2024-12-03 2760/week @ 2024-12-10 1909/week @ 2024-12-17 790/week @ 2024-12-24 960/week @ 2024-12-31

6,765 downloads per month
Used in 76 crates (4 directly)

MIT/Apache

18KB
302 lines

retry-error

An error attempt to represent multiple failures.

This crate implements RetryError, a type to use when you retry something a few times, and all those attempts can fail differently each time. Instead of returning only a single error, it records all of the errors received, in case they are different.

This crate is developed as part of Arti, a project to implement Tor in Rust. It's used by higher-level crates that retry operations.

Example

use retry_error::RetryError;

fn some_operation() -> anyhow::Result<bool> {
   unimplemented!(); // example
}

fn example() -> Result<(), RetryError<anyhow::Error>> {
   const N_ATTEMPTS: usize = 10;
   let mut err = RetryError::in_attempt_to("perform an example operation");
   for _ in 0..N_ATTEMPTS {
       match some_operation() {
           Ok(val) => return Ok(()),
           Err(e) => err.push(e),
       }
   }
   // All attempts failed; return all the errors.
   return Err(err);
}

License: MIT OR Apache-2.0

No runtime deps