4 releases

new 0.1.4 Apr 26, 2024
0.1.3 Mar 31, 2024
0.1.2 Mar 26, 2024
0.1.1 Jan 27, 2024
0.1.0 Dec 4, 2023

#5 in #multi

Download history 5/week @ 2024-01-26 6/week @ 2024-02-09 6/week @ 2024-02-16 21/week @ 2024-02-23 6/week @ 2024-03-01 2/week @ 2024-03-08 1/week @ 2024-03-15 99/week @ 2024-03-22 144/week @ 2024-03-29 15/week @ 2024-04-05

258 downloads per month

MIT license

11KB
170 lines

Wrapper for multiple readers

MultiReader is lazy. It does nothing if you don't use.

Usage

  • SliceReader and BytesReader
use multi_readers::{BytesReader, SliceReader, join_readers};
use std::io::Read;

fn main() -> std::io::Result<()> {
    let slice = SliceReader::new(b"hello");
    let bytes = BytesReader::new("world".as_bytes().to_vec()); 
    let mut reader = join_readers!(slice, bytes);
    let mut buf = [0; 5];
    let len = reader.read(&mut buf)?;
    assert_eq!(b"hello", &buf[..len]);
    let len = reader.read(&mut buf)?;
    assert_eq!(b"world", &buf[..len]);
    Ok(())
}

Usage

  • Merge any type that implements the trait std::io::Read
use multi_readers::{BytesReader, SliceReader, join_readers};
use std::{fs::File, io::Read};
fn main() -> std::io::Result<()> {
    let slice = SliceReader::new(b"First-");
    let bytes = BytesReader::new(b"Second-".to_vec()); 
    std::fs::write("test.txt", b"Third")?;
    let f = File::open("test.txt")?;
    let mut reader = join_readers!(slice, bytes, f);
    let mut buf = String::new();
    reader.read_to_string(&mut buf)?;
    assert_eq!(buf.as_str(), "First-Second-Third");
    Ok(())
}


No runtime deps