2011-10-27 14:54:18 -07:00
|
|
|
/*
|
|
|
|
Module: u64
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2011-11-16 02:10:43 +01:00
|
|
|
Const: min_value
|
2011-10-27 14:54:18 -07:00
|
|
|
|
|
|
|
Return the minimal value for a u64
|
|
|
|
*/
|
2011-11-16 02:10:43 +01:00
|
|
|
const min_value: u64 = 0u64;
|
2011-10-17 14:43:32 +02:00
|
|
|
|
2011-10-27 14:54:18 -07:00
|
|
|
/*
|
2011-11-16 02:10:43 +01:00
|
|
|
Const: max_value
|
2011-10-27 14:54:18 -07:00
|
|
|
|
|
|
|
Return the maximal value for a u64
|
|
|
|
*/
|
2011-11-16 02:10:43 +01:00
|
|
|
const max_value: u64 = 18446744073709551615u64;
|
2011-10-27 14:54:18 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
Function: to_str
|
|
|
|
|
|
|
|
Convert to a string in a given base
|
|
|
|
*/
|
2011-09-02 15:34:58 -07:00
|
|
|
fn to_str(n: u64, radix: uint) -> str {
|
2011-07-27 14:19:39 +02:00
|
|
|
assert (0u < radix && radix <= 16u);
|
2011-07-08 12:18:54 -07:00
|
|
|
|
2011-07-27 14:19:39 +02:00
|
|
|
let r64 = radix as u64;
|
2011-07-13 15:44:09 -07:00
|
|
|
|
2011-09-02 15:34:58 -07:00
|
|
|
fn digit(n: u64) -> str {
|
2011-07-27 14:19:39 +02:00
|
|
|
ret alt n {
|
2011-09-02 15:34:58 -07:00
|
|
|
0u64 { "0" }
|
|
|
|
1u64 { "1" }
|
|
|
|
2u64 { "2" }
|
|
|
|
3u64 { "3" }
|
|
|
|
4u64 { "4" }
|
|
|
|
5u64 { "5" }
|
|
|
|
6u64 { "6" }
|
|
|
|
7u64 { "7" }
|
|
|
|
8u64 { "8" }
|
|
|
|
9u64 { "9" }
|
|
|
|
10u64 { "a" }
|
|
|
|
11u64 { "b" }
|
|
|
|
12u64 { "c" }
|
|
|
|
13u64 { "d" }
|
|
|
|
14u64 { "e" }
|
|
|
|
15u64 { "f" }
|
2011-07-27 14:19:39 +02:00
|
|
|
_ { fail }
|
|
|
|
};
|
2011-07-08 12:18:54 -07:00
|
|
|
}
|
|
|
|
|
2011-09-02 15:34:58 -07:00
|
|
|
if n == 0u64 { ret "0"; }
|
2011-07-08 12:18:54 -07:00
|
|
|
|
2011-09-02 15:34:58 -07:00
|
|
|
let s = "";
|
2011-07-08 12:18:54 -07:00
|
|
|
|
2011-11-03 10:57:54 +01:00
|
|
|
let n = n;
|
2011-07-27 14:19:39 +02:00
|
|
|
while n > 0u64 { s = digit(n % r64) + s; n /= r64; }
|
2011-07-08 12:18:54 -07:00
|
|
|
ret s;
|
|
|
|
}
|
|
|
|
|
2011-10-27 14:54:18 -07:00
|
|
|
/*
|
|
|
|
Function: str
|
|
|
|
|
|
|
|
Convert to a string
|
|
|
|
*/
|
2011-09-02 15:34:58 -07:00
|
|
|
fn str(n: u64) -> str { ret to_str(n, 10u); }
|