2012-07-11 12:28:30 -05:00
|
|
|
enum ast {
|
2012-04-18 23:26:25 -05:00
|
|
|
num(uint),
|
|
|
|
add(&ast, &ast)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn build() {
|
|
|
|
let x = num(3u);
|
|
|
|
let y = num(4u);
|
|
|
|
let z = add(&x, &y);
|
|
|
|
compute(&z);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn compute(x: &ast) -> uint {
|
|
|
|
alt *x {
|
|
|
|
num(x) { x }
|
|
|
|
add(x, y) { compute(x) + compute(y) }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn map_nums(x: &ast, f: fn(uint) -> uint) -> &ast {
|
|
|
|
alt *x {
|
|
|
|
num(x) {
|
2012-07-26 10:51:57 -05:00
|
|
|
ret &num(f(x)); //~ ERROR illegal borrow
|
2012-04-18 23:26:25 -05:00
|
|
|
}
|
|
|
|
add(x, y) {
|
|
|
|
let m_x = map_nums(x, f);
|
|
|
|
let m_y = map_nums(y, f);
|
2012-07-26 10:51:57 -05:00
|
|
|
ret &add(m_x, m_y); //~ ERROR illegal borrow
|
2012-04-18 23:26:25 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|