1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
use std::cmp::Ordering;
pub trait BaseComparator {
fn compare(&self, a: &[u8], b: &[u8]) -> Ordering;
fn lt(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) == Ordering::Less
}
fn le(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) != Ordering::Greater
}
fn gt(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) == Ordering::Greater
}
fn ge(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) != Ordering::Less
}
fn eq(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) == Ordering::Equal
}
fn ne(&self, a: &[u8], b: &[u8]) -> bool {
self.compare(a, b) != Ordering::Equal
}
}
#[derive(Default)]
pub struct DefaultComparator {}
impl BaseComparator for DefaultComparator {
fn compare(&self, a: &[u8], b: &[u8]) -> Ordering {
if a.eq(b) {
Ordering::Equal
} else if a.gt(b) {
Ordering::Greater
} else {
Ordering::Less
}
}
}
#[cfg(test)]
mod tests {
use super::BaseComparator;
use crate::cmp::DefaultComparator;
use std::cmp::Ordering;
#[test]
fn test_basic() {
let cmp = DefaultComparator::default();
assert_eq!(cmp.compare(&[1], &[2]), Ordering::Less);
assert_eq!(cmp.compare(&[2], &[2]), Ordering::Equal);
assert_eq!(cmp.compare(&[2], &[1]), Ordering::Greater);
}
#[test]
fn test_simplify() {
let cmp = DefaultComparator::default();
assert!(cmp.lt(&[1], &[2]));
assert!(cmp.le(&[2], &[2]));
assert!(cmp.ge(&[2], &[2]));
assert!(cmp.eq(&[2], &[2]));
assert!(cmp.gt(&[2], &[1]));
assert!(cmp.ne(&[2], &[1]));
}
}