2012-12-10 19:32:48 -06:00
|
|
|
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2010-06-23 23:03:09 -05:00
|
|
|
|
2011-06-15 13:19:50 -05:00
|
|
|
|
|
|
|
|
|
|
|
// -*- rust -*-
|
2011-07-27 07:19:39 -05:00
|
|
|
fn f(x: int) -> int {
|
2012-08-22 19:24:52 -05:00
|
|
|
// debug!("in f:");
|
2011-06-15 13:19:50 -05:00
|
|
|
|
2011-12-22 19:53:53 -06:00
|
|
|
log(debug, x);
|
2011-07-27 07:19:39 -05:00
|
|
|
if x == 1 {
|
2012-08-22 19:24:52 -05:00
|
|
|
// debug!("bottoming out");
|
2011-06-15 13:19:50 -05:00
|
|
|
|
2012-08-01 19:30:05 -05:00
|
|
|
return 1;
|
2011-06-15 13:19:50 -05:00
|
|
|
} else {
|
2012-08-22 19:24:52 -05:00
|
|
|
// debug!("recurring");
|
2011-06-15 13:19:50 -05:00
|
|
|
|
2011-07-27 07:19:39 -05:00
|
|
|
let y: int = x * f(x - 1);
|
2012-08-22 19:24:52 -05:00
|
|
|
// debug!("returned");
|
2011-06-15 13:19:50 -05:00
|
|
|
|
2011-12-22 19:53:53 -06:00
|
|
|
log(debug, y);
|
2012-08-01 19:30:05 -05:00
|
|
|
return y;
|
2011-06-15 13:19:50 -05:00
|
|
|
}
|
2010-06-23 23:03:09 -05:00
|
|
|
}
|
|
|
|
|
2013-02-01 21:43:17 -06:00
|
|
|
pub fn main() {
|
2011-06-15 13:19:50 -05:00
|
|
|
assert (f(5) == 120);
|
2012-08-22 19:24:52 -05:00
|
|
|
// debug!("all done");
|
2011-06-15 13:19:50 -05:00
|
|
|
|
2011-08-19 17:16:48 -05:00
|
|
|
}
|