Skip to content

Commit

Permalink
Auto merge of rust-lang#80132 - matthewjasper:revert-eval-order, r=ni…
Browse files Browse the repository at this point in the history
…komatsakis

Revert change to trait evaluation order

This change breaks some code and doesn't appear to enable any new code.

closes rust-lang#79902

r? `@nikomatsakis`
  • Loading branch information
bors committed Dec 19, 2020
2 parents bd2f1cb + 3e31ffd commit 1b6b06a
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -334,7 +334,7 @@ impl<'cx, 'tcx> SelectionContext<'cx, 'tcx> {
fn vtable_impl(
&mut self,
impl_def_id: DefId,
mut substs: Normalized<'tcx, SubstsRef<'tcx>>,
substs: Normalized<'tcx, SubstsRef<'tcx>>,
cause: ObligationCause<'tcx>,
recursion_depth: usize,
param_env: ty::ParamEnv<'tcx>,
Expand All @@ -356,9 +356,9 @@ impl<'cx, 'tcx> SelectionContext<'cx, 'tcx> {
// relying on projections in the impl-trait-ref.
//
// e.g., `impl<U: Tr, V: Iterator<Item=U>> Foo<<U as Tr>::T> for V`
substs.obligations.append(&mut impl_obligations);
impl_obligations.extend(substs.obligations);

ImplSourceUserDefinedData { impl_def_id, substs: substs.value, nested: substs.obligations }
ImplSourceUserDefinedData { impl_def_id, substs: substs.value, nested: impl_obligations }
}

fn confirm_object_candidate(
Expand Down
39 changes: 39 additions & 0 deletions src/test/ui/traits/impl-evaluation-order.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
// Regression test for #79902

// Check that evaluation (which is used to determine whether to copy a type in
// MIR building) evaluates bounds from normalizing an impl after evaluating
// any bounds on the impl.

// check-pass

trait A {
type B;
}
trait M {}

struct G<T, U>(*const T, *const U);

impl<T, U> Clone for G<T, U> {
fn clone(&self) -> Self {
G { ..*self }
}
}

impl<T, U> Copy for G<T, U::B>
where
T: A<B = U>,
U: A,
{
}

impl A for () {
type B = ();
}

fn is_m<T: M>(_: T) {}

fn main() {
let x = G(&(), &());
drop(x);
drop(x);
}

0 comments on commit 1b6b06a

Please sign in to comment.