mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 14:13:58 +00:00
Document the feature
This commit is contained in:
parent
19cfa5802e
commit
9656ceb896
1 changed files with 43 additions and 0 deletions
|
@ -73,6 +73,49 @@ fn complete_enum_variants(acc: &mut Completions, ctx: &CompletionContext, ty: &T
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Feature: Fuzzy Completion and Autoimports
|
||||||
|
//
|
||||||
|
// When completing names in the current scope, proposes additional imports from other modules or crates,
|
||||||
|
// if they can be qualified in the scope and their name contains all symbols from the completion input
|
||||||
|
// (case-insensitive, in any order or places).
|
||||||
|
//
|
||||||
|
// ```
|
||||||
|
// fn main() {
|
||||||
|
// pda<|>
|
||||||
|
// }
|
||||||
|
// # pub mod std { pub mod marker { pub struct PhantomData { } } }
|
||||||
|
// ```
|
||||||
|
// ->
|
||||||
|
// ```
|
||||||
|
// use std::marker::PhantomData;
|
||||||
|
//
|
||||||
|
// fn main() {
|
||||||
|
// PhantomData
|
||||||
|
// }
|
||||||
|
// # pub mod std { pub mod marker { pub struct PhantomData { } } }
|
||||||
|
// ```
|
||||||
|
//
|
||||||
|
// .Fuzzy search details
|
||||||
|
//
|
||||||
|
// To avoid an excessive amount of the results returned, completion input is checked for inclusion in the identifiers only
|
||||||
|
// (i.e. in `HashMap` in the `std::collections::HashMap` path), also not in the module indentifiers.
|
||||||
|
//
|
||||||
|
// .Merge Behaviour
|
||||||
|
//
|
||||||
|
// It is possible to configure how use-trees are merged with the `importMergeBehaviour` setting.
|
||||||
|
// Mimics the corresponding behaviour of the `Auto Import` feature.
|
||||||
|
//
|
||||||
|
// .LSP and performance implications
|
||||||
|
//
|
||||||
|
// LSP 3.16 provides the way to defer the computation of some completion data, including the import edits for this feature.
|
||||||
|
// If the LSP client supports the `additionalTextEdits` (case sensitive) resolve client capability, rust-analyzer computes
|
||||||
|
// the completion edits only when a corresponding completion item is selected.
|
||||||
|
// For clients with no such support, all edits have to be calculated on the completion request, including the fuzzy search completion ones,
|
||||||
|
// which might be slow.
|
||||||
|
//
|
||||||
|
// .Feature toggle
|
||||||
|
//
|
||||||
|
// The feature can be turned off in the settings with the `rust-analyzer.completion.enableExperimental` flag.
|
||||||
fn fuzzy_completion(acc: &mut Completions, ctx: &CompletionContext) -> Option<()> {
|
fn fuzzy_completion(acc: &mut Completions, ctx: &CompletionContext) -> Option<()> {
|
||||||
let _p = profile::span("fuzzy_completion");
|
let _p = profile::span("fuzzy_completion");
|
||||||
let current_module = ctx.scope.module()?;
|
let current_module = ctx.scope.module()?;
|
||||||
|
|
Loading…
Reference in a new issue