pub struct ContentSerializer<'w, 'i, W: Write> {
pub writer: &'w mut W,
pub level: QuoteLevel,
pub(super) indent: Indent<'i>,
pub write_indent: bool,
pub expand_empty_elements: bool,
}
Expand description
A serializer used to serialize content of an element. It does not write
surrounding tags. Unlike the ElementSerializer
, this serializer serializes
enums using variant names as tag names, i. e. as <variant>...</variant>
This serializer does the following:
- numbers converted to a decimal representation and serialized as naked strings;
- booleans serialized ether as
"true"
or"false"
; - strings and characters are serialized as naked strings;
None
does not write anything;Some
and newtypes are serialized as an inner type using the same serializer;- units (
()
) and unit structs does not write anything; - sequences, tuples and tuple structs are serialized without delimiters.
[1, 2, 3]
would be serialized as123
(if not using indent); - structs and maps are not supported (
DeError::Unsupported
is returned); - enums:
- unit variants are serialized as self-closed
<variant/>
; - newtype variants are serialized as inner value wrapped in
<variant>...</variant>
; - tuple variants are serialized as sequences where each element is wrapped
in
<variant>...</variant>
; - struct variants are serialized as a sequence of fields wrapped in
<variant>...</variant>
. Each field is serialized recursively using eitherElementSerializer
,ContentSerializer
($value
fields), orSimpleTypeSerializer
($text
fields). In particular, the empty struct is serialized as<variant/>
;
- unit variants are serialized as self-closed
Usage of empty tags depends on the Self::expand_empty_elements
setting.
The difference between this serializer and SimpleTypeSerializer
is in how
sequences and maps are serialized. Unlike SimpleTypeSerializer
it supports
any types in sequences and serializes them as list of elements, but that has
drawbacks. Sequence of primitives would be serialized without delimiters and
it will be impossible to distinguish between them. Even worse, when serializing
with indent, sequence of strings become one big string with additional content
and it would be impossible to distinguish between content of the original
strings and inserted indent characters.
Fields§
§writer: &'w mut W
§level: QuoteLevel
Defines which XML characters need to be escaped in text content
indent: Indent<'i>
Current indentation level. Note, that Indent::None
means that there is
no indentation at all, but write_indent == false
means only, that indent
writing is disabled in this instantiation of ContentSerializer
, but
child serializers should have access to the actual state of indentation.
write_indent: bool
If true
, then current indent will be written before writing the content,
but only if content is not empty.
expand_empty_elements: bool
Implementations§
Source§impl<'w, 'i, W: Write> ContentSerializer<'w, 'i, W>
impl<'w, 'i, W: Write> ContentSerializer<'w, 'i, W>
Sourcepub fn into_simple_type_serializer(self) -> SimpleTypeSerializer<'i, &'w mut W>
pub fn into_simple_type_serializer(self) -> SimpleTypeSerializer<'i, &'w mut W>
Turns this serializer into serializer of a text content
Sourcepub fn new_seq_element_serializer(&mut self) -> ContentSerializer<'_, '_, W>
pub fn new_seq_element_serializer(&mut self) -> ContentSerializer<'_, '_, W>
Creates new serializer that shares state with this serializer and writes to the same underlying writer
Sourcepub(super) fn write_empty(self, name: XmlName<'_>) -> Result<(), DeError>
pub(super) fn write_empty(self, name: XmlName<'_>) -> Result<(), DeError>
Writes name
as self-closed tag
Sourcepub(super) fn write_wrapped<S>(
self,
name: XmlName<'_>,
serialize: S,
) -> Result<(), DeError>
pub(super) fn write_wrapped<S>( self, name: XmlName<'_>, serialize: S, ) -> Result<(), DeError>
Writes simple type content between name
tags
pub(super) fn write_indent(&mut self) -> Result<(), DeError>
Trait Implementations§
Source§impl<'w, 'i, W: Write> SerializeSeq for ContentSerializer<'w, 'i, W>
impl<'w, 'i, W: Write> SerializeSeq for ContentSerializer<'w, 'i, W>
Source§impl<'w, 'i, W: Write> SerializeTuple for ContentSerializer<'w, 'i, W>
impl<'w, 'i, W: Write> SerializeTuple for ContentSerializer<'w, 'i, W>
Source§impl<'w, 'i, W: Write> SerializeTupleStruct for ContentSerializer<'w, 'i, W>
impl<'w, 'i, W: Write> SerializeTupleStruct for ContentSerializer<'w, 'i, W>
Source§impl<'w, 'i, W: Write> Serializer for ContentSerializer<'w, 'i, W>
impl<'w, 'i, W: Write> Serializer for ContentSerializer<'w, 'i, W>
Source§fn serialize_unit_struct(
self,
_name: &'static str,
) -> Result<Self::Ok, Self::Error>
fn serialize_unit_struct( self, _name: &'static str, ) -> Result<Self::Ok, Self::Error>
Does not write anything
Source§fn serialize_unit_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
) -> Result<Self::Ok, Self::Error>
fn serialize_unit_variant( self, _name: &'static str, _variant_index: u32, variant: &'static str, ) -> Result<Self::Ok, Self::Error>
If variant
is a special $text
variant, then do nothing, otherwise
checks variant
for XML name validity and writes <variant/>
.
Source§fn serialize_newtype_variant<T: ?Sized + Serialize>(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
value: &T,
) -> Result<Self::Ok, Self::Error>
fn serialize_newtype_variant<T: ?Sized + Serialize>( self, _name: &'static str, _variant_index: u32, variant: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error>
If variant
is a special $text
variant, then writes value
as a xs:simpleType
,
otherwise checks variant
for XML name validity and writes value
as a new
<variant>
element.
Source§fn serialize_tuple_variant(
self,
name: &'static str,
_variant_index: u32,
variant: &'static str,
len: usize,
) -> Result<Self::SerializeTupleVariant, Self::Error>
fn serialize_tuple_variant( self, name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeTupleVariant, Self::Error>
Serializes variant as a tuple with name variant
, producing
<variant><!-- 1st element of a tuple --></variant>
<variant><!-- 2nd element of a tuple --></variant>
<!-- ... -->
<variant><!-- Nth element of a tuple --></variant>
Source§fn serialize_struct_variant(
self,
name: &'static str,
_variant_index: u32,
variant: &'static str,
len: usize,
) -> Result<Self::SerializeStructVariant, Self::Error>
fn serialize_struct_variant( self, name: &'static str, _variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeStructVariant, Self::Error>
Serializes variant as an element with name variant
, producing
<variant>
<!-- struct fields... -->
</variant>
If struct has no fields which is represented by nested elements or a text,
it may be serialized as self-closed element <variant/>
.
Source§type Ok = ()
type Ok = ()
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 = ContentSerializer<'w, 'i, W>
type SerializeSeq = ContentSerializer<'w, 'i, W>
serialize_seq
for serializing the content of the
sequence.Source§type SerializeTuple = ContentSerializer<'w, 'i, W>
type SerializeTuple = ContentSerializer<'w, 'i, W>
serialize_tuple
for serializing the content of
the tuple.Source§type SerializeTupleStruct = ContentSerializer<'w, 'i, W>
type SerializeTupleStruct = ContentSerializer<'w, 'i, W>
serialize_tuple_struct
for serializing the
content of the tuple struct.Source§type SerializeTupleVariant = Tuple<'w, 'i, W>
type SerializeTupleVariant = Tuple<'w, 'i, W>
serialize_tuple_variant
for serializing the
content of the tuple variant.Source§type SerializeMap = Impossible<<ContentSerializer<'w, 'i, W> as Serializer>::Ok, <ContentSerializer<'w, 'i, W> as Serializer>::Error>
type SerializeMap = Impossible<<ContentSerializer<'w, 'i, W> as Serializer>::Ok, <ContentSerializer<'w, 'i, W> as Serializer>::Error>
serialize_map
for serializing the content of the
map.Source§type SerializeStruct = Impossible<<ContentSerializer<'w, 'i, W> as Serializer>::Ok, <ContentSerializer<'w, 'i, W> as Serializer>::Error>
type SerializeStruct = Impossible<<ContentSerializer<'w, 'i, W> as Serializer>::Ok, <ContentSerializer<'w, 'i, W> as Serializer>::Error>
serialize_struct
for serializing the content of
the struct.Source§type SerializeStructVariant = Struct<'w, 'i, W>
type SerializeStructVariant = Struct<'w, 'i, W>
serialize_struct_variant
for serializing the
content of the struct variant.Source§fn serialize_bool(self, value: bool) -> Result<Self::Ok, Self::Error>
fn serialize_bool(self, value: bool) -> Result<Self::Ok, Self::Error>
bool
value. Read moreSource§fn serialize_i8(self, value: i8) -> Result<Self::Ok, Self::Error>
fn serialize_i8(self, value: i8) -> Result<Self::Ok, Self::Error>
i8
value. Read moreSource§fn serialize_i16(self, value: i16) -> Result<Self::Ok, Self::Error>
fn serialize_i16(self, value: i16) -> Result<Self::Ok, Self::Error>
i16
value. Read moreSource§fn serialize_i32(self, value: i32) -> Result<Self::Ok, Self::Error>
fn serialize_i32(self, value: i32) -> Result<Self::Ok, Self::Error>
i32
value. Read moreSource§fn serialize_i64(self, value: i64) -> Result<Self::Ok, Self::Error>
fn serialize_i64(self, value: i64) -> Result<Self::Ok, Self::Error>
i64
value. Read moreSource§fn serialize_u8(self, value: u8) -> Result<Self::Ok, Self::Error>
fn serialize_u8(self, value: u8) -> Result<Self::Ok, Self::Error>
u8
value. Read moreSource§fn serialize_u16(self, value: u16) -> Result<Self::Ok, Self::Error>
fn serialize_u16(self, value: u16) -> Result<Self::Ok, Self::Error>
u16
value. Read moreSource§fn serialize_u32(self, value: u32) -> Result<Self::Ok, Self::Error>
fn serialize_u32(self, value: u32) -> Result<Self::Ok, Self::Error>
u32
value. Read moreSource§fn serialize_u64(self, value: u64) -> Result<Self::Ok, Self::Error>
fn serialize_u64(self, value: u64) -> Result<Self::Ok, Self::Error>
u64
value. Read moreSource§fn serialize_i128(self, value: i128) -> Result<Self::Ok, Self::Error>
fn serialize_i128(self, value: i128) -> Result<Self::Ok, Self::Error>
i128
value. Read moreSource§fn serialize_u128(self, value: u128) -> Result<Self::Ok, Self::Error>
fn serialize_u128(self, value: u128) -> Result<Self::Ok, Self::Error>
u128
value. Read moreSource§fn serialize_f32(self, value: f32) -> Result<Self::Ok, Self::Error>
fn serialize_f32(self, value: f32) -> Result<Self::Ok, Self::Error>
f32
value. Read moreSource§fn serialize_f64(self, value: f64) -> Result<Self::Ok, Self::Error>
fn serialize_f64(self, value: f64) -> Result<Self::Ok, Self::Error>
f64
value. Read moreSource§fn serialize_char(self, value: char) -> Result<Self::Ok, Self::Error>
fn serialize_char(self, value: char) -> Result<Self::Ok, Self::Error>
Source§fn serialize_bytes(self, value: &[u8]) -> Result<Self::Ok, Self::Error>
fn serialize_bytes(self, value: &[u8]) -> Result<Self::Ok, Self::Error>
Source§fn serialize_str(self, value: &str) -> Result<Self::Ok, Self::Error>
fn serialize_str(self, value: &str) -> Result<Self::Ok, Self::Error>
&str
. Read moreSource§fn serialize_some<T: ?Sized + Serialize>(
self,
value: &T,
) -> Result<Self::Ok, Self::Error>
fn serialize_some<T: ?Sized + Serialize>( self, value: &T, ) -> Result<Self::Ok, Self::Error>
Source§fn serialize_newtype_struct<T: ?Sized + Serialize>(
self,
_name: &'static str,
value: &T,
) -> Result<Self::Ok, Self::Error>
fn serialize_newtype_struct<T: ?Sized + Serialize>( self, _name: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error>
struct Millimeters(u8)
. Read moreSource§fn serialize_seq(
self,
_len: Option<usize>,
) -> Result<Self::SerializeSeq, Self::Error>
fn serialize_seq( self, _len: Option<usize>, ) -> Result<Self::SerializeSeq, Self::Error>
serialize_element
, then a call to
end
. Read moreSource§fn serialize_tuple(
self,
len: usize,
) -> Result<Self::SerializeTuple, Self::Error>
fn serialize_tuple( self, len: usize, ) -> Result<Self::SerializeTuple, Self::Error>
serialize_element
,
then a call to end
. Read moreSource§fn serialize_tuple_struct(
self,
_name: &'static str,
len: usize,
) -> Result<Self::SerializeTupleStruct, Self::Error>
fn serialize_tuple_struct( self, _name: &'static str, len: usize, ) -> Result<Self::SerializeTupleStruct, Self::Error>
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_map(
self,
_len: Option<usize>,
) -> Result<Self::SerializeMap, Self::Error>
fn serialize_map( self, _len: Option<usize>, ) -> Result<Self::SerializeMap, Self::Error>
serialize_key
and serialize_value
, then a call to end
. Read moreSource§fn serialize_struct(
self,
name: &'static str,
_len: usize,
) -> Result<Self::SerializeStruct, Self::Error>
fn serialize_struct( self, name: &'static str, _len: usize, ) -> Result<Self::SerializeStruct, Self::Error>
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 collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error>
fn collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error>
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>
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>
Display
. Read moreSource§fn is_human_readable(&self) -> bool
fn is_human_readable(&self) -> bool
Serialize
implementations should serialize in
human-readable form. Read more