about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorLuqman Aden <laden@csclub.uwaterloo.ca>2013-02-24 20:44:01 -0800
committerLuqman Aden <laden@csclub.uwaterloo.ca>2013-02-26 17:23:30 -0800
commitf460c2adf8223fdff2eaa039af8781bcba11e587 (patch)
tree80056dfd5f41381e46475eea5e7efb937406112a /src
parent0a0fcdb018ebee4aa8acb138418ff53c37ce5051 (diff)
downloadrust-f460c2adf8223fdff2eaa039af8781bcba11e587.tar.gz
rust-f460c2adf8223fdff2eaa039af8781bcba11e587.zip
Move levenshtein distance fn to core::str.
Diffstat (limited to 'src')
-rw-r--r--src/libcore/str.rs34
-rw-r--r--src/librustc/middle/resolve.rs36
2 files changed, 35 insertions, 35 deletions
diff --git a/src/libcore/str.rs b/src/libcore/str.rs
index 3c15a89081d..92e980e34d0 100644
--- a/src/libcore/str.rs
+++ b/src/libcore/str.rs
@@ -590,6 +590,40 @@ pub pure fn split_str_nonempty(s: &a/str, sep: &b/str) -> ~[~str] {
     result
 }
 
+/// Levenshtein Distance between two strings
+pub fn levdistance(s: &str, t: &str) -> uint {
+
+    let slen = str::len(s);
+    let tlen = str::len(t);
+
+    if slen == 0 { return tlen; }
+    if tlen == 0 { return slen; }
+
+    let mut dcol = vec::from_fn(tlen + 1, |x| x);
+
+    for str::each_chari(s) |i, sc| {
+
+        let mut current = i;
+        dcol[0] = current + 1;
+
+        for str::each_chari(t) |j, tc| {
+
+            let mut next = dcol[j + 1];
+
+            if sc == tc {
+                dcol[j + 1] = current;
+            } else {
+                dcol[j + 1] = ::cmp::min(current, next);
+                dcol[j + 1] = ::cmp::min(dcol[j + 1], dcol[j]) + 1;
+            }
+
+            current = next;
+        }
+    }
+
+    return dcol[tlen];
+}
+
 /**
  * Splits a string into a vector of the substrings separated by LF ('\n')
  */
diff --git a/src/librustc/middle/resolve.rs b/src/librustc/middle/resolve.rs
index 3db328ceb91..3f1e4dca3a1 100644
--- a/src/librustc/middle/resolve.rs
+++ b/src/librustc/middle/resolve.rs
@@ -4830,44 +4830,10 @@ pub impl Resolver {
             }
         }
 
-        // Levenshtein Distance between two strings
-        fn distance(s: &str, t: &str) -> uint {
-
-            let slen = str::len(s);
-            let tlen = str::len(t);
-
-            if slen == 0 { return tlen; }
-            if tlen == 0 { return slen; }
-
-            let mut dcol = vec::from_fn(tlen + 1, |x| x);
-
-            for str::each_chari(s) |i, sc| {
-
-                let mut current = i;
-                dcol[0] = current + 1;
-
-                for str::each_chari(t) |j, tc| {
-
-                    let mut next = dcol[j + 1];
-
-                    if sc == tc {
-                        dcol[j + 1] = current;
-                    } else {
-                        dcol[j + 1] = cmp::min(current, next);
-                        dcol[j + 1] = cmp::min(dcol[j + 1], dcol[j]) + 1;
-                    }
-
-                    current = next;
-                }
-            }
-
-            return dcol[tlen];
-        }
-
         let mut smallest = 0;
         for vec::eachi(maybes) |i, &other| {
 
-            values[i] = distance(name, other);
+            values[i] = str::levdistance(name, other);
 
             if values[i] <= values[smallest] {
                 smallest = i;