]> git.lizzy.rs Git - rust.git/commitdiff
Simplify
authorLukas Wirth <lukastw97@gmail.com>
Mon, 20 Dec 2021 13:38:22 +0000 (14:38 +0100)
committerLukas Wirth <lukastw97@gmail.com>
Mon, 20 Dec 2021 13:38:22 +0000 (14:38 +0100)
crates/ide_completion/src/render/builder_ext.rs
crates/ide_completion/src/render/function.rs

index 4d0405444542141ab45594251c18f432ec1b4c78..0c6cbf7cb2d82fbc80cc58657c0a382b8fa10b59 100644 (file)
@@ -1,6 +1,5 @@
 //! Extensions for `Builder` structure required for item rendering.
 
-use either::Either;
 use itertools::Itertools;
 use syntax::ast::{self, HasName};
 
@@ -8,14 +7,14 @@
 
 #[derive(Debug)]
 pub(super) enum Params {
-    Named(Vec<(Either<ast::SelfParam, ast::Param>, hir::Param)>),
+    Named(Option<ast::SelfParam>, Vec<(ast::Param, hir::Param)>),
     Anonymous(usize),
 }
 
 impl Params {
     pub(super) fn len(&self) -> usize {
         match self {
-            Params::Named(xs) => xs.len(),
+            Params::Named(selv, params) => params.len() + if selv.is_some() { 1 } else { 0 },
             Params::Anonymous(len) => *len,
         }
     }
@@ -77,48 +76,56 @@ pub(super) fn add_call_parens(
         } else {
             self.trigger_call_info();
             let snippet = match (ctx.config.add_call_argument_snippets, params) {
-                (true, Params::Named(params)) => {
+                (true, Params::Named(self_param, params)) => {
+                    let offset = if self_param.is_some() { 2 } else { 1 };
                     let function_params_snippet = params.iter().enumerate().format_with(
                         ", ",
                         |(index, (param_source, param)), f| {
                             let name;
                             let text;
-                            let (ref_, name) = match param_source {
-                                Either::Left(self_param) => (
-                                    match self_param.kind() {
-                                        ast::SelfParamKind::Owned => "",
-                                        ast::SelfParamKind::Ref => "&",
-                                        ast::SelfParamKind::MutRef => "&mut ",
-                                    },
-                                    "self",
-                                ),
-                                Either::Right(it) => {
-                                    let n = (|| {
-                                        let mut pat = it.pat()?;
-                                        loop {
-                                            match pat {
-                                                ast::Pat::IdentPat(pat) => break pat.name(),
-                                                ast::Pat::RefPat(it) => pat = it.pat()?,
-                                                _ => return None,
-                                            }
-                                        }
-                                    })();
-                                    match n {
-                                        Some(n) => {
-                                            name = n;
-                                            text = name.text();
-                                            let text = text.as_str().trim_start_matches('_');
-                                            let ref_ = ref_of_param(ctx, text, param.ty());
-                                            (ref_, text)
-                                        }
-                                        None => ("", "_"),
+                            let n = (|| {
+                                let mut pat = param_source.pat()?;
+                                loop {
+                                    match pat {
+                                        ast::Pat::IdentPat(pat) => break pat.name(),
+                                        ast::Pat::RefPat(it) => pat = it.pat()?,
+                                        _ => return None,
                                     }
                                 }
+                            })();
+                            let (ref_, name) = match n {
+                                Some(n) => {
+                                    name = n;
+                                    text = name.text();
+                                    let text = text.as_str().trim_start_matches('_');
+                                    let ref_ = ref_of_param(ctx, text, param.ty());
+                                    (ref_, text)
+                                }
+                                None => ("", "_"),
                             };
-                            f(&format_args!("${{{}:{}{}}}", index + 1, ref_, name))
+
+                            f(&format_args!("${{{}:{}{}}}", index + offset, ref_, name))
                         },
                     );
-                    format!("{}({})$0", name, function_params_snippet)
+                    match self_param {
+                        Some(self_param) => {
+                            let prefix = match self_param.kind() {
+                                ast::SelfParamKind::Owned => "",
+                                ast::SelfParamKind::Ref => "&",
+                                ast::SelfParamKind::MutRef => "&mut ",
+                            };
+                            format!(
+                                "{}(${{1:{}self}}{}{})$0",
+                                name,
+                                prefix,
+                                if params.is_empty() { "" } else { ", " },
+                                function_params_snippet
+                            )
+                        }
+                        None => {
+                            format!("{}({})$0", name, function_params_snippet)
+                        }
+                    }
                 }
                 _ => {
                     cov_mark::hit!(suppress_arg_snippets);
index 86dfbf7fc8f9da931d269aa745580a773cd31cae..5a243cbdd3276cec7e95fa3997110daf83c55559 100644 (file)
@@ -1,6 +1,5 @@
 //! Renderer for function calls.
 
-use either::Either;
 use hir::{AsAssocItem, HasSource, HirDisplay};
 use ide_db::SymbolKind;
 use itertools::Itertools;
@@ -56,7 +55,7 @@ struct FunctionRender<'a> {
     ///
     /// It seems that just using `ast` is the best choice -- most of parses
     /// should be cached anyway.
-    ast_node: ast::Fn,
+    param_list: Option<ast::ParamList>,
     is_method: bool,
 }
 
@@ -69,9 +68,9 @@ fn new(
         is_method: bool,
     ) -> Option<FunctionRender<'a>> {
         let name = local_name.unwrap_or_else(|| fn_.name(ctx.db()));
-        let ast_node = fn_.source(ctx.db())?.value;
+        let param_list = fn_.source(ctx.db())?.value.param_list();
 
-        Some(FunctionRender { ctx, name, receiver, func: fn_, ast_node, is_method })
+        Some(FunctionRender { ctx, name, receiver, func: fn_, param_list, is_method })
     }
 
     fn render(self, import_to_add: Option<ImportEdit>) -> CompletionItem {
@@ -152,25 +151,25 @@ fn params_display(&self) -> String {
     }
 
     fn params(&self) -> Params {
-        let ast_params = match self.ast_node.param_list() {
+        let ast_params = match &self.param_list {
             Some(it) => it,
-            None => return Params::Named(Vec::new()),
+            None => return Params::Named(None, Vec::new()),
         };
-        let params = ast_params.params().map(Either::Right);
+        let params = ast_params.params();
 
-        let params = if self.ctx.completion.has_dot_receiver() || self.receiver.is_some() {
-            params.zip(self.func.method_params(self.ctx.db()).unwrap_or_default()).collect()
+        let (params, self_param) = if self.ctx.completion.has_dot_receiver()
+            || self.receiver.is_some()
+        {
+            (params.zip(self.func.method_params(self.ctx.db()).unwrap_or_default()).collect(), None)
         } else {
-            ast_params
-                .self_param()
-                .map(Either::Left)
-                .into_iter()
-                .chain(params)
-                .zip(self.func.assoc_fn_params(self.ctx.db()))
-                .collect()
+            let mut assoc_params = self.func.assoc_fn_params(self.ctx.db());
+            if self.func.self_param(self.ctx.db()).is_some() {
+                assoc_params.remove(0);
+            }
+            (params.zip(assoc_params).collect(), ast_params.self_param())
         };
 
-        Params::Named(params)
+        Params::Named(self_param, params)
     }
 
     fn kind(&self) -> CompletionItemKind {