From b8918942c0ce592334edf4f9db573a8d04dcadb1 Mon Sep 17 00:00:00 2001 From: Joel Wachsler Date: Tue, 12 Jul 2022 13:49:45 +0000 Subject: [PATCH] Combine logic --- .../group/method/method_with_params.rs | 42 ++++++++++--------- 1 file changed, 22 insertions(+), 20 deletions(-) diff --git a/qbittorrent-web-api-gen/src/generate/group/method/method_with_params.rs b/qbittorrent-web-api-gen/src/generate/group/method/method_with_params.rs index 591b164..08944d2 100644 --- a/qbittorrent-web-api-gen/src/generate/group/method/method_with_params.rs +++ b/qbittorrent-web-api-gen/src/generate/group/method/method_with_params.rs @@ -22,37 +22,39 @@ pub fn create_method_with_params( .iter() .filter(|param| !param.get_type_info().is_optional); - let mandatory_param_args = mandatory_params.clone().map(|param| { - let name = util::to_ident(¶m.get_type_info().name.to_snake()); + let param_to_ident = |param: &types::Type| { let t = util::to_ident(¶m.to_borrowed_type()); if param.should_borrow() { - quote! { - #name: &#t - } + quote! { &#t } } else { - quote! { - #name: #t - } + quote! { #t } } - }); + }; + + let param_name = |param: &types::Type| { + let name_as_str = param.get_type_info().name.to_snake(); + (util::to_ident(&name_as_str), name_as_str) + }; + + let param_with_name = |param: &types::Type| { + let (name, ..) = param_name(param); + let t = param_to_ident(param); + + quote! { #name: #t } + }; + + let mandatory_param_args = mandatory_params.clone().map(|param| param_with_name(param)); let mandatory_param_names = mandatory_params.clone().map(|param| { - let name = util::to_ident(¶m.get_type_info().name.to_snake()); - - quote! { - #name - } + let (name, ..) = param_name(param); + quote! { #name } }); let mandatory_param_args_clone = mandatory_param_args.clone(); let mandatory_param_form_build = mandatory_params.map(|param| { - let n = ¶m.get_type_info().name; - let name = util::to_ident(&n.to_snake()); - - quote! { - let form = form.text(#n, #name.to_string()); - } + let (name, name_as_str) = param_name(param); + quote! { let form = form.text(#name_as_str, #name.to_string()); } }); let optional_params = params