fn with(t: T, f: fn(T)) { f(t) } fn nested(x: &x.int) { // (1) do with( fn&(x: &x.int, // Refers to the region `x` at (1) y: &y.int, // A fresh region `y` (2) z: fn(x: &x.int, // Refers to `x` at (1) y: &y.int, // Refers to `y` at (2) z: &z.int) -> &z.int) // A fresh region `z` (3) -> &x.int { if false { ret z(x, x, x); } //~ ERROR mismatched types: expected `&y.int` but found `&x.int` if false { ret z(x, x, y); } //~ ERROR mismatched types: expected `&y.int` but found `&x.int` //~^ ERROR mismatched types: expected `&x.int` but found `&y.int` if false { ret z(x, y, x); } if false { ret z(x, y, y); } //~ ERROR mismatched types: expected `&x.int` but found `&y.int` if false { ret z(y, x, x); } //~ ERROR mismatched types: expected `&x.int` but found `&y.int` //~^ ERROR mismatched types: expected `&y.int` but found `&x.int` if false { ret z(y, x, y); } //~ ERROR mismatched types: expected `&x.int` but found `&y.int` //~^ ERROR mismatched types: expected `&y.int` but found `&x.int` //~^^ ERROR mismatched types: expected `&x.int` but found `&y.int` if false { ret z(y, y, x); } //~ ERROR mismatched types: expected `&x.int` but found `&y.int` if false { ret z(y, y, y); } //~ ERROR mismatched types: expected `&x.int` but found `&y.int` //~^ ERROR mismatched types: expected `&x.int` but found `&y.int` fail; } ) |foo| { let a: &x.int = foo(x, x, |_x, _y, z| z ); let b: &x.int = foo(x, a, |_x, _y, z| z ); let c: &x.int = foo(a, a, |_x, _y, z| z ); let z = 3i; let d: &x.int = foo(x, x, |_x, _y, z| z ); let e: &x.int = foo(x, &z, |_x, _y, z| z ); let f: &x.int = foo(&z, &z, |_x, _y, z| z ); //~ ERROR mismatched types: expected `&x.int` but found foo(x, &z, |x, _y, _z| x ); //~ ERROR mismatched types: expected `&z.int` but found `&x.int` foo(x, &z, |_x, y, _z| y ); //~ ERROR mismatched types: expected `&z.int` but found `&