nu_utils/
casing.rs

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
use std::cmp::Ordering;
use unicase::UniCase;

pub trait IgnoreCaseExt {
    /// Returns a [case folded] equivalent of this string, as a new String.
    ///
    /// Case folding is primarily based on lowercase mapping, but includes
    /// additional changes to the source text to help make case folding
    /// language-invariant and consistent. Case folded text should be used
    /// solely for processing and generally should not be stored or displayed.
    ///
    /// [case folded]: <https://unicode.org/faq/casemap_charprop.html#2>
    fn to_folded_case(&self) -> String;

    /// Checks that two strings are a case-insensitive match.
    ///
    /// Essentially `to_folded_case(a) == to_folded_case(b)`, but without
    /// allocating and copying string temporaries. Because case folding involves
    /// Unicode table lookups, it can sometimes be more efficient to use
    /// `to_folded_case` to case fold once and then compare those strings.
    fn eq_ignore_case(&self, other: &str) -> bool;

    /// Compares two strings case-insensitively.
    ///
    /// Essentially `to_folded_case(a) == to_folded_case(b)`, but without
    /// allocating and copying string temporaries. Because case folding involves
    /// Unicode table lookups, it can sometimes be more efficient to use
    /// `to_folded_case` to case fold once and then compare those strings.
    ///
    /// Note that this *only* ignores case, comparing the folded strings without
    /// any other collation data or locale, so the sort order may be surprising
    /// outside of ASCII characters.
    fn cmp_ignore_case(&self, other: &str) -> Ordering;
}

impl IgnoreCaseExt for str {
    fn to_folded_case(&self) -> String {
        UniCase::new(self).to_folded_case()
    }

    fn eq_ignore_case(&self, other: &str) -> bool {
        UniCase::new(self) == UniCase::new(other)
    }

    fn cmp_ignore_case(&self, other: &str) -> Ordering {
        UniCase::new(self).cmp(&UniCase::new(other))
    }
}