// Test that if a struct declares multiple region bounds for a given // type parameter, an explicit lifetime bound is required on object // lifetimes within. #![allow(dead_code)] trait Test { fn foo(&self) { } } struct Ref0 { r: *mut T } struct Ref1<'a,T:'a+?Sized> { r: &'a T } struct Ref2<'a,'b:'a,T:'a+'b+?Sized> { r: &'a &'b T } fn a<'a,'b>(t: Ref2<'a,'b, dyn Test>) { //~^ ERROR lifetime bound for this object type cannot be deduced from context } fn b(t: Ref2) { //~^ ERROR lifetime bound for this object type cannot be deduced from context } fn c(t: Ref2<&dyn Test>) { // In this case, the &'a overrides. } fn d(t: Ref2>) { // In this case, the lifetime parameter from the Ref1 overrides. } fn e(t: Ref2>) { // In this case, Ref2 is ambiguous, but Ref0 overrides with 'static. } fn f(t: &Ref2) { //~^ ERROR lifetime bound for this object type cannot be deduced from context } fn main() { }