Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

alias-relate when normalizing in unnormalized env causes overflow #89

Open
lcnr opened this issue Feb 8, 2024 · 0 comments
Open

alias-relate when normalizing in unnormalized env causes overflow #89

lcnr opened this issue Feb 8, 2024 · 0 comments

Comments

@lcnr
Copy link
Contributor

lcnr commented Feb 8, 2024

We hide impl candidates more frequently in the new solver when compared with the old one as we now correctly handle unnormalized projections.

// revisions: current next
//[next] compile-flags: -Znext-solver
//[next] known-bug: #92505
//[current] check-pass

trait Trait {
    type Assoc;
}

impl<T> Trait for T {
    type Assoc = T;
}

fn impls_trait<T: Trait>() {}

fn foo<T>()
where
    <T as Trait>::Assoc: Trait,
{
    // Trying to use `<T as Trait>::Assoc: Trait` to prove `T: Trait`
    // requires normalizing `<T as Trait>::Assoc`. We do not normalize
    // using impl candidates if there's a where-bound for that trait.
    //
    // We therefore check whether `T: Trait` is proven by the environment.
    // For that we try to apply the `<T as Trait>::Assoc: Trait` candidate,
    // trying to normalize its self type results in overflow.
    //
    // In the old solver we eagerly normalize the environment, ignoring the
    // unnormalized `<T as Trait>::Assoc: Trait` where-bound when normalizing
    // `<T as Trait>::Asosc`.
    impls_trait::<T>();
}

fn main() {}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant