stubborn-io

Crates.iostubborn-io
lib.rsstubborn-io
version0.3.5
sourcesrc
created_at2019-07-31 22:41:08.523215
updated_at2024-05-08 00:04:04.967681
descriptionio traits/structs that automatically recover from potential disconnections/interruptions.
homepage
repositoryhttps://github.com/craftytrickster/stubborn-io
max_upload_size
id153290
size43,116
David Raifaizen (craftytrickster)

documentation

https://docs.rs/stubborn-io

README

stubborn-io

This crate provides io traits/structs that automatically recover from potential disconnections/interruptions.

To use with your project, add the following to your Cargo.toml:

stubborn-io = "0.3"

API Documentation, examples and motivations can be found here - https://docs.rs/stubborn-io .

Usage Example

In this example, we will see a drop in replacement for tokio's TcpStream, with the distinction that it will automatically attempt to reconnect in the face of connectivity failures.

use stubborn_io::StubbornTcpStream;
use tokio::io::AsyncWriteExt;

let addr = "localhost:8080";

// we are connecting to the TcpStream using the default built in options.
// these can also be customized (for example, the amount of reconnect attempts,
// wait duration, etc) using the connect_with_options method.
let mut tcp_stream = StubbornTcpStream::connect(addr).await?;
// once we acquire the wrapped IO, in this case, a TcpStream, we can
// call all of the regular methods on it, as seen below
tcp_stream.write_all(b"hello world!").await?;
Commit count: 60

cargo fmt