2010-08-20 11:40:59 -07:00
|
|
|
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn add(uint x, uint y) -> uint { ret x + y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn sub(uint x, uint y) -> uint { ret x - y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn mul(uint x, uint y) -> uint { ret x * y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn div(uint x, uint y) -> uint { ret x / y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn rem(uint x, uint y) -> uint { ret x % y; }
|
|
|
|
|
|
|
|
fn lt(uint x, uint y) -> bool { ret x < y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn le(uint x, uint y) -> bool { ret x <= y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn eq(uint x, uint y) -> bool { ret x == y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn ne(uint x, uint y) -> bool { ret x != y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn ge(uint x, uint y) -> bool { ret x >= y; }
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2010-08-20 11:40:59 -07:00
|
|
|
fn gt(uint x, uint y) -> bool { ret x > y; }
|
|
|
|
|
2011-06-15 11:19:50 -07:00
|
|
|
fn max(uint x, uint y) -> uint { if (x > y) { ret x; } ret y; }
|
2011-05-20 18:36:35 -07:00
|
|
|
|
2011-03-18 13:32:15 -07:00
|
|
|
iter range(uint lo, uint hi) -> uint {
|
|
|
|
auto lo_ = lo;
|
2011-06-15 11:19:50 -07:00
|
|
|
while (lo_ < hi) { put lo_; lo_ += 1u; }
|
2010-08-20 11:40:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
fn next_power_of_two(uint n) -> uint {
|
2010-09-22 15:44:13 -07:00
|
|
|
// FIXME change |* uint(4)| below to |* uint(8) / uint(2)| and watch the
|
|
|
|
// world explode.
|
2011-06-15 11:19:50 -07:00
|
|
|
|
2011-05-12 17:24:54 +02:00
|
|
|
let uint halfbits = sys::rustrt::size_of[uint]() * 4u;
|
2010-09-22 15:44:13 -07:00
|
|
|
let uint tmp = n - 1u;
|
|
|
|
let uint shift = 1u;
|
2011-06-15 11:19:50 -07:00
|
|
|
while (shift <= halfbits) { tmp |= tmp >> shift; shift <<= 1u; }
|
2010-09-22 15:44:13 -07:00
|
|
|
ret tmp + 1u;
|
2010-08-20 11:40:59 -07:00
|
|
|
}
|
|
|
|
|
2011-03-25 18:34:21 -07:00
|
|
|
fn parse_buf(vec[u8] buf, uint radix) -> uint {
|
2011-05-17 20:41:41 +02:00
|
|
|
if (vec::len[u8](buf) == 0u) {
|
2011-04-27 11:59:22 -07:00
|
|
|
log_err "parse_buf(): buf is empty";
|
|
|
|
fail;
|
|
|
|
}
|
2011-05-17 20:41:41 +02:00
|
|
|
auto i = vec::len[u8](buf) - 1u;
|
2011-03-25 18:34:21 -07:00
|
|
|
auto power = 1u;
|
|
|
|
auto n = 0u;
|
2011-04-27 11:45:53 -07:00
|
|
|
while (true) {
|
2011-06-15 11:19:50 -07:00
|
|
|
n += (buf.(i) - ('0' as u8) as uint) * power;
|
2011-03-25 18:34:21 -07:00
|
|
|
power *= radix;
|
2011-04-27 11:45:53 -07:00
|
|
|
if (i == 0u) { ret n; }
|
2011-04-27 11:59:22 -07:00
|
|
|
i -= 1u;
|
2011-03-25 18:34:21 -07:00
|
|
|
}
|
2011-04-27 11:59:22 -07:00
|
|
|
fail;
|
2011-03-25 18:34:21 -07:00
|
|
|
}
|
|
|
|
|
2011-06-15 11:19:50 -07:00
|
|
|
fn to_str(uint num, uint radix) -> str {
|
2011-03-18 13:32:15 -07:00
|
|
|
auto n = num;
|
2011-05-02 17:47:24 -07:00
|
|
|
assert (0u < radix && radix <= 16u);
|
2010-09-22 15:44:13 -07:00
|
|
|
fn digit(uint n) -> char {
|
2011-05-22 01:41:46 -04:00
|
|
|
ret alt (n) {
|
2011-06-15 11:19:50 -07:00
|
|
|
case (0u) { '0' }
|
|
|
|
case (1u) { '1' }
|
|
|
|
case (2u) { '2' }
|
|
|
|
case (3u) { '3' }
|
|
|
|
case (4u) { '4' }
|
|
|
|
case (5u) { '5' }
|
|
|
|
case (6u) { '6' }
|
|
|
|
case (7u) { '7' }
|
|
|
|
case (8u) { '8' }
|
|
|
|
case (9u) { '9' }
|
|
|
|
case (10u) { 'a' }
|
|
|
|
case (11u) { 'b' }
|
|
|
|
case (12u) { 'c' }
|
|
|
|
case (13u) { 'd' }
|
|
|
|
case (14u) { 'e' }
|
|
|
|
case (15u) { 'f' }
|
|
|
|
case (_) { fail }
|
|
|
|
};
|
2010-08-20 11:40:59 -07:00
|
|
|
}
|
2010-09-22 15:44:13 -07:00
|
|
|
if (n == 0u) { ret "0"; }
|
|
|
|
let str s = "";
|
2010-11-09 17:49:20 -08:00
|
|
|
while (n != 0u) {
|
2011-05-17 20:41:41 +02:00
|
|
|
s += str::unsafe_from_byte(digit(n % radix) as u8);
|
2010-11-09 17:49:20 -08:00
|
|
|
n /= radix;
|
2010-09-22 15:44:13 -07:00
|
|
|
}
|
2010-11-09 17:49:20 -08:00
|
|
|
let str s1 = "";
|
2011-05-17 20:41:41 +02:00
|
|
|
let uint len = str::byte_len(s);
|
2011-06-15 11:19:50 -07:00
|
|
|
while (len != 0u) { len -= 1u; s1 += str::unsafe_from_byte(s.(len)); }
|
2010-11-09 17:49:20 -08:00
|
|
|
ret s1;
|
2010-08-20 11:40:59 -07:00
|
|
|
}
|
2010-09-22 15:44:13 -07:00
|
|
|
// Local Variables:
|
|
|
|
// mode: rust;
|
|
|
|
// fill-column: 78;
|
|
|
|
// indent-tabs-mode: nil
|
|
|
|
// c-basic-offset: 4
|
|
|
|
// buffer-file-coding-system: utf-8-unix
|
2011-06-15 12:01:19 -07:00
|
|
|
// compile-command: "make -k -C $RBUILD 2>&1 | sed -e 's/\\/x\\//x:\\//g'";
|
2010-09-22 15:44:13 -07:00
|
|
|
// End:
|