Struct serde_gff::de::Deserializer
source · Expand description
Структура для поддержки чтения GFF файлов в экосистеме serde
Implementations
sourceimpl<R: Read + Seek> Deserializer<R>
impl<R: Read + Seek> Deserializer<R>
sourcepub fn new(reader: R) -> Result<Self>
pub fn new(reader: R) -> Result<Self>
Создает десериализатор для чтения GFF файла из указанного источника данных с использованием
кодировки UTF-8
для декодирования строк и генерацией ошибки в случае, если декодировать
набор байт, как строку в этой кодировке, не удалось.
Параметры
reader
: Источник данных для чтения файла
Ошибки
В случае, если не удалось прочитать заголовок GFF файла – например, он слишком короткий
sourcepub fn with_encoding(
reader: R,
encoding: EncodingRef,
trap: DecoderTrap
) -> Result<Self>
pub fn with_encoding(
reader: R,
encoding: EncodingRef,
trap: DecoderTrap
) -> Result<Self>
Создает десериализатор для чтения GFF файла из указанного источника данных с использованием указанной кодировки для декодирования строк.
Параметры
reader
: Источник данных для чтения файлаencoding
: Кодировка для декодирования символов в строкахtrap
: Способ обработки символов в строках, которые не удалось декодировать с использованием выбранной кодировки
Ошибки
В случае, если не удалось прочитать заголовок GFF файла – например, он слишком короткий
Trait Implementations
sourceimpl<'de, 'a, R: Read + Seek> Deserializer<'de> for &'a mut Deserializer<R>
impl<'de, 'a, R: Read + Seek> Deserializer<'de> for &'a mut Deserializer<R>
sourcefn deserialize_option<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_option<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Всегда разбирает любое значение, как Some(...)
, формат не умеет хранить признак
отсутствия значения. None
в опциональные поля будет записываться только потому,
что при десериализации данное поле не будет найдено
sourcefn deserialize_unit<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_unit<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Десериализует любую GFF структуру в unit
, в остальных случаях выдает ошибку
sourcefn deserialize_identifier<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_identifier<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Данный метод вызывается при необходимости десериализовать идентификатор перечисления
sourcefn deserialize_unit_struct<V>(
self,
_name: &'static str,
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_unit_struct<V>(
self,
_name: &'static str,
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
Десериализует любую GFF структуру в unit
, в остальных случаях выдает ошибку
sourcefn deserialize_newtype_struct<V>(
self,
_name: &'static str,
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_newtype_struct<V>(
self,
_name: &'static str,
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
Разбирает в newtype структуру нижележащее значение
type Error = Error
type Error = Error
sourcefn is_human_readable(&self) -> bool
fn is_human_readable(&self) -> bool
Deserialize
implementations should expect to
deserialize their human-readable form. Read moresourcefn deserialize_i8<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_i8<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting an i8
value.sourcefn deserialize_u8<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_u8<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a u8
value.sourcefn deserialize_i16<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_i16<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting an i16
value.sourcefn deserialize_u16<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_u16<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a u16
value.sourcefn deserialize_i32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_i32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting an i32
value.sourcefn deserialize_u32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_u32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a u32
value.sourcefn deserialize_i64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_i64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting an i64
value.sourcefn deserialize_u64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_u64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a u64
value.sourcefn deserialize_f32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_f32<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a f32
value.sourcefn deserialize_f64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_f64<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a f64
value.sourcefn deserialize_bool<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_bool<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a bool
value.sourcefn deserialize_char<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_char<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a char
value.sourcefn deserialize_str<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_str<V>(self, visitor: V) -> Result<V::Value>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 moresourcefn deserialize_string<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_string<V>(self, visitor: V) -> Result<V::Value>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 moresourcefn deserialize_bytes<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_bytes<V>(self, visitor: V) -> Result<V::Value>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 moresourcefn deserialize_byte_buf<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_byte_buf<V>(self, visitor: V) -> Result<V::Value>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 moresourcefn deserialize_any<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_any<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserializer
to figure out how to drive the visitor based
on what data type is in the input. Read moresourcefn deserialize_ignored_any<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_ignored_any<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type needs to deserialize a value whose type
doesn’t matter because it is ignored. Read moresourcefn deserialize_map<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_map<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a map of key-value pairs.sourcefn deserialize_seq<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_seq<V>(self, visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a sequence of values.sourcefn deserialize_tuple<V>(self, len: usize, _visitor: V) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_tuple<V>(self, len: usize, _visitor: V) -> Result<V::Value>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. Read moresourcefn deserialize_tuple_struct<V>(
self,
name: &'static str,
len: usize,
_visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_tuple_struct<V>(
self,
name: &'static str,
len: usize,
_visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a tuple struct with a
particular name and number of fields. Read moresourcefn deserialize_struct<V>(
self,
_name: &'static str,
_fields: &'static [&'static str],
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_struct<V>(
self,
_name: &'static str,
_fields: &'static [&'static str],
visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting a struct with a particular
name and fields. Read moresourcefn deserialize_enum<V>(
self,
name: &'static str,
variants: &'static [&'static str],
_visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
fn deserialize_enum<V>(
self,
name: &'static str,
variants: &'static [&'static str],
_visitor: V
) -> Result<V::Value>where
V: Visitor<'de>,
Deserialize
type is expecting an enum value with a
particular name and possible variants. Read moresourceimpl<'de, 'a, R: Read + Seek> MapAccess<'de> for &'a mut Deserializer<R>
impl<'de, 'a, R: Read + Seek> MapAccess<'de> for &'a mut Deserializer<R>
type Error = Error
type Error = Error
sourcefn next_key_seed<K>(&mut self, seed: K) -> Result<Option<K::Value>>where
K: DeserializeSeed<'de>,
fn next_key_seed<K>(&mut self, seed: K) -> Result<Option<K::Value>>where
K: DeserializeSeed<'de>,
Ok(Some(key))
for the next key in the map, or Ok(None)
if there are no more remaining entries. Read moresourcefn next_value_seed<V>(&mut self, seed: V) -> Result<V::Value>where
V: DeserializeSeed<'de>,
fn next_value_seed<V>(&mut self, seed: V) -> Result<V::Value>where
V: DeserializeSeed<'de>,
Ok(value)
for the next value in the map. Read moresourcefn next_entry_seed<K, V>(
&mut self,
kseed: K,
vseed: V
) -> Result<Option<(<K as DeserializeSeed<'de>>::Value, <V as DeserializeSeed<'de>>::Value)>, Self::Error>where
K: DeserializeSeed<'de>,
V: DeserializeSeed<'de>,
fn next_entry_seed<K, V>(
&mut self,
kseed: K,
vseed: V
) -> Result<Option<(<K as DeserializeSeed<'de>>::Value, <V as DeserializeSeed<'de>>::Value)>, Self::Error>where
K: DeserializeSeed<'de>,
V: DeserializeSeed<'de>,
Ok(Some((key, value)))
for the next (key-value) pair in
the map, or Ok(None)
if there are no more remaining items. Read moresourcefn next_key<K>(&mut self) -> Result<Option<K>, Self::Error>where
K: Deserialize<'de>,
fn next_key<K>(&mut self) -> Result<Option<K>, Self::Error>where
K: Deserialize<'de>,
Ok(Some(key))
for the next key in the map, or Ok(None)
if there are no more remaining entries. Read moresourcefn next_value<V>(&mut self) -> Result<V, Self::Error>where
V: Deserialize<'de>,
fn next_value<V>(&mut self) -> Result<V, Self::Error>where
V: Deserialize<'de>,
Ok(value)
for the next value in the map. Read moresourcefn next_entry<K, V>(&mut self) -> Result<Option<(K, V)>, Self::Error>where
K: Deserialize<'de>,
V: Deserialize<'de>,
fn next_entry<K, V>(&mut self) -> Result<Option<(K, V)>, Self::Error>where
K: Deserialize<'de>,
V: Deserialize<'de>,
Ok(Some((key, value)))
for the next (key-value) pair in
the map, or Ok(None)
if there are no more remaining items. Read moresourceimpl<'de, 'a, R: Read + Seek> SeqAccess<'de> for &'a mut Deserializer<R>
impl<'de, 'a, R: Read + Seek> SeqAccess<'de> for &'a mut Deserializer<R>
type Error = Error
type Error = Error
sourcefn next_element_seed<T>(&mut self, seed: T) -> Result<Option<T::Value>>where
T: DeserializeSeed<'de>,
fn next_element_seed<T>(&mut self, seed: T) -> Result<Option<T::Value>>where
T: DeserializeSeed<'de>,
Ok(Some(value))
for the next value in the sequence, or
Ok(None)
if there are no more remaining items. Read moresourcefn next_element<T>(&mut self) -> Result<Option<T>, Self::Error>where
T: Deserialize<'de>,
fn next_element<T>(&mut self) -> Result<Option<T>, Self::Error>where
T: Deserialize<'de>,
Ok(Some(value))
for the next value in the sequence, or
Ok(None)
if there are no more remaining items. Read more