Revert "Revert "resolve: Avoid "self-confirming" import resolutions in one more case""

This reverts commit b20bce8ce5.

It retains the test added in that commit as a check-pass test, intended to
prevent future (unintentional) regressions.
This commit is contained in:
Mark Rousskov 2020-11-05 15:16:12 -05:00
parent b1d9f31e04
commit ae4f80b4be
3 changed files with 16 additions and 26 deletions

View file

@ -872,6 +872,12 @@ impl<'a, 'b> ImportResolver<'a, 'b> {
/// consolidate multiple unresolved import errors into a single diagnostic. /// consolidate multiple unresolved import errors into a single diagnostic.
fn finalize_import(&mut self, import: &'b Import<'b>) -> Option<UnresolvedImportError> { fn finalize_import(&mut self, import: &'b Import<'b>) -> Option<UnresolvedImportError> {
let orig_vis = import.vis.replace(ty::Visibility::Invisible); let orig_vis = import.vis.replace(ty::Visibility::Invisible);
let orig_unusable_binding = match &import.kind {
ImportKind::Single { target_bindings, .. } => {
Some(mem::replace(&mut self.r.unusable_binding, target_bindings[TypeNS].get()))
}
_ => None,
};
let prev_ambiguity_errors_len = self.r.ambiguity_errors.len(); let prev_ambiguity_errors_len = self.r.ambiguity_errors.len();
let path_res = self.r.resolve_path( let path_res = self.r.resolve_path(
&import.module_path, &import.module_path,
@ -882,6 +888,9 @@ impl<'a, 'b> ImportResolver<'a, 'b> {
import.crate_lint(), import.crate_lint(),
); );
let no_ambiguity = self.r.ambiguity_errors.len() == prev_ambiguity_errors_len; let no_ambiguity = self.r.ambiguity_errors.len() == prev_ambiguity_errors_len;
if let Some(orig_unusable_binding) = orig_unusable_binding {
self.r.unusable_binding = orig_unusable_binding;
}
import.vis.set(orig_vis); import.vis.set(orig_vis);
if let PathResult::Failed { .. } | PathResult::NonModule(..) = path_res { if let PathResult::Failed { .. } | PathResult::NonModule(..) = path_res {
// Consider erroneous imports used to avoid duplicate diagnostics. // Consider erroneous imports used to avoid duplicate diagnostics.
@ -892,8 +901,7 @@ impl<'a, 'b> ImportResolver<'a, 'b> {
// Consistency checks, analogous to `finalize_macro_resolutions`. // Consistency checks, analogous to `finalize_macro_resolutions`.
if let Some(initial_module) = import.imported_module.get() { if let Some(initial_module) = import.imported_module.get() {
if !ModuleOrUniformRoot::same_def(module, initial_module) && no_ambiguity { if !ModuleOrUniformRoot::same_def(module, initial_module) && no_ambiguity {
let msg = "inconsistent resolution for an import"; span_bug!(import.span, "inconsistent resolution for an import");
self.r.session.span_err(import.span, msg);
} }
} else if self.r.privacy_errors.is_empty() { } else if self.r.privacy_errors.is_empty() {
let msg = "cannot determine resolution for the import"; let msg = "cannot determine resolution for the import";
@ -913,6 +921,7 @@ impl<'a, 'b> ImportResolver<'a, 'b> {
} }
PathResult::Failed { is_error_from_last_segment: true, span, label, suggestion } => { PathResult::Failed { is_error_from_last_segment: true, span, label, suggestion } => {
if no_ambiguity { if no_ambiguity {
assert!(import.imported_module.get().is_none());
let err = match self.make_path_suggestion( let err = match self.make_path_suggestion(
span, span,
import.module_path.clone(), import.module_path.clone(),

View file

@ -1,3 +1,5 @@
// check-pass
// Minimized case from #62767. // Minimized case from #62767.
mod m { mod m {
pub enum Same { pub enum Same {
@ -9,7 +11,7 @@ use m::*;
// The variant `Same` introduced by this import is also considered when resolving the prefix // The variant `Same` introduced by this import is also considered when resolving the prefix
// `Same::` during import validation to avoid effects similar to time travel (#74556). // `Same::` during import validation to avoid effects similar to time travel (#74556).
use Same::Same; //~ ERROR unresolved import `Same` use Same::Same;
// Case from #74556. // Case from #74556.
mod foo { mod foo {
@ -21,8 +23,8 @@ mod foo {
} }
use foo::*; use foo::*;
use bar::bar; //~ ERROR unresolved import `bar::bar` use bar::bar;
//~| ERROR inconsistent resolution for an import
use bar::foobar; use bar::foobar;
fn main() {} fn main() {}

View file

@ -1,21 +0,0 @@
error: inconsistent resolution for an import
--> $DIR/issue-62767.rs:24:5
|
LL | use bar::bar;
| ^^^^^^^^
error[E0432]: unresolved import `Same`
--> $DIR/issue-62767.rs:12:5
|
LL | use Same::Same;
| ^^^^ `Same` is a variant, not a module
error[E0432]: unresolved import `bar::bar`
--> $DIR/issue-62767.rs:24:5
|
LL | use bar::bar;
| ^^^^^^^^ no `bar` in `foo::bar::bar`
error: aborting due to 3 previous errors
For more information about this error, try `rustc --explain E0432`.