8 releases (stable)

1.2.4 Dec 2, 2023
1.2.3 Sep 25, 2023
1.2.2 Sep 18, 2020
1.2.1 Jul 7, 2020
0.1.0 May 31, 2020

#1919 in Asynchronous

Download history 27923/week @ 2024-10-08 28259/week @ 2024-10-15 28292/week @ 2024-10-22 25473/week @ 2024-10-29 23971/week @ 2024-11-05 22395/week @ 2024-11-12 22178/week @ 2024-11-19 18219/week @ 2024-11-26 23553/week @ 2024-12-03 24328/week @ 2024-12-10 23312/week @ 2024-12-17 9858/week @ 2024-12-24 14244/week @ 2024-12-31 21495/week @ 2025-01-07 23175/week @ 2025-01-14 18433/week @ 2025-01-21

79,265 downloads per month
Used in 212 crates (32 directly)

Apache-2.0 OR MIT

18KB
296 lines

async-dup

Build License Cargo Documentation

Duplicate an async I/O handle.

This crate provides two tools, Arc and Mutex:

  • Arc implements AsyncRead, AsyncWrite, and AsyncSeek if a reference to the inner type does.
  • A reference to Mutex implements AsyncRead, AsyncWrite, and AsyncSeek if the inner type does.

Wrap an async I/O handle in Arc or Mutex to clone it or share among tasks.

Examples

Clone an async I/O handle:

use async_dup::Arc;
use futures::io;
use smol::Async;
use std::net::TcpStream;

// A client that echoes messages back to the server.
let stream = Async::<TcpStream>::connect("127.0.0.1:8000").await?;

// Create two handles to the stream.
let reader = Arc::new(stream);
let mut writer = reader.clone();

// Echo data received from the reader back into the writer.
io::copy(reader, &mut writer).await?;

Share an async I/O handle:

use async_dup::Mutex;
use futures::io;
use futures::prelude::*;

// Reads data from a stream and echoes it back.
async fn echo(stream: impl AsyncRead + AsyncWrite + Unpin) -> io::Result<u64> {
    let stream = Mutex::new(stream);
    io::copy(&stream, &mut &stream).await
}

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

~545KB

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy