diff options
| author | Graydon Hoare <[email protected]> | 2010-09-22 15:44:13 -0700 |
|---|---|---|
| committer | Graydon Hoare <[email protected]> | 2010-09-22 15:44:13 -0700 |
| commit | 2880ecd73ff7443ad72eb7af3c85e673024fc7fd (patch) | |
| tree | b9e703a5e279db41fa36bdbe9674abe8f159e91c /src/lib/deque.rs | |
| parent | Move llvm-using code in rustc to trans module. (diff) | |
| download | rust-2880ecd73ff7443ad72eb7af3c85e673024fc7fd.tar.xz rust-2880ecd73ff7443ad72eb7af3c85e673024fc7fd.zip | |
Reformat standard library; no code changes.
Diffstat (limited to 'src/lib/deque.rs')
| -rw-r--r-- | src/lib/deque.rs | 234 |
1 files changed, 122 insertions, 112 deletions
diff --git a/src/lib/deque.rs b/src/lib/deque.rs index 96a63880..959339d8 100644 --- a/src/lib/deque.rs +++ b/src/lib/deque.rs @@ -7,132 +7,142 @@ import std._vec; import std._int; type t[T] = obj { - fn size() -> uint; + fn size() -> uint; - fn add_front(&T t); - fn add_back(&T t); + fn add_front(&T t); + fn add_back(&T t); - fn pop_front() -> T; - fn pop_back() -> T; + fn pop_front() -> T; + fn pop_back() -> T; - fn peek_front() -> T; - fn peek_back() -> T; + fn peek_front() -> T; + fn peek_back() -> T; - fn get(int i) -> T; + fn get(int i) -> T; }; fn create[T]() -> t[T] { - type cell[T] = mutable util.option[T]; + type cell[T] = mutable util.option[T]; - let uint initial_capacity = 32u; // 2^5 - - /** - * Grow is only called on full elts, so nelts is also len(elts), unlike - * elsewhere. - */ - fn grow[T](uint nelts, uint lo, vec[cell[T]] elts) -> vec[cell[T]] { - check (nelts == _vec.len[cell[T]](elts)); - - fn fill[T](uint i, uint nelts, uint lo, &vec[cell[T]] old) -> cell[T] { - if (i < nelts) { - ret old.((lo + i) % nelts); - } else { - ret util.none[T]; - } - } - - let uint nalloc = _uint.next_power_of_two(nelts + 1u); - let _vec.init_op[cell[T]] copy_op = bind fill[T](_, nelts, lo, elts); - ret _vec.init_fn[cell[T]](copy_op, nalloc); - } - - fn get[T](vec[cell[T]] elts, uint i) -> T { - alt (elts.(i)) { - case (util.some[T](?t)) { ret t; } - case (_) { fail; } - } - } - - obj deque[T](mutable uint nelts, - mutable uint lo, - mutable uint hi, - mutable vec[cell[T]] elts) - { - fn size() -> uint { ret nelts; } - - fn add_front(&T t) { - let uint oldlo = lo; - - if (lo == 0u) { - lo = _vec.len[cell[T]](elts) - 1u; - } else { - lo -= 1u; - } - - if (lo == hi) { - elts = grow[T](nelts, oldlo, elts); - lo = _vec.len[cell[T]](elts) - 1u; - hi = nelts; - } - - elts.(lo) = util.some[T](t); - nelts += 1u; - } - - fn add_back(&T t) { - if (lo == hi && nelts != 0u) { - elts = grow[T](nelts, lo, elts); - lo = 0u; - hi = nelts; - } - - elts.(hi) = util.some[T](t); - hi = (hi + 1u) % _vec.len[cell[T]](elts); - nelts += 1u; - } + let uint initial_capacity = 32u; // 2^5 /** - * We actually release (turn to none()) the T we're popping so that we - * don't keep anyone's refcount up unexpectedly. + * Grow is only called on full elts, so nelts is also len(elts), unlike + * elsewhere. */ - fn pop_front() -> T { - let T t = get[T](elts, lo); - elts.(lo) = util.none[T]; - lo = (lo + 1u) % _vec.len[cell[T]](elts); - nelts -= 1u; - ret t; - } - - fn pop_back() -> T { - if (hi == 0u) { - hi = _vec.len[cell[T]](elts) - 1u; - } else { - hi -= 1u; - } - - let T t = get[T](elts, hi); - elts.(hi) = util.none[T]; - nelts -= 1u; - ret t; - } - - fn peek_front() -> T { - ret get[T](elts, lo); + fn grow[T](uint nelts, uint lo, vec[cell[T]] elts) -> vec[cell[T]] { + check (nelts == _vec.len[cell[T]](elts)); + + fn fill[T](uint i, uint nelts, uint lo, + &vec[cell[T]] old) -> cell[T] { + if (i < nelts) { + ret old.((lo + i) % nelts); + } else { + ret util.none[T]; + } + } + + let uint nalloc = _uint.next_power_of_two(nelts + 1u); + let _vec.init_op[cell[T]] copy_op = bind fill[T](_, nelts, lo, elts); + ret _vec.init_fn[cell[T]](copy_op, nalloc); } - fn peek_back() -> T { - ret get[T](elts, hi - 1u); + fn get[T](vec[cell[T]] elts, uint i) -> T { + alt (elts.(i)) { + case (util.some[T](?t)) { ret t; } + case (_) { fail; } + } } - fn get(int i) -> T { - let uint idx = (lo + (i as uint)) % _vec.len[cell[T]](elts); - ret get[T](elts, idx); - } - - } - let vec[cell[T]] v = _vec.init_elt[cell[T]](util.none[T], - initial_capacity); - - ret deque[T](0u, 0u, 0u, v); + obj deque[T](mutable uint nelts, + mutable uint lo, + mutable uint hi, + mutable vec[cell[T]] elts) + { + fn size() -> uint { ret nelts; } + + fn add_front(&T t) { + let uint oldlo = lo; + + if (lo == 0u) { + lo = _vec.len[cell[T]](elts) - 1u; + } else { + lo -= 1u; + } + + if (lo == hi) { + elts = grow[T](nelts, oldlo, elts); + lo = _vec.len[cell[T]](elts) - 1u; + hi = nelts; + } + + elts.(lo) = util.some[T](t); + nelts += 1u; + } + + fn add_back(&T t) { + if (lo == hi && nelts != 0u) { + elts = grow[T](nelts, lo, elts); + lo = 0u; + hi = nelts; + } + + elts.(hi) = util.some[T](t); + hi = (hi + 1u) % _vec.len[cell[T]](elts); + nelts += 1u; + } + + /** + * We actually release (turn to none()) the T we're popping so + * that we don't keep anyone's refcount up unexpectedly. + */ + fn pop_front() -> T { + let T t = get[T](elts, lo); + elts.(lo) = util.none[T]; + lo = (lo + 1u) % _vec.len[cell[T]](elts); + nelts -= 1u; + ret t; + } + + fn pop_back() -> T { + if (hi == 0u) { + hi = _vec.len[cell[T]](elts) - 1u; + } else { + hi -= 1u; + } + + let T t = get[T](elts, hi); + elts.(hi) = util.none[T]; + nelts -= 1u; + ret t; + } + + fn peek_front() -> T { + ret get[T](elts, lo); + } + + fn peek_back() -> T { + ret get[T](elts, hi - 1u); + } + + fn get(int i) -> T { + let uint idx = (lo + (i as uint)) % _vec.len[cell[T]](elts); + ret get[T](elts, idx); + } + + } + let vec[cell[T]] v = _vec.init_elt[cell[T]](util.none[T], + initial_capacity); + + ret deque[T](0u, 0u, 0u, v); } + +// Local Variables: +// mode: rust; +// fill-column: 78; +// indent-tabs-mode: nil +// c-basic-offset: 4 +// buffer-file-coding-system: utf-8-unix +// compile-command: "make -k -C .. 2>&1 | sed -e 's/\\/x\\//x:\\//g'"; +// End: |