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;

    /// Less than
    fn lt(&self, a: &[u8], b: &[u8]) -> bool {
        self.compare(a, b) == Ordering::Less
    }

    /// Less than or equal
    fn le(&self, a: &[u8], b: &[u8]) -> bool {
        self.compare(a, b) != Ordering::Greater
    }

    /// Greater than
    fn gt(&self, a: &[u8], b: &[u8]) -> bool {
        self.compare(a, b) == Ordering::Greater
    }

    /// Greater than or equal
    fn ge(&self, a: &[u8], b: &[u8]) -> bool {
        self.compare(a, b) != Ordering::Less
    }

    /// Equal
    fn eq(&self, a: &[u8], b: &[u8]) -> bool {
        self.compare(a, b) == Ordering::Equal
    }

    /// Not 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]));
    }
}