2018-08-27 15:13:59 -04:00
|
|
|
// Regression test for #53570. Here, we need to propagate that `T: 'a`
|
|
|
|
// but in some versions of NLL we were propagating a stronger
|
|
|
|
// requirement that `T: 'static`. This arose because we actually had
|
|
|
|
// to propagate both that `T: 'a` but also `T: 'b` where `'b` is the
|
|
|
|
// higher-ranked lifetime that appears in the type of the closure
|
|
|
|
// parameter `x` -- since `'b` cannot be expressed in the caller's
|
|
|
|
// space, that got promoted th `'static`.
|
|
|
|
//
|
2019-11-04 00:00:00 +00:00
|
|
|
// check-pass
|
2018-08-27 15:13:59 -04:00
|
|
|
|
|
|
|
use std::cell::{RefCell, Ref};
|
|
|
|
|
|
|
|
trait AnyVec<'a> {
|
|
|
|
}
|
|
|
|
|
|
|
|
trait GenericVec<T> {
|
2019-05-28 14:46:13 -04:00
|
|
|
fn unwrap<'a, 'b>(vec: &'b dyn AnyVec<'a>) -> &'b [T] where T: 'a;
|
2018-08-27 15:13:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
struct Scratchpad<'a> {
|
2019-05-28 14:46:13 -04:00
|
|
|
buffers: RefCell<Box<dyn AnyVec<'a>>>,
|
2018-08-27 15:13:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> Scratchpad<'a> {
|
|
|
|
fn get<T: GenericVec<T>>(&self) -> Ref<[T]>
|
|
|
|
where T: 'a
|
|
|
|
{
|
|
|
|
Ref::map(self.buffers.borrow(), |x| T::unwrap(x.as_ref()))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() { }
|