feat(sdk): add documentation strings

This commit is contained in:
Kasper Juul Hermansen 2023-02-19 22:38:36 +01:00 committed by Kasper Juul Hermansen
parent a1887afc8b
commit 978ede68ae
3 changed files with 499 additions and 6 deletions

View File

@ -64,9 +64,11 @@ pub fn format_function(funcs: &CommonFunctions, field: &FullTypeFields) -> Optio
.pipe(|t| &t.type_ref) .pipe(|t| &t.type_ref)
.pipe(|t| render_output_type(funcs, t)); .pipe(|t| render_output_type(funcs, t));
if let Some((args, true)) = args { if let Some((args, desc, true)) = args {
let required_args = format_required_function_args(funcs, field); let required_args = format_required_function_args(funcs, field);
Some(quote! { Some(quote! {
$(field.description.pipe(|d| format_struct_comment(d)))
$(&desc)
$(&signature)( $(&signature)(
$(required_args) $(required_args)
) -> $(output_type.as_ref()) { ) -> $(output_type.as_ref()) {
@ -77,6 +79,8 @@ pub fn format_function(funcs: &CommonFunctions, field: &FullTypeFields) -> Optio
$(render_execution(funcs, field)) $(render_execution(funcs, field))
} }
$(field.description.pipe(|d| format_struct_comment(d)))
$(&desc)
$(&signature)_opts$(lifecycle)( $(&signature)_opts$(lifecycle)(
$args $args
) -> $(output_type) { ) -> $(output_type) {
@ -90,8 +94,10 @@ pub fn format_function(funcs: &CommonFunctions, field: &FullTypeFields) -> Optio
}) })
} else { } else {
Some(quote! { Some(quote! {
$(field.description.pipe(|d| format_struct_comment(d)))
$(if let Some((_, desc, _)) = &args => $desc)
$(signature)( $(signature)(
$(if let Some((args, _)) = args => $args) $(if let Some((args, _, _)) = &args => $args)
) -> $(output_type) { ) -> $(output_type) {
let mut query = self.selection.select($(quoted(field.name.as_ref()))); let mut query = self.selection.select($(quoted(field.name.as_ref())));
@ -268,7 +274,8 @@ fn format_function_args(
funcs: &CommonFunctions, funcs: &CommonFunctions,
field: &FullTypeFields, field: &FullTypeFields,
lifecycle: Option<&rust::Tokens>, lifecycle: Option<&rust::Tokens>,
) -> Option<(rust::Tokens, bool)> { ) -> Option<(rust::Tokens, rust::Tokens, bool)> {
let mut argument_description = Vec::new();
if let Some(args) = field.args.as_ref() { if let Some(args) = field.args.as_ref() {
let args = args let args = args
.into_iter() .into_iter()
@ -281,6 +288,18 @@ fn format_function_args(
let t = funcs.format_input_type(&s.input_value.type_); let t = funcs.format_input_type(&s.input_value.type_);
let n = format_struct_name(&s.input_value.name); let n = format_struct_name(&s.input_value.name);
if let Some(desc) = s.input_value.description.as_ref().and_then(|d| {
if d != "" {
Some(write_comment_line(&format!("* `{n}` - {}", d)))
} else {
None
}
}) {
argument_description.push(quote! {
$(desc)
});
}
Some(quote! { Some(quote! {
$(n): $(t), $(n): $(t),
}) })
@ -294,15 +313,34 @@ fn format_function_args(
}; };
if type_field_has_optional(field) { if type_field_has_optional(field) {
let field_name = field_options_struct_name(field);
argument_description.push(quote! {
$(field_name.pipe(|_| write_comment_line(&format!("* `opt` - optional argument, see inner type for documentation, use <func>_opts to use"))))
});
let description = quote! {
$(if argument_description.len() > 0 => $(format!("/// ")))
$(if argument_description.len() > 0 => $(format!("/// # Arguments")))
$(if argument_description.len() > 0 => $(format!("/// ")))
$(for arg_desc in argument_description join ($['\r']) => $arg_desc)
};
Some(( Some((
quote! { quote! {
$(required_args) $(required_args)
opts: $(field_options_struct_name(field))$(lifecycle) opts: $(field_name)$(lifecycle)
}, },
description,
true, true,
)) ))
} else { } else {
Some((required_args, false)) let description = quote! {
$(if argument_description.len() > 0 => $(format!("/// ")))
$(if argument_description.len() > 0 => $(format!("/// # Arguments")))
$(if argument_description.len() > 0 => $(format!("/// ")))
$(for arg_desc in argument_description join ($['\r']) => $arg_desc)
};
Some((required_args, description, false))
} }
} else { } else {
None None
@ -358,3 +396,36 @@ pub fn format_optional_args(
.pipe(|t| render_optional_field_args(funcs, t)) .pipe(|t| render_optional_field_args(funcs, t))
.flatten() .flatten()
} }
pub fn write_comment_line(content: &str) -> Option<rust::Tokens> {
let cnt = content.trim();
if cnt == "" {
return None;
}
let mut tokens = rust::Tokens::new();
for line in content.split('\n') {
tokens.append(format!("/// {}", line.trim()));
tokens.push();
}
Some(tokens)
}
pub fn format_struct_comment(desc: &str) -> Option<rust::Tokens> {
let lines = desc.trim().split("\n");
let formatted_lines = lines
.into_iter()
.map(write_comment_line)
.collect::<Vec<_>>();
if formatted_lines.len() > 0 {
Some(quote! {
$(for line in formatted_lines join($['\r']) => $line)
})
} else {
None
}
}

View File

@ -6,7 +6,7 @@ use itertools::Itertools;
use crate::functions::{type_ref_is_optional, CommonFunctions}; use crate::functions::{type_ref_is_optional, CommonFunctions};
use crate::rust::functions::{ use crate::rust::functions::{
field_options_struct_name, format_function, format_name, format_optional_args, field_options_struct_name, format_function, format_name, format_optional_args,
format_struct_name, format_struct_comment, format_struct_name,
}; };
use crate::utility::OptionExt; use crate::utility::OptionExt;
@ -85,6 +85,7 @@ pub fn render_optional_field_args(
contains_lifetime = true; contains_lifetime = true;
} }
quote! { quote! {
$(a.description.pipe(|d| format_struct_comment(d)))
#[builder(setter(into, strip_option))] #[builder(setter(into, strip_option))]
pub $(format_struct_name(&a.name)): Option<$(type_)>, pub $(format_struct_name(&a.name)): Option<$(type_)>,
} }

File diff suppressed because it is too large Load Diff