Struct minicbor_io::Reader
source · pub struct Reader<R> { /* private fields */ }
Expand description
Wraps a std::io::Read
and reads length-delimited CBOR values.
Implementations§
source§impl<R> Reader<R>
impl<R> Reader<R>
sourcepub fn with_buffer(reader: R, buffer: Vec<u8>) -> Self
pub fn with_buffer(reader: R, buffer: Vec<u8>) -> Self
Create a new reader with a max. buffer size of 512KiB.
sourcepub fn set_max_len(&mut self, val: u32)
pub fn set_max_len(&mut self, val: u32)
Set the max. buffer size in bytes.
If length values greater than this are decoded, an
Error::InvalidLen
will be returned.
sourcepub fn reader_mut(&mut self) -> &mut R
pub fn reader_mut(&mut self) -> &mut R
Get a mutable reference to the inner reader.
sourcepub fn into_parts(self) -> (R, Vec<u8>)
pub fn into_parts(self) -> (R, Vec<u8>)
Deconstruct this reader into the inner reader and the buffer.
source§impl<R: Read> Reader<R>
impl<R: Read> Reader<R>
sourcepub fn read<'a, T: Decode<'a, ()>>(&'a mut self) -> Result<Option<T>, Error>
pub fn read<'a, T: Decode<'a, ()>>(&'a mut self) -> Result<Option<T>, Error>
Read the next CBOR value and decode it.
The value is assumed to be preceded by a u32
(4 bytes in network
byte order) denoting the length of the CBOR item in bytes.
Reading 0 bytes when decoding the length prefix results in Ok(None)
,
otherwise either Some
value or an error is returned.
Trait Implementations§
Auto Trait Implementations§
impl<R> Freeze for Reader<R>where
R: Freeze,
impl<R> RefUnwindSafe for Reader<R>where
R: RefUnwindSafe,
impl<R> Send for Reader<R>where
R: Send,
impl<R> Sync for Reader<R>where
R: Sync,
impl<R> Unpin for Reader<R>where
R: Unpin,
impl<R> UnwindSafe for Reader<R>where
R: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more