1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.

use core::cmp;
use core::str;

use std::error::Error;
use std::io;

use crate::{BasedBufTranche, BufTranche, UnexpectedEndError};

impl io::Read for BufTranche<'_> {
    fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
        let slice = self
            .take_front(cmp::max(self.len(), buf.len()))
            .unwrap()
            .as_slice();
        let len = slice.len();
        if len == 1 {
            buf[0] = slice[0];
        } else {
            buf[..len].copy_from_slice(slice);
        }
        Ok(len)
    }
}

impl io::Read for BasedBufTranche<'_> {
    fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
        self.inner.read(buf)
    }
}

impl io::BufRead for BufTranche<'_> {
    fn fill_buf(&mut self) -> io::Result<&[u8]> {
        Ok(self.as_slice())
    }

    fn consume(&mut self, len: usize) {
        if let Err(err) = self.take_front(len) {
            panic!("{}", err);
        }
    }
}

impl io::BufRead for BasedBufTranche<'_> {
    fn fill_buf(&mut self) -> io::Result<&[u8]> {
        self.inner.fill_buf()
    }

    fn consume(&mut self, len: usize) {
        self.inner.consume(len)
    }
}

impl From<UnexpectedEndError> for io::Error {
    fn from(error: UnexpectedEndError) -> Self {
        io::Error::new(io::ErrorKind::UnexpectedEof, error)
    }
}

impl Error for UnexpectedEndError {
    fn description(&self) -> &str {
        "unexpected end"
    }
}