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 ); // This would result in an error, but it is not reported by typeck // anymore but rather borrowck. Therefore, it doesn't end up // getting printed out since compilation fails after typeck. // // 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 `&