blob: 32ad0fb4d4107826d4f4221e1bac4ad9ee4664a0 [file] [log] [blame]
// run-pass
#![allow(dead_code)]
// B and C both require A, so D does as well, twice, but that's just fine
trait A { fn a(&self) -> isize; }
trait B: A { fn b(&self) -> isize; }
trait C: A { fn c(&self) -> isize; }
trait D: B + C { fn d(&self) -> isize; }
struct S { bogus: () }
impl A for S { fn a(&self) -> isize { 10 } }
impl B for S { fn b(&self) -> isize { 20 } }
impl C for S { fn c(&self) -> isize { 30 } }
impl D for S { fn d(&self) -> isize { 40 } }
fn f<T:D>(x: &T) {
assert_eq!(x.a(), 10);
assert_eq!(x.b(), 20);
assert_eq!(x.c(), 30);
assert_eq!(x.d(), 40);
}
pub fn main() {
let value = &S { bogus: () };
f(value);
}