From a9108ebb7661b9145f29a65bc8589b68a7a3b443 Mon Sep 17 00:00:00 2001 From: Andy Russell Date: Sat, 16 Mar 2019 17:05:16 -0400 Subject: [PATCH] filter suggestions from extern prelude --- src/librustc_resolve/lib.rs | 26 ++++++++++++++----- src/test/ui/proc-macro/resolve-error.stderr | 2 +- src/test/ui/suggestions/auxiliary/foo.rs | 3 +++ .../ui/suggestions/no-extern-crate-in-type.rs | 7 +++++ .../no-extern-crate-in-type.stderr | 13 ++++++++++ 5 files changed, 44 insertions(+), 7 deletions(-) create mode 100644 src/test/ui/suggestions/auxiliary/foo.rs create mode 100644 src/test/ui/suggestions/no-extern-crate-in-type.rs create mode 100644 src/test/ui/suggestions/no-extern-crate-in-type.stderr diff --git a/src/librustc_resolve/lib.rs b/src/librustc_resolve/lib.rs index ac149be4b2a89..a4e1b9ad6244c 100644 --- a/src/librustc_resolve/lib.rs +++ b/src/librustc_resolve/lib.rs @@ -4046,13 +4046,27 @@ impl<'a> Resolver<'a> { } else { // Items from the prelude if !module.no_implicit_prelude { - names.extend(self.extern_prelude.iter().map(|(ident, _)| { - TypoSuggestion { - candidate: ident.name, - article: "a", - kind: "crate", - } + names.extend(self.extern_prelude.clone().iter().flat_map(|(ident, _)| { + self.crate_loader + .maybe_process_path_extern(ident.name, ident.span) + .and_then(|crate_id| { + let crate_mod = Def::Mod(DefId { + krate: crate_id, + index: CRATE_DEF_INDEX, + }); + + if filter_fn(crate_mod) { + Some(TypoSuggestion { + candidate: ident.name, + article: "a", + kind: "crate", + }) + } else { + None + } + }) })); + if let Some(prelude) = self.prelude { add_module_candidates(prelude, &mut names); } diff --git a/src/test/ui/proc-macro/resolve-error.stderr b/src/test/ui/proc-macro/resolve-error.stderr index 1e7fd25d0da42..cf7de578c7d42 100644 --- a/src/test/ui/proc-macro/resolve-error.stderr +++ b/src/test/ui/proc-macro/resolve-error.stderr @@ -20,7 +20,7 @@ error: cannot find derive macro `attr_proc_macra` in this scope --> $DIR/resolve-error.rs:44:10 | LL | #[derive(attr_proc_macra)] - | ^^^^^^^^^^^^^^^ help: try: `attr_proc_macro` + | ^^^^^^^^^^^^^^^ error: cannot find macro `FooWithLongNama!` in this scope --> $DIR/resolve-error.rs:49:5 diff --git a/src/test/ui/suggestions/auxiliary/foo.rs b/src/test/ui/suggestions/auxiliary/foo.rs new file mode 100644 index 0000000000000..e90bbef6d5c5f --- /dev/null +++ b/src/test/ui/suggestions/auxiliary/foo.rs @@ -0,0 +1,3 @@ +//! Contains a struct with almost the same name as itself, to trigger Levenshtein suggestions. + +pub struct Foo; diff --git a/src/test/ui/suggestions/no-extern-crate-in-type.rs b/src/test/ui/suggestions/no-extern-crate-in-type.rs new file mode 100644 index 0000000000000..bb93ef4549dc2 --- /dev/null +++ b/src/test/ui/suggestions/no-extern-crate-in-type.rs @@ -0,0 +1,7 @@ +// aux-build:foo.rs + +extern crate foo; + +type Output = Option; //~ ERROR cannot find type `Foo` + +fn main() {} diff --git a/src/test/ui/suggestions/no-extern-crate-in-type.stderr b/src/test/ui/suggestions/no-extern-crate-in-type.stderr new file mode 100644 index 0000000000000..d4a5a956714c9 --- /dev/null +++ b/src/test/ui/suggestions/no-extern-crate-in-type.stderr @@ -0,0 +1,13 @@ +error[E0412]: cannot find type `Foo` in this scope + --> $DIR/no-extern-crate-in-type.rs:5:22 + | +LL | type Output = Option; + | ^^^ not found in this scope +help: possible candidate is found in another module, you can import it into scope + | +LL | use foo::Foo; + | + +error: aborting due to previous error + +For more information about this error, try `rustc --explain E0412`.