File: langid.rs

package info (click to toggle)
rustc-web 1.85.0%2Bdfsg3-1~deb12u3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bookworm-proposed-updates
  • size: 1,759,988 kB
  • sloc: xml: 158,127; python: 35,830; javascript: 19,497; cpp: 19,002; sh: 17,245; ansic: 13,127; asm: 4,376; makefile: 1,056; lisp: 29; perl: 29; ruby: 19; sql: 11
file content (72 lines) | stat: -rw-r--r-- 1,892 bytes parent folder | download | duplicates (38)
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
use unic_langid::LanguageIdentifier;
#[cfg(feature = "unic-langid-macros")]
use unic_langid::{langid, langid_slice, langids};

#[test]
fn basic_test() {
    let loc: LanguageIdentifier = "en-US".parse().expect("Malformed Language Identifier");
    assert_eq!(&loc.to_string(), "en-US");
}

#[test]
#[cfg(feature = "unic-langid-macros")]
fn langid_macro_test() {
    let loc = langid!("en-US");
    assert_eq!(&loc.to_string(), "en-US");

    // ensure it can be used in a const context
    const _: LanguageIdentifier = langid!("en-US");
}

#[test]
#[cfg(feature = "unic-langid-macros")]
fn langids_macro_test() {
    let langids = langids!["en-US", "pl", "de-AT", "Pl-Latn-PL"];
    assert_eq!(langids.len(), 4);
    assert_eq!(langids.get(3).unwrap().language.as_str(), "pl");

    // check trailing comma
    langids!["en-US", "pl",];
}

#[test]
#[cfg(feature = "unic-langid-macros")]
fn langid_slice_macro_test() {
    let langids = langids!["en-US", "pl", "de-AT", "Pl-Latn-PL"];

    // ensure it can be used in a const context
    const CONST_LANGIDS: &[LanguageIdentifier] =
        langid_slice!["en-US", "pl", "de-AT", "Pl-Latn-PL"];
    assert_eq!(CONST_LANGIDS, langids.as_slice());

    // check trailing comma
    let _ = langid_slice!["en-US", "pl",];
}

#[test]
fn langid_ord() {
    let mut input = vec!["en-Latn", "en-US"];

    let mut langids: Vec<LanguageIdentifier> = input.iter().map(|l| l.parse().unwrap()).collect();

    assert_eq!(
        langids
            .iter()
            .map(|l: &LanguageIdentifier| l.to_string())
            .collect::<Vec<_>>(),
        &["en-Latn", "en-US"]
    );

    input.sort();
    assert_eq!(input, &["en-Latn", "en-US"]);

    langids.sort();

    assert_eq!(
        langids
            .iter()
            .map(|l: &LanguageIdentifier| l.to_string())
            .collect::<Vec<_>>(),
        &["en-US", "en-Latn"]
    );
}