De-mode std::{treemap,sort}. Part of #3583.

This commit is contained in:
Graydon Hoare 2012-09-27 18:21:32 -07:00
parent 86041c421d
commit fe62ff465c
3 changed files with 11 additions and 25 deletions

View File

@ -5,12 +5,6 @@
use vec::{len, push}; use vec::{len, push};
use core::cmp::{Eq, Ord}; use core::cmp::{Eq, Ord};
export le;
export merge_sort;
export quick_sort;
export quick_sort3;
export Sort;
type Le<T> = pure fn(v1: &T, v2: &T) -> bool; type Le<T> = pure fn(v1: &T, v2: &T) -> bool;
/** /**
@ -19,7 +13,7 @@ type Le<T> = pure fn(v1: &T, v2: &T) -> bool;
* Has worst case O(n log n) performance, best case O(n), but * Has worst case O(n log n) performance, best case O(n), but
* is not space efficient. This is a stable sort. * is not space efficient. This is a stable sort.
*/ */
fn merge_sort<T: Copy>(le: Le<T>, v: &[const T]) -> ~[T] { pub fn merge_sort<T: Copy>(le: Le<T>, v: &[const T]) -> ~[T] {
type Slice = (uint, uint); type Slice = (uint, uint);
return merge_sort_(le, v, (0u, len(v))); return merge_sort_(le, v, (0u, len(v)));
@ -93,7 +87,7 @@ fn qsort<T: Copy>(compare_func: Le<T>, arr: &[mut T], left: uint,
* Has worst case O(n^2) performance, average case O(n log n). * Has worst case O(n^2) performance, average case O(n log n).
* This is an unstable sort. * This is an unstable sort.
*/ */
fn quick_sort<T: Copy>(compare_func: Le<T>, arr: &[mut T]) { pub fn quick_sort<T: Copy>(compare_func: Le<T>, arr: &[mut T]) {
if len::<T>(arr) == 0u { return; } if len::<T>(arr) == 0u { return; }
qsort::<T>(compare_func, arr, 0u, len::<T>(arr) - 1u); qsort::<T>(compare_func, arr, 0u, len::<T>(arr) - 1u);
} }
@ -155,12 +149,12 @@ fn qsort3<T: Copy Ord Eq>(arr: &[mut T], left: int, right: int) {
* *
* This is an unstable sort. * This is an unstable sort.
*/ */
fn quick_sort3<T: Copy Ord Eq>(arr: &[mut T]) { pub fn quick_sort3<T: Copy Ord Eq>(arr: &[mut T]) {
if arr.len() <= 1 { return; } if arr.len() <= 1 { return; }
qsort3(arr, 0, (arr.len() - 1) as int); qsort3(arr, 0, (arr.len() - 1) as int);
} }
trait Sort { pub trait Sort {
fn qsort(self); fn qsort(self);
} }
@ -274,7 +268,7 @@ mod tests {
fn check_sort(v1: &[int], v2: &[int]) { fn check_sort(v1: &[int], v2: &[int]) {
let len = vec::len::<int>(v1); let len = vec::len::<int>(v1);
pure fn le(a: &int, b: &int) -> bool { *a <= *b } pub pure fn le(a: &int, b: &int) -> bool { *a <= *b }
let f = le; let f = le;
let v3 = merge_sort::<int>(f, v1); let v3 = merge_sort::<int>(f, v1);
let mut i = 0u; let mut i = 0u;
@ -304,7 +298,7 @@ mod tests {
#[test] #[test]
fn test_merge_sort_mutable() { fn test_merge_sort_mutable() {
pure fn le(a: &int, b: &int) -> bool { *a <= *b } pub pure fn le(a: &int, b: &int) -> bool { *a <= *b }
let v1 = ~[mut 3, 2, 1]; let v1 = ~[mut 3, 2, 1];
let v2 = merge_sort(le, v1); let v2 = merge_sort(le, v1);
assert v2 == ~[1, 2, 3]; assert v2 == ~[1, 2, 3];

View File

@ -98,11 +98,8 @@ mod map;
mod rope; mod rope;
#[legacy_exports] #[legacy_exports]
mod smallintmap; mod smallintmap;
#[legacy_exports]
mod sort; mod sort;
#[legacy_exports]
mod treemap; mod treemap;
#[legacy_exports]
// And ... other stuff // And ... other stuff

View File

@ -12,12 +12,7 @@ use core::cmp::{Eq, Ord};
use core::option::{Some, None}; use core::option::{Some, None};
use Option = core::Option; use Option = core::Option;
export TreeMap; pub type TreeMap<K, V> = @mut TreeEdge<K, V>;
export insert;
export find;
export traverse;
type TreeMap<K, V> = @mut TreeEdge<K, V>;
type TreeEdge<K, V> = Option<@TreeNode<K, V>>; type TreeEdge<K, V> = Option<@TreeNode<K, V>>;
@ -29,10 +24,10 @@ enum TreeNode<K, V> = {
}; };
/// Create a treemap /// Create a treemap
fn TreeMap<K, V>() -> TreeMap<K, V> { @mut None } pub fn TreeMap<K, V>() -> TreeMap<K, V> { @mut None }
/// Insert a value into the map /// Insert a value into the map
fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) { pub fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) {
match copy *m { match copy *m {
None => { None => {
*m = Some(@TreeNode({key: k, *m = Some(@TreeNode({key: k,
@ -54,7 +49,7 @@ fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) {
} }
/// Find a value based on the key /// Find a value based on the key
fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K) pub fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K)
-> Option<V> { -> Option<V> {
match copy *m { match copy *m {
None => None, None => None,
@ -73,7 +68,7 @@ fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K)
} }
/// Visit all pairs in the map in order. /// Visit all pairs in the map in order.
fn traverse<K, V: Copy>(m: &const TreeEdge<K, V>, f: fn((&K), (&V))) { pub fn traverse<K, V: Copy>(m: &const TreeEdge<K, V>, f: fn((&K), (&V))) {
match copy *m { match copy *m {
None => (), None => (),
Some(node) => { Some(node) => {