2 unstable releases

0.6.0 May 29, 2020
0.5.0 May 29, 2020

#977 in Asynchronous

Download history 13/week @ 2024-08-29 44/week @ 2024-09-05 11/week @ 2024-09-12 16/week @ 2024-09-19 8/week @ 2024-09-26 19/week @ 2024-10-03 31/week @ 2024-10-10 23/week @ 2024-10-17 17/week @ 2024-10-24 11/week @ 2024-10-31 20/week @ 2024-11-07 26/week @ 2024-11-14 27/week @ 2024-11-21 9/week @ 2024-11-28 6/week @ 2024-12-05 12/week @ 2024-12-12

60 downloads per month

MIT license

380KB
5.5K SLoC

futures-net

CI (Linux) Doc Version License


lib.rs:

Async network TCP, UDP, UDS

The types are designed to closely follow the APIs of the analogous types in std::net in Asychronous versions.

Examples

TCP Server

use futures_net::{TcpListener, TcpStream, runtime::Runtime};
use futures::prelude::*;

async fn say_hello(mut stream: TcpStream) {
    stream.write_all(b"Shall I hear more, or shall I speak at this?").await;
}

#[futures_net::main]
async fn main() -> Result<(), Box<dyn std::error::Error + 'static>> {
    let socket_addr = "127.0.0.1:8080".parse()?;
    let mut listener = TcpListener::bind(&socket_addr)?;
    let mut incoming = listener.incoming();

    // accept connections and process them serially
    while let Some(stream) = incoming.next().await {
        say_hello(stream?).await;
    }
    Ok(())
}

TCP Client

use std::error::Error;
use futures::prelude::*;
use futures_net::{TcpListener, TcpStream, runtime::Runtime};

#[futures_net::main]
async fn main() -> Result<(), Box<dyn Error + 'static>> {
    let socket_addr = "127.0.0.1:8080".parse()?;
    let mut buffer = vec![];
    let mut stream = TcpStream::connect(&socket_addr).await?;

    stream.read(&mut buffer).await?;
    println!("{:?}", buffer);
    Ok(())
}

Dependencies

~1.5–2.3MB
~41K SLoC