pub struct Serializer;
Expand description
Serializer whose output is a Value
.
This is the serializer that backs serde_json::to_value
.
Unlike the main serde_json serializer which goes from some serializable
value of type T
to JSON text, this one goes from T
to
serde_json::Value
.
The to_value
function is implementable as:
use serde::Serialize;
use serde_json::{Error, Value};
pub fn to_value<T>(input: T) -> Result<Value, Error>
where
T: Serialize,
{
input.serialize(serde_json::value::Serializer)
}
Trait Implementations§
Source§impl Serializer for Serializer
impl Serializer for Serializer
Source§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.Source§type SerializeSeq = SerializeVec
type SerializeSeq = SerializeVec
Type returned from
serialize_seq
for serializing the content of the
sequence.Source§type SerializeTuple = SerializeVec
type SerializeTuple = SerializeVec
Type returned from
serialize_tuple
for serializing the content of
the tuple.Source§type SerializeTupleStruct = SerializeVec
type SerializeTupleStruct = SerializeVec
Type returned from
serialize_tuple_struct
for serializing the
content of the tuple struct.Source§type SerializeTupleVariant = SerializeTupleVariant
type SerializeTupleVariant = SerializeTupleVariant
Type returned from
serialize_tuple_variant
for serializing the
content of the tuple variant.Source§type SerializeMap = SerializeMap
type SerializeMap = SerializeMap
Type returned from
serialize_map
for serializing the content of the
map.Source§type SerializeStruct = SerializeMap
type SerializeStruct = SerializeMap
Type returned from
serialize_struct
for serializing the content of
the struct.Source§type SerializeStructVariant = SerializeStructVariant
type SerializeStructVariant = SerializeStructVariant
Type returned from
serialize_struct_variant
for serializing the
content of the struct variant.Source§fn serialize_bytes(self, value: &[u8]) -> Result<Value>
fn serialize_bytes(self, value: &[u8]) -> Result<Value>
Serialize a chunk of raw byte data. Read more
Source§fn serialize_unit_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
) -> Result<Value>
fn serialize_unit_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, ) -> Result<Value>
Source§fn serialize_newtype_struct<T>(
self,
_name: &'static str,
value: &T,
) -> Result<Value>
fn serialize_newtype_struct<T>( self, _name: &'static str, value: &T, ) -> Result<Value>
Serialize a newtype struct like
struct Millimeters(u8)
. Read moreSource§fn serialize_newtype_variant<T>(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
value: &T,
) -> Result<Value>
fn serialize_newtype_variant<T>( self, _name: &'static str, _variant_index: u32, variant: &'static str, value: &T, ) -> Result<Value>
Source§fn serialize_seq(self, len: Option<usize>) -> Result<Self::SerializeSeq>
fn serialize_seq(self, len: Option<usize>) -> Result<Self::SerializeSeq>
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 moreSource§fn serialize_tuple(self, len: usize) -> Result<Self::SerializeTuple>
fn serialize_tuple(self, len: usize) -> Result<Self::SerializeTuple>
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 moreSource§fn serialize_tuple_struct(
self,
_name: &'static str,
len: usize,
) -> Result<Self::SerializeTupleStruct>
fn serialize_tuple_struct( self, _name: &'static str, len: usize, ) -> Result<Self::SerializeTupleStruct>
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 moreSource§fn serialize_tuple_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
len: usize,
) -> Result<Self::SerializeTupleVariant>
fn serialize_tuple_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeTupleVariant>
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 moreSource§fn serialize_map(self, _len: Option<usize>) -> Result<Self::SerializeMap>
fn serialize_map(self, _len: Option<usize>) -> Result<Self::SerializeMap>
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 moreSource§fn serialize_struct(
self,
name: &'static str,
len: usize,
) -> Result<Self::SerializeStruct>
fn serialize_struct( self, name: &'static str, len: usize, ) -> Result<Self::SerializeStruct>
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 moreSource§fn serialize_struct_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
_len: usize,
) -> Result<Self::SerializeStructVariant>
fn serialize_struct_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, _len: usize, ) -> Result<Self::SerializeStructVariant>
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 collect_str<T>(self, value: &T) -> Result<Value>
fn collect_str<T>(self, value: &T) -> Result<Value>
Serialize a string produced by an implementation of
Display
. 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 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 Serializer
impl RefUnwindSafe for Serializer
impl Send for Serializer
impl Sync for Serializer
impl Unpin for Serializer
impl UnwindSafe for Serializer
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
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 0 bytes