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

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

#1891 in Encoding

Download history 99/week @ 2023-12-15 68/week @ 2023-12-22 30/week @ 2023-12-29 75/week @ 2024-01-05 103/week @ 2024-01-12 77/week @ 2024-01-19 81/week @ 2024-01-26 93/week @ 2024-02-02 107/week @ 2024-02-09 198/week @ 2024-02-16 100/week @ 2024-02-23 99/week @ 2024-03-01 189/week @ 2024-03-08 106/week @ 2024-03-15 133/week @ 2024-03-22 181/week @ 2024-03-29

618 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