in avro/src/ser_schema.rs [1477:1523]
fn serialize_struct_with_schema<'a>(
&'a mut self,
name: &'static str,
len: usize,
schema: &'s Schema,
) -> Result<SchemaAwareWriteSerializeStruct<'a, 's, W>, Error> {
let create_error = |cause: String| Error::SerializeValueWithSchema {
value_type: "struct",
value: format!("{name}{{ ... }}. Cause: {cause}"),
schema: schema.clone(),
};
match schema {
Schema::Record(record_schema) => Ok(SchemaAwareWriteSerializeStruct::new(
self,
record_schema,
len,
)),
Schema::Ref { name: ref_name } => {
let ref_schema = self.get_ref_schema(ref_name)?;
self.serialize_struct_with_schema(name, len, ref_schema)
}
Schema::Union(union_schema) => {
for (i, variant_schema) in union_schema.schemas.iter().enumerate() {
match variant_schema {
Schema::Record(inner)
if inner.fields.len() == len && inner.name.name == name =>
{
encode_int(i as i32, &mut *self.writer)?;
return self.serialize_struct_with_schema(name, len, variant_schema);
}
Schema::Ref { name: _ } => {
encode_int(i as i32, &mut *self.writer)?;
return self.serialize_struct_with_schema(name, len, variant_schema);
}
_ => { /* skip */ }
}
}
Err(create_error(format!(
"Expected Record or Ref schema in {union_schema:?}"
)))
}
_ => Err(create_error(format!(
"Expected Record, Ref or Union schema. Got: {schema}"
))),
}
}