2018-08-30 07:18:55 -05:00
|
|
|
// run-pass
|
2014-06-23 07:17:18 -05:00
|
|
|
// This is a regression test for the ICE from issue #10846.
|
|
|
|
//
|
|
|
|
// The original issue causing the ICE: the LUB-computations during
|
|
|
|
// type inference were encountering late-bound lifetimes, and
|
2014-08-01 18:42:13 -05:00
|
|
|
// asserting that such lifetimes should have already been substituted
|
2014-06-23 07:17:18 -05:00
|
|
|
// with a concrete lifetime.
|
|
|
|
//
|
|
|
|
// However, those encounters were occurring within the lexical scope
|
|
|
|
// of the binding for the late-bound lifetime; that is, the late-bound
|
|
|
|
// lifetimes were perfectly valid. The core problem was that the type
|
|
|
|
// folding code was over-zealously passing back all lifetimes when
|
|
|
|
// doing region-folding, when really all clients of the region-folding
|
|
|
|
// case only want to see FREE lifetime variables, not bound ones.
|
|
|
|
|
2015-03-22 15:13:15 -05:00
|
|
|
// pretty-expanded FIXME #23616
|
|
|
|
|
2014-06-23 07:17:18 -05:00
|
|
|
pub fn main() {
|
|
|
|
fn explicit() {
|
2019-05-28 13:47:21 -05:00
|
|
|
fn test<F>(_x: Option<Box<F>>) where F: FnMut(Box<dyn for<'a> FnMut(&'a isize)>) {}
|
2021-08-24 19:39:40 -05:00
|
|
|
test(Some(Box::new(|_f: Box<dyn for<'a> FnMut(&'a isize)>| {})));
|
2014-06-23 07:17:18 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// The code below is shorthand for the code above (and more likely
|
|
|
|
// to represent what one encounters in practice).
|
|
|
|
fn implicit() {
|
2019-05-28 13:47:21 -05:00
|
|
|
fn test<F>(_x: Option<Box<F>>) where F: FnMut(Box<dyn FnMut(& isize)>) {}
|
2021-08-24 19:39:40 -05:00
|
|
|
test(Some(Box::new(|_f: Box<dyn FnMut(& isize)>| {})));
|
2014-06-23 07:17:18 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
explicit();
|
|
|
|
implicit();
|
|
|
|
}
|