|  | // Test that `dyn Bar<Item = XX>` uses `'static` as the default object | 
|  | // lifetime bound for the type `XX`. | 
|  |  | 
|  | trait Foo<'a> { | 
|  | type Item: 'a + ?Sized; | 
|  |  | 
|  | fn item(&self) -> Box<Self::Item> { panic!() } | 
|  | } | 
|  |  | 
|  | trait Bar { } | 
|  |  | 
|  | impl<T> Foo<'_> for T { | 
|  | type Item = dyn Bar; | 
|  | } | 
|  |  | 
|  | fn is_static<T>(_: T) where T: 'static { } | 
|  |  | 
|  | // Here, we default to `dyn Bar + 'a`.  Or, we *should*, but the | 
|  | // current code forces us into a conservative, hacky path. | 
|  | fn bar<'a>(x: &'a str) -> &'a dyn Foo<'a, Item = dyn Bar> { &() } | 
|  | //~^ ERROR please supply an explicit bound | 
|  |  | 
|  | fn main() { | 
|  | let s = format!("foo"); | 
|  | let r = bar(&s); | 
|  |  | 
|  | // If it weren't for the conservative path above, we'd expect an | 
|  | // error here. | 
|  | is_static(r.item()); | 
|  | } |