// 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 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. #![feature(managed_boxes)] extern crate collections; extern crate time; use time::precise_time_s; use std::os; use std::task; use std::vec; #[deriving(Clone)] enum List { Nil, Cons(T, @List) } enum UniqueList { ULNil, ULCons(Box) } fn main() { let (repeat, depth) = if os::getenv("RUST_BENCH").is_some() { (50, 1000) } else { (10, 10) }; run(repeat, depth); } fn run(repeat: int, depth: int) { for _ in range(0, repeat) { println!("starting {:.4f}", precise_time_s()); task::try(proc() { recurse_or_fail(depth, None) }); println!("stopping {:.4f}", precise_time_s()); } } type nillist = List<()>; // Filled with things that have to be unwound struct State { managed: @nillist, unique: Box, tuple: (@nillist, Box), vec: Vec<@nillist>, res: r } struct r { _l: @nillist, } #[unsafe_destructor] impl Drop for r { fn drop(&mut self) {} } fn r(l: @nillist) -> r { r { _l: l } } fn recurse_or_fail(depth: int, st: Option) { if depth == 0 { println!("unwinding {:.4f}", precise_time_s()); fail!(); } else { let depth = depth - 1; let st = match st { None => { State { managed: @Nil, unique: box Nil, tuple: (@Nil, box Nil), vec: vec!(@Nil), res: r(@Nil) } } Some(st) => { State { managed: @Cons((), st.managed), unique: box Cons((), @*st.unique), tuple: (@Cons((), st.tuple.ref0().clone()), box Cons((), @*st.tuple.ref1().clone())), vec: st.vec.clone().append(&[@Cons((), *st.vec.last().unwrap())]), res: r(@Cons((), st.res._l)) } } }; recurse_or_fail(depth, Some(st)); } }