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

#11 in #datagram

Download history 96/week @ 2023-12-03 114/week @ 2023-12-10 160/week @ 2023-12-17 111/week @ 2023-12-24 38/week @ 2023-12-31 129/week @ 2024-01-07 134/week @ 2024-01-14 97/week @ 2024-01-21 68/week @ 2024-01-28 96/week @ 2024-02-04 124/week @ 2024-02-11 181/week @ 2024-02-18 150/week @ 2024-02-25 181/week @ 2024-03-03 170/week @ 2024-03-10 170/week @ 2024-03-17

680 downloads per month
Used in 12 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