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
77
78
79
80
81
82
|
use criterion::black_box;
use criterion::criterion_group;
use criterion::criterion_main;
use criterion::Criterion;
use unic_langid_impl::parser::parse_language_identifier;
fn language_identifier_parser_bench(c: &mut Criterion) {
let strings = &[
"en-US",
"en-GB",
"es-AR",
"it",
"zh-Hans-CN",
"de-AT",
"pl",
"fr-FR",
"de-AT",
"sr-Cyrl-SR",
"nb-NO",
"fr-FR",
"mk",
"uk",
"en-US",
"en-GB",
"es-AR",
"th",
"de",
"zh-Cyrl-HN",
"en-Latn-US",
];
c.bench_function("language_identifier_parser", |b| {
let slices: Vec<&[u8]> = strings.iter().map(|s| s.as_bytes()).collect();
b.iter(|| {
for s in &slices {
let _ = parse_language_identifier(black_box(s));
}
})
});
}
fn language_identifier_parser_casing_bench(c: &mut Criterion) {
let strings = &[
"En_uS",
"EN-GB",
"ES-aR",
"iT",
"zH_HaNs_cN",
"dE-aT",
"Pl",
"FR-FR",
"de_AT",
"sR-CyrL_sr",
"NB-NO",
"fr_fr",
"Mk",
"uK",
"en-us",
"en_gb",
"ES-AR",
"tH",
"DE",
"ZH_cyrl_hN",
"eN-lAtN-uS",
];
c.bench_function("language_identifier_parser_casing", |b| {
let slices: Vec<&[u8]> = strings.iter().map(|s| s.as_bytes()).collect();
b.iter(|| {
for s in &slices {
let _ = parse_language_identifier(black_box(s));
}
})
});
}
criterion_group!(
benches,
language_identifier_parser_bench,
language_identifier_parser_casing_bench,
);
criterion_main!(benches);
|