diff options
| author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-02-03 15:01:08 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-02-03 15:01:08 +0000 |
| commit | 5a7e11f5fbc6cdf7af79afe70a94c78b79e366d2 (patch) | |
| tree | a3b1c4408dab97c5fc188b14b046560cc4503818 /src/test/codegen/src-hash-algorithm | |
| parent | 46b5089bfaa9a6b1e72a96c922fa3dec736aeaf5 (diff) | |
| parent | 7619c2afeaac09ced8a55b6f2db21550b80fba5e (diff) | |
| download | rust-5a7e11f5fbc6cdf7af79afe70a94c78b79e366d2.tar.gz rust-5a7e11f5fbc6cdf7af79afe70a94c78b79e366d2.zip | |
Merge #11397
11397: internal: Refactor completion module split r=Veykril a=Veykril Currently our completion infra is split into several modules, each trying to do completions for something specific. This "something" is rather unstructured as it stands now, we have a module for `flyimporting path` completions, `unqualified` and `qualified path` completions, modules for `pattern position` completions that only try to complete extra things for patterns that aren't done in the path modules, `attribute` completions that again only try to add builtin attribute completions without adding the normal path completions and a bunch of other special "entity" completions like lifetimes, method call/field access, function param cloning, ... which serve a more specific purpose than the previous listed ones. As is evident, the former mentioned ones have some decent overlap which requires extra filtering in them so that they don't collide with each other duplicating a bunch of completions(which we had happen in the past at times). Now this overlap mostly happens with path completions(and keyword completions as well in some sense) which gives me the feeling that having `qualified` and `unqualified` path completions be separate from the rest gives us more troubles than benefits in the long run. So this is an attempt at changing this structure to instead still go by rough entity for special cases, but when it comes to paths we instead do the module split on the "path kinds"/"locations"(think pattern, type, expr position etc) that exist. This goes hand in hand with the test refactoring I have done that moved tests to "location oriented" modules as well as the `CompletionContext` refactoring that actually already started splitting the context up for path kinds. This PR moves some path completions out of the `qualified` and `unqualified` path modules namely attribute, visibility, use and pattern paths. Co-authored-by: Lukas Wirth <lukastw97@gmail.com>
Diffstat (limited to 'src/test/codegen/src-hash-algorithm')
0 files changed, 0 insertions, 0 deletions
