#reader #byte #tap #read #buffer #own #copies

tap-reader

Wraps an existing reader and copies the read bytes into it's own buffer

2 stable releases

Uses old Rust 2015

1.0.1 Sep 9, 2018

#2349 in Encoding

Download history 106/week @ 2024-03-15 133/week @ 2024-03-22 192/week @ 2024-03-29 114/week @ 2024-04-05 111/week @ 2024-04-12 140/week @ 2024-04-19 120/week @ 2024-04-26 111/week @ 2024-05-03 107/week @ 2024-05-10 90/week @ 2024-05-17 91/week @ 2024-05-24 100/week @ 2024-05-31 53/week @ 2024-06-07 83/week @ 2024-06-14 104/week @ 2024-06-21 48/week @ 2024-06-28

305 downloads per month
Used in 3 crates (2 directly)

GPL-3.0 license

15KB
79 lines

tap-reader

Wraps an existing reader and copies the read bytes into it's own buffer

Installation

Add the following line to your Cargo.toml:

[dependencies]
tap-reader = "1"

Usage

To use, add the following lines to your crate root (src/lib.rs, src/main.rs, etc.)

extern crate tap_reader;

use tap_reader::Tap;

Example

extern crate tap_reader;
extern crate serde_json;
extern crate serde;
#[macro_use] extern crate serde_derive;

use std::error::Error;
use std::io::Cursor;
use tap_reader::Tap;

#[derive(Debug, Deserialize, PartialEq)]
struct Foo {
    foo: String,
    bar: usize,
}

fn main() -> Result<(), Box<Error>> {
    let input = r#"{"foo":"hello, world!","bar":42}"#;
    let bytes = input.as_bytes();
    let reader = Cursor::new(bytes);
    let mut reader = Tap::new(reader);
    
    let foo: Foo = match serde_json::from_reader(&mut reader) {
        Ok(foo) => foo,
        Err(e) => {
            eprintln!("Error serializing Foo from input: '{}'\n error was: {}",
                      String::from_utf8_lossy(&reader.bytes),
                      e.description());
            return Err(());
        }
    };
    
    assert_eq!(
        foo,
        Foo {
            foo: "hello, world!".to_string(),
            bar: 42
        }
    );
    assert_eq!(reader.bytes, bytes);
    Ok(())
}

No runtime deps