rust/tests/ui/higher-rank-trait-bounds/hrtb-cache-issue-54302.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

25 lines
877 B
Rust
Raw Normal View History

// Regression test for #54302.
//
// We were incorrectly using the "evaluation cache" (which ignored
// region results) to conclude that `&'static str: Deserialize`, even
// though it would require that `for<'de> 'de: 'static`, which is
// clearly false.
trait Deserialize<'de> {}
trait DeserializeOwned: for<'de> Deserialize<'de> {}
impl<T> DeserializeOwned for T where T: for<'de> Deserialize<'de> {}
// Based on this impl, `&'static str` only implements Deserialize<'static>.
// It does not implement for<'de> Deserialize<'de>.
impl<'de: 'a, 'a> Deserialize<'de> for &'a str {}
fn main() {
fn assert_deserialize_owned<T: DeserializeOwned>() {}
assert_deserialize_owned::<&'static str>(); //~ ERROR
// It correctly does not implement for<'de> Deserialize<'de>.
// fn assert_hrtb<T: for<'de> Deserialize<'de>>() {}
// assert_hrtb::<&'static str>();
}