Simplify generated enum code (#286)
* simplify the code generated for unit enums * simplify generated code for validating object properties * optimize internal and externally tagged enums --------- Co-authored-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
parent
e5ef0f8d7b
commit
d04c17bda4
3 changed files with 152 additions and 124 deletions
|
@ -13,47 +13,32 @@ pub struct SchemaMetadata<'a> {
|
|||
|
||||
impl<'a> SchemaMetadata<'a> {
|
||||
pub fn apply_to_schema(&self, schema_expr: &mut TokenStream) {
|
||||
let setters = self.make_setters();
|
||||
if !setters.is_empty() {
|
||||
*schema_expr = quote! {{
|
||||
let schema = #schema_expr;
|
||||
schemars::_private::apply_metadata(schema, schemars::schema::Metadata {
|
||||
#(#setters)*
|
||||
..Default::default()
|
||||
})
|
||||
}}
|
||||
}
|
||||
}
|
||||
|
||||
fn make_setters(&self) -> Vec<TokenStream> {
|
||||
let mut setters = Vec::<TokenStream>::new();
|
||||
|
||||
if let Some(title) = &self.title {
|
||||
setters.push(quote! {
|
||||
title: Some(#title.to_owned()),
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_title(#schema_expr, #title)
|
||||
};
|
||||
}
|
||||
if let Some(description) = &self.description {
|
||||
setters.push(quote! {
|
||||
description: Some(#description.to_owned()),
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_description(#schema_expr, #description)
|
||||
};
|
||||
}
|
||||
|
||||
if self.deprecated {
|
||||
setters.push(quote! {
|
||||
deprecated: true,
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_deprecated(#schema_expr, true)
|
||||
};
|
||||
}
|
||||
|
||||
if self.read_only {
|
||||
setters.push(quote! {
|
||||
read_only: true,
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_read_only(#schema_expr, true)
|
||||
};
|
||||
}
|
||||
if self.write_only {
|
||||
setters.push(quote! {
|
||||
write_only: true,
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_write_only(#schema_expr, true)
|
||||
};
|
||||
}
|
||||
|
||||
if !self.examples.is_empty() {
|
||||
|
@ -62,17 +47,16 @@ impl<'a> SchemaMetadata<'a> {
|
|||
schemars::_serde_json::value::to_value(#eg())
|
||||
}
|
||||
});
|
||||
setters.push(quote! {
|
||||
examples: vec![#(#examples),*].into_iter().flatten().collect(),
|
||||
});
|
||||
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_examples(#schema_expr, [#(#examples),*].into_iter().flatten())
|
||||
};
|
||||
}
|
||||
|
||||
if let Some(default) = &self.default {
|
||||
setters.push(quote! {
|
||||
default: #default.and_then(|d| schemars::_schemars_maybe_to_value!(d)),
|
||||
});
|
||||
*schema_expr = quote! {
|
||||
schemars::_private::metadata::add_default(#schema_expr, #default.and_then(|d| schemars::_schemars_maybe_to_value!(d)))
|
||||
};
|
||||
}
|
||||
|
||||
setters
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue