2020-06-08 23:12:01 +00:00
|
|
|
// Test taking the LUB of two function types that are not equatable but where one is more
|
|
|
|
// general than the other. Test the case where the more general type (`x`) is the first
|
|
|
|
// match arm specifically.
|
|
|
|
|
2022-04-01 13:13:25 -04:00
|
|
|
// revisions: leak noleak
|
|
|
|
//[noleak] compile-flags:-Zno-leak-check
|
2022-05-20 02:00:42 -04:00
|
|
|
|
2020-06-08 23:12:01 +00:00
|
|
|
fn foo(x: for<'a, 'b> fn(&'a u8, &'b u8) -> &'a u8, y: for<'a> fn(&'a u8, &'a u8) -> &'a u8) {
|
|
|
|
// The two types above are not equivalent. With the older LUB/GLB
|
|
|
|
// algorithm, this may have worked (I don't remember), but now it
|
|
|
|
// doesn't because we require equality.
|
|
|
|
let z = match 22 {
|
|
|
|
0 => x,
|
2022-05-20 02:00:42 -04:00
|
|
|
_ => y,
|
2022-04-01 13:13:25 -04:00
|
|
|
//[leak]~^ ERROR `match` arms have incompatible types
|
|
|
|
//[noleak]~^^ ERROR mismatched types
|
2020-06-08 23:12:01 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn foo_cast(x: for<'a, 'b> fn(&'a u8, &'b u8) -> &'a u8, y: for<'a> fn(&'a u8, &'a u8) -> &'a u8) {
|
|
|
|
// But we can *upcast* explicitly the type of `x` and figure
|
|
|
|
// things out:
|
|
|
|
let z = match 22 {
|
|
|
|
0 => x as for<'a> fn(&'a u8, &'a u8) -> &'a u8,
|
|
|
|
_ => y,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|