From 6f0fe9b91b8f217bc889f25e44843ff939ce4aa9 Mon Sep 17 00:00:00 2001 From: Fabian Wolff Date: Fri, 18 Jun 2021 18:08:26 +0200 Subject: [PATCH] Fix the ICE described in #83693 --- compiler/rustc_resolve/src/late/lifetimes.rs | 5 +-- src/test/ui/typeck/issue-83693.rs | 19 ++++++++++ src/test/ui/typeck/issue-83693.stderr | 39 ++++++++++++++++++++ src/test/ui/typeck/issue-84768.rs | 10 +++++ src/test/ui/typeck/issue-84768.stderr | 19 ++++++++++ 5 files changed, 89 insertions(+), 3 deletions(-) create mode 100644 src/test/ui/typeck/issue-83693.rs create mode 100644 src/test/ui/typeck/issue-83693.stderr create mode 100644 src/test/ui/typeck/issue-84768.rs create mode 100644 src/test/ui/typeck/issue-84768.stderr diff --git a/compiler/rustc_resolve/src/late/lifetimes.rs b/compiler/rustc_resolve/src/late/lifetimes.rs index ca7cdc4caf505..0638455a8f1bf 100644 --- a/compiler/rustc_resolve/src/late/lifetimes.rs +++ b/compiler/rustc_resolve/src/late/lifetimes.rs @@ -2688,15 +2688,14 @@ impl<'a, 'tcx> LifetimeContext<'a, 'tcx> { Scope::Binder { hir_id, .. } => { break *hir_id; } - Scope::Body { id, .. } => break id.hir_id, Scope::ObjectLifetimeDefault { ref s, .. } | Scope::Elision { ref s, .. } | Scope::Supertrait { ref s, .. } | Scope::TraitRefBoundary { ref s, .. } => { scope = *s; } - Scope::Root => { - // See issue #83907. Just bail out from looking inside. + Scope::Root | Scope::Body { .. } => { + // See issues #83907 and #83693. Just bail out from looking inside. self.tcx.sess.delay_span_bug( rustc_span::DUMMY_SP, "In fn_like_elision without appropriate scope above", diff --git a/src/test/ui/typeck/issue-83693.rs b/src/test/ui/typeck/issue-83693.rs new file mode 100644 index 0000000000000..a4255822056d3 --- /dev/null +++ b/src/test/ui/typeck/issue-83693.rs @@ -0,0 +1,19 @@ +// Regression test for the ICE described in #83693. + +#![feature(fn_traits)] +#![crate_type="lib"] + +impl F { +//~^ ERROR: cannot find type `F` in this scope [E0412] + fn call() { + ::call + //~^ ERROR: cannot find type `TestResult` in this scope [E0412] + //~| associated type bindings are not allowed here [E0229] + } +} + +fn call() { + ::call + //~^ ERROR: cannot find type `x` in this scope [E0412] + //~| ERROR: associated type bindings are not allowed here [E0229] +} diff --git a/src/test/ui/typeck/issue-83693.stderr b/src/test/ui/typeck/issue-83693.stderr new file mode 100644 index 0000000000000..e5ef0d0d59f73 --- /dev/null +++ b/src/test/ui/typeck/issue-83693.stderr @@ -0,0 +1,39 @@ +error[E0412]: cannot find type `F` in this scope + --> $DIR/issue-83693.rs:6:6 + | +LL | impl F { + | ^ help: a trait with a similar name exists: `Fn` + | + ::: $SRC_DIR/core/src/ops/function.rs:LL:COL + | +LL | pub trait Fn: FnMut { + | ------------------------------- similarly named trait `Fn` defined here + +error[E0412]: cannot find type `TestResult` in this scope + --> $DIR/issue-83693.rs:9:22 + | +LL | ::call + | ^^^^^^^^^^ not found in this scope + +error[E0412]: cannot find type `x` in this scope + --> $DIR/issue-83693.rs:16:6 + | +LL | ::call + | ^ not found in this scope + +error[E0229]: associated type bindings are not allowed here + --> $DIR/issue-83693.rs:9:18 + | +LL | ::call + | ^^^^^^^^^^^^^^^ associated type not allowed here + +error[E0229]: associated type bindings are not allowed here + --> $DIR/issue-83693.rs:16:11 + | +LL | ::call + | ^^^^^^^^^^ associated type not allowed here + +error: aborting due to 5 previous errors + +Some errors have detailed explanations: E0229, E0412. +For more information about an error, try `rustc --explain E0229`. diff --git a/src/test/ui/typeck/issue-84768.rs b/src/test/ui/typeck/issue-84768.rs new file mode 100644 index 0000000000000..ffa92823b42f6 --- /dev/null +++ b/src/test/ui/typeck/issue-84768.rs @@ -0,0 +1,10 @@ +// Regression test for the ICE described in #84768. + +#![feature(fn_traits)] +#![crate_type="lib"] + +fn transform_mut(f: F) where F: for<'b> FnOnce(&'b mut u8) { + ::call_once(f, 1) + //~^ ERROR: associated type bindings are not allowed here [E0229] + //~| ERROR: mismatched types [E0308] +} diff --git a/src/test/ui/typeck/issue-84768.stderr b/src/test/ui/typeck/issue-84768.stderr new file mode 100644 index 0000000000000..0a79d539ea962 --- /dev/null +++ b/src/test/ui/typeck/issue-84768.stderr @@ -0,0 +1,19 @@ +error[E0229]: associated type bindings are not allowed here + --> $DIR/issue-84768.rs:7:11 + | +LL | ::call_once(f, 1) + | ^^^^^^^^^^^^^^^ associated type not allowed here + +error[E0308]: mismatched types + --> $DIR/issue-84768.rs:7:42 + | +LL | ::call_once(f, 1) + | ^ expected tuple, found integer + | + = note: expected tuple `(&mut u8,)` + found type `{integer}` + +error: aborting due to 2 previous errors + +Some errors have detailed explanations: E0229, E0308. +For more information about an error, try `rustc --explain E0229`.