From 3db64a400c78bbd2708e67ddc07df1001fff3f29 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Wed, 17 Feb 2021 17:53:31 +0300 Subject: rename completion -> ide_completion We don't have completion-related PRs in flight, so lets do it --- crates/completion/src/render/builder_ext.rs | 94 ----------------------------- 1 file changed, 94 deletions(-) delete mode 100644 crates/completion/src/render/builder_ext.rs (limited to 'crates/completion/src/render/builder_ext.rs') diff --git a/crates/completion/src/render/builder_ext.rs b/crates/completion/src/render/builder_ext.rs deleted file mode 100644 index d053a988b..000000000 --- a/crates/completion/src/render/builder_ext.rs +++ /dev/null @@ -1,94 +0,0 @@ -//! Extensions for `Builder` structure required for item rendering. - -use itertools::Itertools; -use test_utils::mark; - -use crate::{item::Builder, CompletionContext}; - -#[derive(Debug)] -pub(super) enum Params { - Named(Vec), - Anonymous(usize), -} - -impl Params { - pub(super) fn len(&self) -> usize { - match self { - Params::Named(xs) => xs.len(), - 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 ctx.use_item_syntax.is_some() { - mark::hit!(no_parens_in_use_item); - return false; - } - if ctx.is_pattern_call { - return false; - } - if ctx.is_call { - 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() { - 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: String, - params: Params, - ) -> 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. - mark::hit!(inserts_parens_for_function_calls); - - let (snippet, label) = if params.is_empty() { - (format!("{}()$0", name), format!("{}()", name)) - } else { - self = self.trigger_call_info(); - let snippet = match (ctx.config.add_call_argument_snippets, params) { - (true, Params::Named(params)) => { - let function_params_snippet = - params.iter().enumerate().format_with(", ", |(index, param_name), f| { - f(&format_args!("${{{}:{}}}", index + 1, param_name)) - }); - format!("{}({})$0", name, function_params_snippet) - } - _ => { - mark::hit!(suppress_arg_snippets); - format!("{}($0)", name) - } - }; - - (snippet, format!("{}(…)", name)) - }; - self.lookup_by(name).label(label).insert_snippet(cap, snippet) - } -} -- cgit v1.2.3