Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/ide_completion/src/render/builder_ext.rs')
| -rw-r--r-- | crates/ide_completion/src/render/builder_ext.rs | 129 |
1 files changed, 0 insertions, 129 deletions
diff --git a/crates/ide_completion/src/render/builder_ext.rs b/crates/ide_completion/src/render/builder_ext.rs deleted file mode 100644 index 70767a2a9c..0000000000 --- a/crates/ide_completion/src/render/builder_ext.rs +++ /dev/null @@ -1,129 +0,0 @@ -//! Extensions for `Builder` structure required for item rendering. - -use itertools::Itertools; -use syntax::SmolStr; - -use crate::{context::PathKind, item::Builder, patterns::ImmediateLocation, CompletionContext}; - -#[derive(Debug)] -pub(super) enum Params { - Named(Option<hir::SelfParam>, Vec<hir::Param>), - #[allow(dead_code)] - Anonymous(usize), -} - -impl Params { - pub(super) fn len(&self) -> usize { - match self { - Params::Named(selv, params) => params.len() + if selv.is_some() { 1 } else { 0 }, - Params::Anonymous(len) => *len, - } - } - - pub(super) fn is_empty(&self) -> bool { - self.len() == 0 - } -} - -impl Builder { - fn should_add_parens(&self, ctx: &CompletionContext) -> bool { - if !ctx.config.add_call_parenthesis { - return false; - } - if let Some(PathKind::Use) = ctx.path_kind() { - cov_mark::hit!(no_parens_in_use_item); - return false; - } - if matches!(ctx.path_kind(), Some(PathKind::Expr | PathKind::Pat) if ctx.path_is_call()) - | matches!( - ctx.completion_location, - Some(ImmediateLocation::MethodCall { has_parens: true, .. }) - ) - { - return false; - } - - // Don't add parentheses if the expected type is some function reference. - if let Some(ty) = &ctx.expected_type { - if ty.is_fn() { - cov_mark::hit!(no_call_parens_if_fn_ptr_needed); - return false; - } - } - - // Nothing prevents us from adding parentheses - true - } - - pub(super) fn add_call_parens( - &mut self, - ctx: &CompletionContext, - name: SmolStr, - params: Params, - ) -> &mut Builder { - if !self.should_add_parens(ctx) { - return self; - } - - let cap = match ctx.config.snippet_cap { - Some(it) => it, - None => return self, - }; - // If not an import, add parenthesis automatically. - cov_mark::hit!(inserts_parens_for_function_calls); - - let (snippet, label) = if params.is_empty() { - (format!("{}()$0", name), format!("{}()", name)) - } else { - self.trigger_call_info(); - let snippet = match (ctx.config.add_call_argument_snippets, 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), f| match param.name(ctx.db) { - Some(n) => { - let smol_str = n.to_smol_str(); - let text = smol_str.as_str().trim_start_matches('_'); - let ref_ = ref_of_param(ctx, text, param.ty()); - f(&format_args!("${{{}:{}{}}}", index + offset, ref_, text)) - } - None => f(&format_args!("${{{}:_}}", index + offset,)), - }, - ); - match self_param { - Some(self_param) => { - format!( - "{}(${{1:{}}}{}{})$0", - name, - self_param.display(ctx.db), - if params.is_empty() { "" } else { ", " }, - function_params_snippet - ) - } - None => { - format!("{}({})$0", name, function_params_snippet) - } - } - } - _ => { - cov_mark::hit!(suppress_arg_snippets); - format!("{}($0)", name) - } - }; - - (snippet, format!("{}(…)", name)) - }; - self.lookup_by(name).label(label).insert_snippet(cap, snippet) - } -} -fn ref_of_param(ctx: &CompletionContext, arg: &str, ty: &hir::Type) -> &'static str { - if let Some(derefed_ty) = ty.remove_ref() { - for (name, local) in ctx.locals.iter() { - if name.as_text().as_deref() == Some(arg) && local.ty(ctx.db) == derefed_ty { - return if ty.is_mutable_reference() { "&mut " } else { "&" }; - } - } - } - "" -} |