in serde-generate/src/csharp.rs [432:520]
fn output_serialization_helper(&mut self, name: &str, format0: &Format) -> Result<()> {
use Format::*;
write!(
self.out,
"public static void serialize_{}({} value, Serde.ISerializer serializer) {{",
name,
self.quote_type(format0)
)?;
self.out.indent();
match format0 {
Option(format) => {
write!(
self.out,
r#"
if (value.IsSome(out var val)) {{
serializer.serialize_option_tag(true);
{}
}} else {{
serializer.serialize_option_tag(false);
}}
"#,
self.quote_serialize_value("val", format)
)?;
}
Seq(format) => {
write!(
self.out,
r#"
serializer.serialize_len(value.Count);
foreach (var item in value) {{
{}
}}
"#,
self.quote_serialize_value("item", format)
)?;
}
Map { key, value } => {
write!(
self.out,
r#"
serializer.serialize_len(value.Count);
int[] offsets = new int[value.Count];
int count = 0;
foreach (KeyValuePair<{}, {}> entry in value) {{
offsets[count++] = serializer.get_buffer_offset();
{}
{}
}}
serializer.sort_map_entries(offsets);
"#,
self.quote_type(key),
self.quote_type(value),
self.quote_serialize_value("entry.Key", key),
self.quote_serialize_value("entry.Value", value)
)?;
}
Tuple(formats) => {
writeln!(self.out)?;
for (index, format) in formats.iter().enumerate() {
let expr = format!("value.Item{}", index + 1);
writeln!(self.out, "{}", self.quote_serialize_value(&expr, format))?;
}
}
TupleArray { content, size } => {
write!(
self.out,
r#"
if (value.Count != {0}) {{
throw new Serde.SerializationException("Invalid length for fixed-size array: " + value.Count + " instead of " + {0});
}}
foreach (var item in value) {{
{1}
}}
"#,
size,
self.quote_serialize_value("item", content),
)?;
}
_ => panic!("unexpected case"),
}
self.out.unindent();
writeln!(self.out, "}}\n")
}