rust-analyzer/crates/hir-def/src/nameres
bors d5366b5c19 Auto merge of #16265 - Patryk27:suggest-pub-crate-imports, r=Veykril
fix: Acknowledge `pub(crate)` imports in import suggestions

rust-analyzer has logic that discounts suggesting `use`s for private imports, but that logic is unnecessarily strict - for instance given this code:

```rust
mod foo {
    pub struct Foo;
}

pub(crate) use self::foo::*;

mod bar {
    fn main() {
        Foo$0;
    }
}
```

... RA will suggest to add `use crate::foo::Foo;`, which not only makes the code overly verbose (especially in larger code bases), but also is disjoint with what rustc itself suggests.

This commit adjusts the logic, so that `pub(crate)` imports are taken into account when generating the suggestions; considering rustc's behavior, I think this change doesn't warrant any extra configuration flag.

Note that this is my first commit to RA, so I guess the approach taken here might be suboptimal - certainly feels somewhat hacky, maybe there's some better way of finding out the optimal import path 😅
2024-01-11 09:54:22 +00:00
..
tests internal: Move out WithFixture into dev-dep only crate 2023-12-18 15:24:08 +01:00
attr_resolution.rs Rename some things and turn macro to macro def into a query 2023-12-21 09:18:25 +01:00
collector.rs remove redundant clones 2024-01-07 00:17:48 +01:00
diagnostics.rs Change terminology, do not name use items and use trees as imports 2023-08-02 14:19:38 +02:00
mod_resolution.rs Simplify 2023-12-06 14:36:39 +01:00
path_resolution.rs Suggest pub(crate) imports 2024-01-10 18:21:16 +01:00
proc_macro.rs internal: Move proc-macro knowledge out of base-db 2023-12-18 12:37:18 +01:00
tests.rs internal: Move out WithFixture into dev-dep only crate 2023-12-18 15:24:08 +01:00