mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 04:45:05 +00:00
Auto merge of #18337 - dqkqd:issue-18287, r=Veykril
fix: private items are shown in completions for modules in fn body Close: #18287
This commit is contained in:
commit
dc2a348bdd
2 changed files with 20 additions and 4 deletions
|
@ -139,13 +139,11 @@ impl Visibility {
|
||||||
let def_map_block = def_map.block_id();
|
let def_map_block = def_map.block_id();
|
||||||
loop {
|
loop {
|
||||||
match (to_module.block, def_map_block) {
|
match (to_module.block, def_map_block) {
|
||||||
// to_module is not a block, so there is no parent def map to use
|
// `to_module` is not a block, so there is no parent def map to use.
|
||||||
(None, _) => (),
|
(None, _) => (),
|
||||||
|
// `to_module` is at `def_map`'s block, no need to move further.
|
||||||
(Some(a), Some(b)) if a == b => {
|
(Some(a), Some(b)) if a == b => {
|
||||||
cov_mark::hit!(is_visible_from_same_block_def_map);
|
cov_mark::hit!(is_visible_from_same_block_def_map);
|
||||||
if let Some(parent) = def_map.parent() {
|
|
||||||
to_module = parent;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
if let Some(parent) = to_module.def_map(db).parent() {
|
if let Some(parent) = to_module.def_map(db).parent() {
|
||||||
|
|
|
@ -923,3 +923,21 @@ fn foo() {
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn private_item_in_module_in_function_body() {
|
||||||
|
check_empty(
|
||||||
|
r#"
|
||||||
|
fn main() {
|
||||||
|
mod foo {
|
||||||
|
struct Private;
|
||||||
|
pub struct Public;
|
||||||
|
}
|
||||||
|
foo::$0
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
expect![[r#"
|
||||||
|
st Public Public
|
||||||
|
"#]],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue