5 stable releases

3.0.0 Jun 24, 2019
2.2.0 Apr 15, 2019
2.1.0 Apr 15, 2019
2.0.0 Mar 8, 2019
1.0.0 Mar 8, 2019

#23 in #datagram

Download history 136/week @ 2024-11-16 169/week @ 2024-11-23 167/week @ 2024-11-30 221/week @ 2024-12-07 263/week @ 2024-12-14 89/week @ 2024-12-21 55/week @ 2024-12-28 176/week @ 2025-01-04 250/week @ 2025-01-11 199/week @ 2025-01-18 118/week @ 2025-01-25 543/week @ 2025-02-01 374/week @ 2025-02-08 154/week @ 2025-02-15 155/week @ 2025-02-22 94/week @ 2025-03-01

906 downloads per month
Used in 11 crates (3 directly)

MIT/Apache

12KB
65 lines

async-datagram

crates.io version build status downloads docs.rs docs

Async datagram traits.

Examples

Basic usage

use async_datagram::AsyncDatagram;
use std::task::{Context, Poll};
use std::pin::Pin;

struct Udp;

impl AsyncDatagram for Udp {
  type Sender = std::net::SocketAddr;
  type Receiver = std::net::SocketAddr;
  type Err = std::io::Error;

  fn poll_send_to(
    self: Pin<&mut Self>,
    cx: &mut Context<'_>,
    buf: &[u8],
    target: &Self::Receiver,
  ) -> Poll<Result<usize, Self::Err>> {
    Poll::Ready(Ok(0))
  }

  fn poll_recv_from(
    self: Pin<&mut Self>,
    cx: &mut Context<'_>,
    buf: &mut [u8],
  ) -> Poll<Result<(usize, Self::Sender), Self::Err>> {
    Poll::Pending
  }
}

Installation

$ cargo add async-datagram

Safety

This crate uses #![deny(unsafe_code)] to ensure everything is implemented in 100% Safe Rust.

Contributing

Want to join us? Check out our "Contributing" guide and take a look at some of these issues:

References

None.

License

MIT OR Apache-2.0

No runtime deps