2012-09-18 15:52:21 -07:00
|
|
|
#[legacy_modes];
|
|
|
|
|
2012-07-11 10:28:30 -07:00
|
|
|
enum ast {
|
2012-04-18 21:26:25 -07: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 {
|
2012-08-06 12:34:08 -07:00
|
|
|
match *x {
|
2012-08-03 19:59:04 -07:00
|
|
|
num(x) => { x }
|
|
|
|
add(x, y) => { compute(x) + compute(y) }
|
2012-04-18 21:26:25 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn map_nums(x: &ast, f: fn(uint) -> uint) -> &ast {
|
2012-08-06 12:34:08 -07:00
|
|
|
match *x {
|
2012-08-03 19:59:04 -07:00
|
|
|
num(x) => {
|
2012-08-01 17:30:05 -07:00
|
|
|
return &num(f(x)); //~ ERROR illegal borrow
|
2012-04-18 21:26:25 -07:00
|
|
|
}
|
2012-08-03 19:59:04 -07:00
|
|
|
add(x, y) => {
|
2012-04-18 21:26:25 -07:00
|
|
|
let m_x = map_nums(x, f);
|
|
|
|
let m_y = map_nums(y, f);
|
2012-08-01 17:30:05 -07:00
|
|
|
return &add(m_x, m_y); //~ ERROR illegal borrow
|
2012-04-18 21:26:25 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-09-18 15:52:21 -07:00
|
|
|
fn main() {}
|