rust-analyzer/crates/ide-completion/src
bors 6b250a22c4 Auto merge of #16687 - kilpkonn:master, r=Veykril
feat: Add "make tuple" tactic to term search

Follow up to https://github.com/rust-lang/rust-analyzer/pull/16092

Now term search also supports tuples.
```rust
let a: i32 = 1;
let b: f64 = 0.0;
let c: (i32, (f64, i32)) = todo!(); // Finds (a, (b, a))
```
In addition to new tactic that handles tuples I changed how the generics are handled.
Previously it tried all possible options from types we had in scope but now it only tries useful ones that help us directly towards the goal or at least towards calling some other function.
This changes O(2^n) to O(n^2) where n is amount of rounds which in practice allows using types that take generics for multiple rounds (previously limited to 1). Average case that also used to be exponential is now roughly linear.
This means that deeply nested generics also work.
````rust
// Finds all valid combos, including `Some(Some(Some(...)))`
let a: Option<Option<Option<bool>>> = todo!();
````

_Note that although the complexity is smaller allowing more types with generics the search overall slows down considerably. I hope it's fine tho as the autocomplete is disabled by default and for code actions it's not super slow. Might have to tweak the depth hyper parameter tho_

This resulted in a huge increase of results found (benchmarks on `ripgrep` crate):
Before
````
Tail Expr syntactic hits: 149/1692 (8%)
Tail Exprs found: 749/1692 (44%)
Term search avg time: 18ms
```
After
```
Tail Expr syntactic hits: 291/1692 (17%)
Tail Exprs found: 1253/1692 (74%)
Term search avg time: 139ms
````

Most changes are local to term search except some tuple related stuff on `hir::Type`.
2024-02-27 09:41:14 +00:00
..
completions internal: Fetch toolchain and datalayout for DetachedFiles 2024-02-20 10:40:39 +01:00
context fix: Fix completions panicking with certain macro setups 2024-02-27 09:35:57 +01:00
render fix: clippy 2024-02-13 10:11:17 +00:00
tests completions: speed up completions by filtering non-applicable traits 2024-02-26 12:49:11 -05:00
completions.rs Cleanup term search related changes 2024-02-11 14:35:54 +02:00
config.rs Optionally disable term search for autocompletion 2024-02-11 13:33:29 +02:00
context.rs fix: Split toolchain and datalayout out of CrateData 2024-02-16 14:48:25 +01:00
item.rs minor: fix typo 2024-02-19 18:12:08 +08:00
lib.rs Add lete to postfix completion list 2024-02-06 13:13:51 +02:00
render.rs Improve generics handling in term search 2024-02-26 20:17:09 +02:00
snippet.rs Always render the path to be imported in the completion detail 2023-12-11 18:37:12 +01:00
tests.rs Optionally disable term search for autocompletion 2024-02-11 13:33:29 +02:00