aboutsummaryrefslogtreecommitdiff
path: root/src/lib/deque.rs
diff options
context:
space:
mode:
authorGraydon Hoare <[email protected]>2010-09-22 15:44:13 -0700
committerGraydon Hoare <[email protected]>2010-09-22 15:44:13 -0700
commit2880ecd73ff7443ad72eb7af3c85e673024fc7fd (patch)
treeb9e703a5e279db41fa36bdbe9674abe8f159e91c /src/lib/deque.rs
parentMove llvm-using code in rustc to trans module. (diff)
downloadrust-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.rs234
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: