Unnamed repository; edit this file 'description' to name the repository.
Auto merge of #11988 - jonas-schievink:expand-glob, r=jonas-schievink
minor: reenable simplify glob import test
bors 2022-04-14
parent 5620d25 · parent 72dcfe6 · commit 4cee507
-rw-r--r--crates/ide_assists/src/handlers/expand_glob_import.rs75
1 files changed, 33 insertions, 42 deletions
diff --git a/crates/ide_assists/src/handlers/expand_glob_import.rs b/crates/ide_assists/src/handlers/expand_glob_import.rs
index 3566b1be89..ba5a47f4df 100644
--- a/crates/ide_assists/src/handlers/expand_glob_import.rs
+++ b/crates/ide_assists/src/handlers/expand_glob_import.rs
@@ -52,7 +52,7 @@ pub(crate) fn expand_glob_import(acc: &mut Assists, ctx: &AssistContext) -> Opti
let current_scope = ctx.sema.scope(&star.parent()?)?;
let current_module = current_scope.module();
- let refs_in_target = find_refs_in_mod(ctx, target_module, Some(current_module))?;
+ let refs_in_target = find_refs_in_mod(ctx, target_module, current_module)?;
let imported_defs = find_imported_defs(ctx, star)?;
let target = parent.either(|n| n.syntax().clone(), |n| n.syntax().clone());
@@ -168,18 +168,12 @@ impl Refs {
}
}
-fn find_refs_in_mod(
- ctx: &AssistContext,
- module: Module,
- visible_from: Option<Module>,
-) -> Option<Refs> {
- if let Some(from) = visible_from {
- if !is_mod_visible_from(ctx, module, from) {
- return None;
- }
+fn find_refs_in_mod(ctx: &AssistContext, module: Module, visible_from: Module) -> Option<Refs> {
+ if !is_mod_visible_from(ctx, module, visible_from) {
+ return None;
}
- let module_scope = module.scope(ctx.db(), visible_from);
+ let module_scope = module.scope(ctx.db(), Some(visible_from));
let refs = module_scope.into_iter().filter_map(|(n, d)| Ref::from_scope_def(n, d)).collect();
Some(Refs(refs))
}
@@ -729,37 +723,34 @@ fn qux(bar: Bar, baz: Baz) {
#[test]
fn expanding_glob_import_with_macro_defs() {
- // FIXME: this is currently fails because `Definition::find_usages` ignores macros
- // https://github.com/rust-analyzer/rust-analyzer/issues/3484
- //
- // check_assist(
- // expand_glob_import,
- // r"
- // //- /lib.rs crate:foo
- // #[macro_export]
- // macro_rules! bar {
- // () => ()
- // }
-
- // pub fn baz() {}
-
- // //- /main.rs crate:main deps:foo
- // use foo::*$0;
-
- // fn main() {
- // bar!();
- // baz();
- // }
- // ",
- // r"
- // use foo::{bar, baz};
-
- // fn main() {
- // bar!();
- // baz();
- // }
- // ",
- // )
+ check_assist(
+ expand_glob_import,
+ r#"
+//- /lib.rs crate:foo
+#[macro_export]
+macro_rules! bar {
+ () => ()
+}
+
+pub fn baz() {}
+
+//- /main.rs crate:main deps:foo
+use foo::*$0;
+
+fn main() {
+ bar!();
+ baz();
+}
+"#,
+ r#"
+use foo::{bar, baz};
+
+fn main() {
+ bar!();
+ baz();
+}
+"#,
+ );
}
#[test]