Struct ValueSerializer
#[non_exhaustive]pub struct ValueSerializer {}
Available on crate feature
dep_toml_edit
only.Expand description
Serialization for TOML values.
This structure implements serialization support for TOML to serialize an arbitrary type to TOML. Note that the TOML format does not support all datatypes in Rust, such as enums, tuples, and tuple structs. These types will generate an error when serialized.
Currently a serializer always writes its output to an in-memory String
,
which is passed in when creating the serializer itself.
§Examples
use serde::Serialize;
#[derive(Serialize)]
struct Config {
database: Database,
}
#[derive(Serialize)]
struct Database {
ip: String,
port: Vec<u16>,
connection_max: u32,
enabled: bool,
}
let config = Config {
database: Database {
ip: "192.168.1.1".to_string(),
port: vec![8001, 8002, 8003],
connection_max: 5000,
enabled: false,
},
};
let value = serde::Serialize::serialize(
&config,
toml_edit::ser::ValueSerializer::new()
).unwrap();
println!("{}", value)
Implementations§
§impl ValueSerializer
impl ValueSerializer
pub fn new() -> ValueSerializer
pub fn new() -> ValueSerializer
Creates a new serializer generate a TOML document.
Trait Implementations§
§impl Default for ValueSerializer
impl Default for ValueSerializer
§fn default() -> ValueSerializer
fn default() -> ValueSerializer
Returns the “default value” for a type. Read more
§impl Serializer for ValueSerializer
impl Serializer for ValueSerializer
§type Ok = Value
type Ok = Value
The output type produced by this
Serializer
during successful
serialization. Most serializers that produce text or binary output
should set Ok = ()
and serialize into an io::Write
or buffer
contained within the Serializer
instance. Serializers that build
in-memory data structures may be simplified by using Ok
to propagate
the data structure around.§type SerializeSeq = SerializeValueArray
type SerializeSeq = SerializeValueArray
Type returned from
serialize_seq
for serializing the content of the
sequence.§type SerializeTuple = SerializeValueArray
type SerializeTuple = SerializeValueArray
Type returned from
serialize_tuple
for serializing the content of
the tuple.§type SerializeTupleStruct = SerializeValueArray
type SerializeTupleStruct = SerializeValueArray
Type returned from
serialize_tuple_struct
for serializing the
content of the tuple struct.§type SerializeTupleVariant = SerializeVariant<SerializeValueArray>
type SerializeTupleVariant = SerializeVariant<SerializeValueArray>
Type returned from
serialize_tuple_variant
for serializing the
content of the tuple variant.§type SerializeMap = SerializeMap
type SerializeMap = SerializeMap
Type returned from
serialize_map
for serializing the content of the
map.§type SerializeStruct = SerializeMap
type SerializeStruct = SerializeMap
Type returned from
serialize_struct
for serializing the content of
the struct.§type SerializeStructVariant = SerializeVariant<SerializeMap>
type SerializeStructVariant = SerializeVariant<SerializeMap>
Type returned from
serialize_struct_variant
for serializing the
content of the struct variant.§fn serialize_bool(
self,
v: bool,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_bool( self, v: bool, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
bool
value. Read more§fn serialize_i8(
self,
v: i8,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_i8( self, v: i8, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
i8
value. Read more§fn serialize_i16(
self,
v: i16,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_i16( self, v: i16, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
i16
value. Read more§fn serialize_i32(
self,
v: i32,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_i32( self, v: i32, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
i32
value. Read more§fn serialize_i64(
self,
v: i64,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_i64( self, v: i64, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
i64
value. Read more§fn serialize_u8(
self,
v: u8,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_u8( self, v: u8, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
u8
value. Read more§fn serialize_u16(
self,
v: u16,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_u16( self, v: u16, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
u16
value. Read more§fn serialize_u32(
self,
v: u32,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_u32( self, v: u32, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
u32
value. Read more§fn serialize_u64(
self,
v: u64,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_u64( self, v: u64, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
u64
value. Read more§fn serialize_f32(
self,
v: f32,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_f32( self, v: f32, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
f32
value. Read more§fn serialize_f64(
self,
v: f64,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_f64( self, v: f64, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize an
f64
value. Read more§fn serialize_char(
self,
v: char,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_char( self, v: char, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a character. Read more
§fn serialize_str(
self,
v: &str,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_str( self, v: &str, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
&str
. Read more§fn serialize_bytes(
self,
value: &[u8],
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_bytes( self, value: &[u8], ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a chunk of raw byte data. Read more
§fn serialize_none(
self,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_none( self, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
§fn serialize_some<T>(
self,
value: &T,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_some<T>( self, value: &T, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
§fn serialize_unit(
self,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_unit( self, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a
()
value. Read more§fn serialize_unit_struct(
self,
name: &'static str,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_unit_struct( self, name: &'static str, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
§fn serialize_unit_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_unit_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
§fn serialize_newtype_struct<T>(
self,
_name: &'static str,
value: &T,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_newtype_struct<T>( self, _name: &'static str, value: &T, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
Serialize a newtype struct like
struct Millimeters(u8)
. Read more§fn serialize_newtype_variant<T>(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
value: &T,
) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_newtype_variant<T>( self, _name: &'static str, _variant_index: u32, variant: &'static str, value: &T, ) -> Result<<ValueSerializer as Serializer>::Ok, <ValueSerializer as Serializer>::Error> ⓘ
§fn serialize_seq(
self,
len: Option<usize>,
) -> Result<<ValueSerializer as Serializer>::SerializeSeq, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_seq( self, len: Option<usize>, ) -> Result<<ValueSerializer as Serializer>::SerializeSeq, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a variably sized sequence. This call must be
followed by zero or more calls to
serialize_element
, then a call to
end
. Read more§fn serialize_tuple(
self,
len: usize,
) -> Result<<ValueSerializer as Serializer>::SerializeTuple, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_tuple( self, len: usize, ) -> Result<<ValueSerializer as Serializer>::SerializeTuple, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a statically sized sequence whose length will be
known at deserialization time without looking at the serialized data.
This call must be followed by zero or more calls to
serialize_element
,
then a call to end
. Read more§fn serialize_tuple_struct(
self,
_name: &'static str,
len: usize,
) -> Result<<ValueSerializer as Serializer>::SerializeTupleStruct, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_tuple_struct( self, _name: &'static str, len: usize, ) -> Result<<ValueSerializer as Serializer>::SerializeTupleStruct, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a tuple struct like
struct Rgb(u8, u8, u8)
. This
call must be followed by zero or more calls to serialize_field
, then a
call to end
. Read more§fn serialize_tuple_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
len: usize,
) -> Result<<ValueSerializer as Serializer>::SerializeTupleVariant, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_tuple_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<<ValueSerializer as Serializer>::SerializeTupleVariant, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a tuple variant like
E::T
in enum E { T(u8, u8) }
. This call must be followed by zero or more calls to
serialize_field
, then a call to end
. Read more§fn serialize_map(
self,
len: Option<usize>,
) -> Result<<ValueSerializer as Serializer>::SerializeMap, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_map( self, len: Option<usize>, ) -> Result<<ValueSerializer as Serializer>::SerializeMap, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a map. This call must be followed by zero or more
calls to
serialize_key
and serialize_value
, then a call to end
. Read more§fn serialize_struct(
self,
name: &'static str,
len: usize,
) -> Result<<ValueSerializer as Serializer>::SerializeStruct, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_struct( self, name: &'static str, len: usize, ) -> Result<<ValueSerializer as Serializer>::SerializeStruct, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a struct like
struct Rgb { r: u8, g: u8, b: u8 }
.
This call must be followed by zero or more calls to serialize_field
,
then a call to end
. Read more§fn serialize_struct_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
len: usize,
) -> Result<<ValueSerializer as Serializer>::SerializeStructVariant, <ValueSerializer as Serializer>::Error> ⓘ
fn serialize_struct_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<<ValueSerializer as Serializer>::SerializeStructVariant, <ValueSerializer as Serializer>::Error> ⓘ
Begin to serialize a struct variant like
E::S
in enum E { S { r: u8, g: u8, b: u8 } }
. This call must be followed by zero or more calls to
serialize_field
, then a call to end
. Read moreSource§fn serialize_i128(self, v: i128) -> Result<Self::Ok, Self::Error> ⓘ
fn serialize_i128(self, v: i128) -> Result<Self::Ok, Self::Error> ⓘ
Serialize an
i128
value. Read moreSource§fn serialize_u128(self, v: u128) -> Result<Self::Ok, Self::Error> ⓘ
fn serialize_u128(self, v: u128) -> Result<Self::Ok, Self::Error> ⓘ
Serialize a
u128
value. Read moreSource§fn collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error> ⓘ
fn collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error> ⓘ
Collect an iterator as a sequence. Read more
Source§fn collect_map<K, V, I>(self, iter: I) -> Result<Self::Ok, Self::Error> ⓘ
fn collect_map<K, V, I>(self, iter: I) -> Result<Self::Ok, Self::Error> ⓘ
Collect an iterator as a map. Read more
Source§fn collect_str<T>(self, value: &T) -> Result<Self::Ok, Self::Error> ⓘ
fn collect_str<T>(self, value: &T) -> Result<Self::Ok, Self::Error> ⓘ
Serialize a string produced by an implementation of
Display
. Read moreSource§fn is_human_readable(&self) -> bool
fn is_human_readable(&self) -> bool
Determine whether
Serialize
implementations should serialize in
human-readable form. Read moreAuto Trait Implementations§
impl Freeze for ValueSerializer
impl RefUnwindSafe for ValueSerializer
impl Send for ValueSerializer
impl Sync for ValueSerializer
impl Unpin for ValueSerializer
impl UnwindSafe for ValueSerializer
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
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
The alignment of this type in bytes.
Source§fn byte_align(&self) -> usize
fn byte_align(&self) -> usize
Returns the alignment of this type in bytes.
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
Returns a deterministic hash of the
TypeId
of Self
using a custom hasher.Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Know whether dropping values of this type matters, in compile-time.
Source§fn mem_align_of<T>() -> usize
fn mem_align_of<T>() -> usize
Returns the minimum alignment of the type in bytes. Read more
Source§fn mem_align_of_val(&self) -> usize
fn mem_align_of_val(&self) -> usize
Returns the alignment of the pointed-to value in bytes. Read more
Source§fn mem_size_of<T>() -> usize
fn mem_size_of<T>() -> usize
Returns the size of a type in bytes. Read more
Source§fn mem_size_of_val(&self) -> usize
fn mem_size_of_val(&self) -> usize
Returns the size of the pointed-to value in bytes. Read more
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
Returns
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
Forgets about
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
Available on crate feature
unsafe_layout
only.Returns the value of type
T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
Available on crate feature
unsafe_layout
only.Returns the value of type
T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
Available on crate feature
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more