// Test cases where we constrain `>::AssocType` to // outlive `'a` and there are no bounds in the trait definition of // `Anything`. This means that the constraint can only be satisfied in two // ways: // // - by ensuring that `T: 'a` and `'b: 'a`, or // - by something in the where clauses. // // As of this writing, the where clause option does not work because // of limitations in our region inferencing system (this is true both // with and without NLL). See `projection_outlives`. // // Ensuring that both `T: 'a` and `'b: 'a` holds does work (`elements_outlive`). // compile-flags:-Zverbose #![allow(warnings)] #![feature(rustc_attrs)] use std::cell::Cell; trait Anything<'a> { type AssocType; } fn with_signature<'a, T, F>(cell: Cell<&'a ()>, t: T, op: F) where F: FnOnce(Cell<&'a ()>, T), { op(cell, t) } fn require<'a, 'b, T>(_cell: Cell<&'a ()>, _t: T) where T: Anything<'b>, T::AssocType: 'a, { } #[rustc_regions] fn no_relationships_late<'a, 'b, T>(cell: Cell<&'a ()>, t: T) where T: Anything<'b>, { with_signature(cell, t, |cell, t| require(cell, t)); //~^ ERROR the parameter type `T` may not live long enough //~| ERROR } #[rustc_regions] fn no_relationships_early<'a, 'b, T>(cell: Cell<&'a ()>, t: T) where T: Anything<'b>, 'a: 'a, { with_signature(cell, t, |cell, t| require(cell, t)); //~^ ERROR the parameter type `T` may not live long enough //~| ERROR } #[rustc_regions] fn projection_outlives<'a, 'b, T>(cell: Cell<&'a ()>, t: T) where T: Anything<'b>, T::AssocType: 'a, { // We are projecting `>::AssocType`, and we know // that this outlives `'a` because of the where-clause. with_signature(cell, t, |cell, t| require(cell, t)); } #[rustc_regions] fn elements_outlive<'a, 'b, T>(cell: Cell<&'a ()>, t: T) where T: Anything<'b>, T: 'a, 'b: 'a, { with_signature(cell, t, |cell, t| require(cell, t)); } fn main() {}