aboutsummaryrefslogtreecommitdiff
path: root/src/lib/_int.rs
diff options
context:
space:
mode:
authorBrian Anderson <[email protected]>2011-03-13 18:29:10 -0400
committerGraydon Hoare <[email protected]>2011-03-14 15:52:48 -0700
commit922f69387dab9f751ab110055d5b9638dbae6a78 (patch)
tree699fef780ab5b74a092b9a0e009e683189771a15 /src/lib/_int.rs
parentMention test/bench in README (diff)
downloadrust-922f69387dab9f751ab110055d5b9638dbae6a78.tar.xz
rust-922f69387dab9f751ab110055d5b9638dbae6a78.zip
Add _int.pow
Diffstat (limited to 'src/lib/_int.rs')
-rw-r--r--src/lib/_int.rs17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/lib/_int.rs b/src/lib/_int.rs
index ee660f01..ef1b3b66 100644
--- a/src/lib/_int.rs
+++ b/src/lib/_int.rs
@@ -34,6 +34,23 @@ fn to_str(mutable int n, uint radix) -> str
}
}
+fn pow(int base, uint exponent) -> int {
+
+ if (exponent == 0u) {
+ ret 1;
+ } else if (base == 0) {
+ ret 0;
+ } else {
+ auto accum = base;
+ auto count = exponent;
+ while (count > 1u) {
+ accum *= base;
+ count -= 1u;
+ }
+ ret accum;
+ }
+}
+
// Local Variables:
// mode: rust;
// fill-column: 78;