diff options
| author | Ali Bektas <bektasali@protonmail.com> | 2023-08-09 23:42:52 +0200 |
|---|---|---|
| committer | Ali Bektas <bektasali@protonmail.com> | 2023-08-09 23:42:52 +0200 |
| commit | c81a0681a26c557e2f46dcb1876fcafa24d569b3 (patch) | |
| tree | 8ec8102284f41e90dfbc4be607eb75afad61c703 | |
| parent | b78d69c79586aeed7f2c8afb9a4e2c0543b3876f (diff) | |
| download | rust-c81a0681a26c557e2f46dcb1876fcafa24d569b3.tar.gz rust-c81a0681a26c557e2f46dcb1876fcafa24d569b3.zip | |
Deunwrap generate_delegate_methods
| -rw-r--r-- | crates/ide-assists/src/handlers/generate_delegate_methods.rs | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/crates/ide-assists/src/handlers/generate_delegate_methods.rs b/crates/ide-assists/src/handlers/generate_delegate_methods.rs index 31fc69562c9..bbac0a26ea4 100644 --- a/crates/ide-assists/src/handlers/generate_delegate_methods.rs +++ b/crates/ide-assists/src/handlers/generate_delegate_methods.rs @@ -95,6 +95,9 @@ pub(crate) fn generate_delegate_methods(acc: &mut Assists, ctx: &AssistContext<' let Some(impl_def) = find_struct_impl(ctx, &adt, std::slice::from_ref(&name)) else { continue; }; + + let field = make::ext::field_from_idents(["self", &field_name])?; + acc.add_group( &GroupLabel("Generate delegate methods…".to_owned()), AssistId("generate_delegate_methods", AssistKind::Generate), @@ -115,11 +118,7 @@ pub(crate) fn generate_delegate_methods(acc: &mut Assists, ctx: &AssistContext<' Some(list) => convert_param_list_to_arg_list(list), None => make::arg_list([]), }; - let tail_expr = make::expr_method_call( - make::ext::field_from_idents(["self", &field_name]).unwrap(), // This unwrap is ok because we have at least 1 arg in the list - make::name_ref(&name), - arg_list, - ); + let tail_expr = make::expr_method_call(field, make::name_ref(&name), arg_list); let ret_type = method_source.ret_type(); let is_async = method_source.async_token().is_some(); let is_const = method_source.const_token().is_some(); |
