3 stable releases

1.2.0 May 1, 2021
1.1.0 Mar 20, 2021
1.0.3 Feb 14, 2021
1.0.2 Oct 4, 2020
1.0.1 Sep 29, 2020

#46 in Network programming

Download history 50270/week @ 2021-01-16 54824/week @ 2021-01-23 58547/week @ 2021-01-30 55895/week @ 2021-02-06 66026/week @ 2021-02-13 69227/week @ 2021-02-20 71352/week @ 2021-02-27 69449/week @ 2021-03-06 67387/week @ 2021-03-13 68875/week @ 2021-03-20 68096/week @ 2021-03-27 67128/week @ 2021-04-03 67551/week @ 2021-04-10 46563/week @ 2021-04-17 43038/week @ 2021-04-24 38934/week @ 2021-05-01

270,784 downloads per month
Used in 15 crates (via zbus)

Apache-2.0 OR MIT

9KB
55 lines

nb-connect (deprecated)

Build License Cargo Documentation

This crate is now deprecated in favor of socket2.

Non-blocking TCP or Unix connect.

This crate allows you to create a TcpStream or a UnixStream in a non-blocking way, without waiting for the connection to become fully established.

Examples

use polling::{Event, Poller};
use std::time::Duration;

// Create a pending TCP connection.
let stream = nb_connect::tcp(([127, 0, 0, 1], 80))?;

// Create a poller that waits for the stream to become writable.
let poller = Poller::new()?;
poller.add(&stream, Event::writable(0))?;

// Wait for at most 1 second.
if poller.wait(&mut Vec::new(), Some(Duration::from_secs(1)))? == 0 {
    println!("timeout");
} else if let Some(err) = stream.take_error()? {
    println!("error: {}", err);
} else {
    println!("connected");
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~170KB