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;
Nonedoes not write anything;Someand 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::Unsupportedis 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($valuefields), orSimpleTypeSerializer($textfields). 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: QuoteLevelDefines 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: boolIf true, then current indent will be written before writing the content,
but only if content is not empty.
expand_empty_elements: boolImplementations§
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