blob: 7e597baa6ec291275d9bd3139a6676ce3f1081e2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
// This is a regression test for issues that came up during review of the (closed)
// PR #132289; this 3-ish-crate (including std) test case is adapted from
// the third example from @steffahn during review.
// https://github.com/rust-lang/rust/pull/132289#issuecomment-2564599221
//@ run-pass
//@ check-run-results
//@ aux-build: pr_review_132289_3_lib.rs
extern crate pr_review_132289_3_lib;
use std::ops::Index;
use pr_review_132289_3_lib::{call, Trait};
trait SubIndex<I>: Index<I> {}
struct Param;
trait Project {
type Ty: ?Sized;
}
impl Project for () {
type Ty = dyn SubIndex<Param, Output = ()>;
}
impl Index<Param> for <() as Project>::Ty {
type Output = ();
fn index(&self, _: Param) -> &() {
&()
}
}
struct Struct;
impl Trait for Struct {
fn f(&self)
where
// higher-ranked to allow potentially-false bounds
for<'a> dyn Index<(), Output = ()>: Index<()>,
// after #132289 rustc used to believe this bound false
{
println!("hello!");
}
}
fn main() {
call(&Struct); // <- would segfault if the method `f` wasn't part of the vtable
}
|