pub struct Reader<B> { /* private fields */ }
Expand description
Reader
s allow access to data stored in a Flexbuffer.
Each reader represents a single address in the buffer so data is read lazily. Start a reader
by calling get_root
on your flexbuffer &[u8]
.
- The
get_T
methods return aResult<T, Error>
. They return an OK value if and only if the flexbuffer type matchesT
. This is analogous to the behavior of Rust’s json library, though with Result instead of Option. - The
as_T
methods will try their best to return to a value of typeT
(by casting or even parsing a string if necessary) but ultimately returnsT::default
if it fails. This behavior is analogous to that of flexbuffers C++.
Implementations§
Source§impl<B: Buffer> Reader<B>
impl<B: Buffer> Reader<B>
Sourcepub fn get_root(buffer: B) -> Result<Self, Error>
pub fn get_root(buffer: B) -> Result<Self, Error>
Parses the flexbuffer from the given buffer. Assumes the flexbuffer root is the last byte of the buffer.
Sourcepub fn buffer(&self) -> B
pub fn buffer(&self) -> B
Convenience function to get the underlying buffer. By using shallow_copy
, this preserves
the lifetime that the underlying buffer has.
Sourcepub fn flexbuffer_type(&self) -> FlexBufferType
pub fn flexbuffer_type(&self) -> FlexBufferType
Returns the FlexBufferType of this Reader.
Sourcepub fn length(&self) -> usize
pub fn length(&self) -> usize
Returns the length of the Flexbuffer. If the type has no length, or if an error occurs, 0 is returned.
Sourcepub fn is_aligned(&self) -> bool
pub fn is_aligned(&self) -> bool
Returns true if the flexbuffer is aligned to 8 bytes. This guarantees, for valid
flexbuffers, that the data is correctly aligned in memory and slices can be read directly
e.g. with get_f64s
or get_i16s
.
pub fn as_vector(&self) -> VectorReader<B>
pub fn as_map(&self) -> MapReader<B>
Sourcepub fn get_slice<T: ReadLE>(&self) -> Result<&[T], Error>
👎Deprecated since 0.3.0: This function is unsafe - if this functionality is needed use Reader::buffer::align_to
pub fn get_slice<T: ReadLE>(&self) -> Result<&[T], Error>
Reader::buffer::align_to
Directly reads a slice of type T
where T
is one of u8,u16,u32,u64,i8,i16,i32,i64,f32,f64
.
Returns Err if the type, bitwidth, or memory alignment does not match. Since the bitwidth is
dynamic, its better to use a VectorReader unless you know your data and performance is critical.
Sourcepub fn get_bool(&self) -> Result<bool, Error>
pub fn get_bool(&self) -> Result<bool, Error>
Returns the value of the reader if it is a boolean. Otherwise Returns error.
Sourcepub fn get_key(&self) -> Result<B::BufferString, Error>
pub fn get_key(&self) -> Result<B::BufferString, Error>
Retrieves the string value up until the first \0
character.
pub fn get_blob(&self) -> Result<Blob<B>, Error>
pub fn as_blob(&self) -> Blob<B>
Sourcepub fn get_str(&self) -> Result<B::BufferString, Error>
pub fn get_str(&self) -> Result<B::BufferString, Error>
Retrieves str pointer, errors if invalid UTF-8, or the provided index is out of bounds.
pub fn get_map(&self) -> Result<MapReader<B>, Error>
Sourcepub fn get_u64(&self) -> Result<u64, Error>
pub fn get_u64(&self) -> Result<u64, Error>
Tries to read a FlexBufferType::UInt. Returns Err if the type is not a UInt or if the address is out of bounds.
Sourcepub fn get_i64(&self) -> Result<i64, Error>
pub fn get_i64(&self) -> Result<i64, Error>
Tries to read a FlexBufferType::Int. Returns Err if the type is not a UInt or if the address is out of bounds.
Sourcepub fn get_f64(&self) -> Result<f64, Error>
pub fn get_f64(&self) -> Result<f64, Error>
Tries to read a FlexBufferType::Float. Returns Err if the type is not a UInt, if the address is out of bounds, or if its a f16 or f8 (not currently supported).
pub fn as_bool(&self) -> bool
Sourcepub fn as_u64(&self) -> u64
pub fn as_u64(&self) -> u64
Returns a u64, casting if necessary. For Maps and Vectors, their length is returned. If anything fails, 0 is returned.
pub fn as_u32(&self) -> u32
pub fn as_u16(&self) -> u16
pub fn as_u8(&self) -> u8
Sourcepub fn as_i64(&self) -> i64
pub fn as_i64(&self) -> i64
Returns an i64, casting if necessary. For Maps and Vectors, their length is returned. If anything fails, 0 is returned.
pub fn as_i32(&self) -> i32
pub fn as_i16(&self) -> i16
pub fn as_i8(&self) -> i8
Sourcepub fn as_f64(&self) -> f64
pub fn as_f64(&self) -> f64
Returns an f64, casting if necessary. For Maps and Vectors, their length is returned. If anything fails, 0 is returned.
pub fn as_f32(&self) -> f32
Sourcepub fn as_str(&self) -> B::BufferString
pub fn as_str(&self) -> B::BufferString
Returns empty string if you’re not trying to read a string.
pub fn get_vector(&self) -> Result<VectorReader<B>, Error>
Trait Implementations§
Source§impl<'de> Deserializer<'de> for Reader<&'de [u8]>
impl<'de> Deserializer<'de> for Reader<&'de [u8]>
Source§type Error = DeserializationError
type Error = DeserializationError
Source§fn is_human_readable(&self) -> bool
fn is_human_readable(&self) -> bool
Deserialize
implementations should expect to
deserialize their human-readable form. Read moreSource§fn deserialize_any<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_any<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserializer
to figure out how to drive the visitor based
on what data type is in the input. Read moreSource§fn deserialize_bool<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_bool<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a bool
value.Source§fn deserialize_i8<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_i8<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an i8
value.Source§fn deserialize_i16<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_i16<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an i16
value.Source§fn deserialize_i32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_i32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an i32
value.Source§fn deserialize_i64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_i64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an i64
value.Source§fn deserialize_u8<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_u8<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a u8
value.Source§fn deserialize_u16<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_u16<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a u16
value.Source§fn deserialize_u32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_u32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a u32
value.Source§fn deserialize_u64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_u64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a u64
value.Source§fn deserialize_f32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_f32<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a f32
value.Source§fn deserialize_f64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_f64<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a f64
value.Source§fn deserialize_str<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_str<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a string value and does
not benefit from taking ownership of buffered data owned by the
Deserializer
. Read moreSource§fn deserialize_unit<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_unit<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a unit value.Source§fn deserialize_unit_struct<V>(
self,
name: &'static str,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_unit_struct<V>(
self,
name: &'static str,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a unit struct with a
particular name.Source§fn deserialize_bytes<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_bytes<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a byte array and does not
benefit from taking ownership of buffered data owned by the
Deserializer
. Read moreSource§fn deserialize_ignored_any<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_ignored_any<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type needs to deserialize a value whose type
doesn’t matter because it is ignored. Read moreSource§fn deserialize_map<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_map<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a map of key-value pairs.Source§fn deserialize_identifier<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_identifier<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting the name of a struct
field or the discriminant of an enum variant.Source§fn deserialize_struct<V>(
self,
name: &'static str,
fields: &'static [&'static str],
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_struct<V>(
self,
name: &'static str,
fields: &'static [&'static str],
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a struct with a particular
name and fields.Source§fn deserialize_tuple<V>(
self,
len: usize,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_tuple<V>(
self,
len: usize,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a sequence of values and
knows how many values there are without looking at the serialized data.Source§fn deserialize_tuple_struct<V>(
self,
name: &'static str,
len: usize,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_tuple_struct<V>(
self,
name: &'static str,
len: usize,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a tuple struct with a
particular name and number of fields.Source§fn deserialize_seq<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_seq<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a sequence of values.Source§fn deserialize_string<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
fn deserialize_string<V>(
self,
visitor: V,
) -> Result<V::Value, <Self as Deserializer<'de>>::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a string value and would
benefit from taking ownership of buffered data owned by the
Deserializer
. Read moreSource§fn deserialize_char<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_char<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a char
value.Source§fn deserialize_byte_buf<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_byte_buf<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a byte array and would
benefit from taking ownership of buffered data owned by the
Deserializer
. Read moreSource§fn deserialize_option<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_option<V>(self, visitor: V) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an optional value. Read moreSource§fn deserialize_newtype_struct<V>(
self,
_name: &'static str,
visitor: V,
) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_newtype_struct<V>(
self,
_name: &'static str,
visitor: V,
) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserialize
type is expecting a newtype struct with a
particular name.Source§fn deserialize_enum<V>(
self,
_name: &'static str,
_variants: &'static [&'static str],
visitor: V,
) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
fn deserialize_enum<V>(
self,
_name: &'static str,
_variants: &'static [&'static str],
visitor: V,
) -> Result<V::Value, Self::Error>where
V: Visitor<'de>,
Deserialize
type is expecting an enum value with a
particular name and possible variants.Source§impl<'de> VariantAccess<'de> for Reader<&'de [u8]>
impl<'de> VariantAccess<'de> for Reader<&'de [u8]>
Source§type Error = DeserializationError
type Error = DeserializationError
EnumAccess
.