dgrambuf

Crates.iodgrambuf
lib.rsdgrambuf
version0.2.0
sourcesrc
created_at2022-04-22 13:27:27.969394
updated_at2023-01-13 17:16:04.500187
descriptionA fixed capacity ring buffer for datagrams (byte slices)
homepagehttps://sr.ht/~jpastuszek/dgrambuf/
repositoryhttps://git.sr.ht/~jpastuszek/dgrambuf
max_upload_size
id572160
size19,464
Jakub Pastuszek (jpastuszek)

documentation

https://docs.rs/dgrambuf

README

Latest Version Documentation License

A fixed size ring buffer for datagrams of various sizes.

Implementation uses std::collections::VecDeque for metadata storage and a fixed size backing buffer for storage of datagram data.

Examples

Usage as store and forward buffer for UNIX datagram socket.

use dgrambuf::DatagramBuf;
use std::os::unix::net::UnixDatagram;

fn main() -> std::io::Result<()> {
    let socket = UnixDatagram::bind("/path/to/my/socket")?;

    // allocate backing buffer
    let mut dgram_buf = Vec::new();
    dgram_buf.resize(512, 0);

    let mut dgram_buf = DatagramBuf::from_slice(&mut dgram_buf);

    // receive 10 datagrams up to 128 bytes in length each
    for _ in 0..10 {
        // drop old datagrams if there is not enough space left in the backing buffer (512)
        let mut buf = dgram_buf.alloc_front_drop(128).unwrap();

        let count = socket.recv(&mut buf)?;
        // reduce the size of the allocation to fit the datagram received
        dgram_buf.truncate_front(count);
    }

    // send back the received datagrams in order
    while let Some(mut buf) = dgram_buf.pop_back() {
        socket.send(&mut buf)?;
    }
    Ok(())
}
Commit count: 0

cargo fmt