blob: c34a6aebc074cce46ed2e371ca94d6cc8f0f0f71 (
plain)
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
|
// This file is part of ICU4X. For terms of use, please see the file
// called LICENSE at the top level of the ICU4X source tree
// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).
use iai::black_box;
#[path = "../src/samples.rs"]
mod samples;
use samples::*;
use zerovec::ule::VarULE;
use zerovec::VarZeroSlice;
use zerovec::ZeroVec;
fn sum_slice() -> u32 {
black_box(TEST_SLICE).iter().sum::<u32>()
}
fn sum_zerovec() -> u32 {
ZeroVec::<u32>::parse_byte_slice(black_box(TEST_BUFFER_LE))
.unwrap()
.iter()
.sum::<u32>()
}
fn binarysearch_slice() -> Result<usize, usize> {
black_box(TEST_SLICE).binary_search(&0x0c0d0c)
}
fn binarysearch_zerovec() -> Result<usize, usize> {
ZeroVec::<u32>::parse_byte_slice(black_box(TEST_BUFFER_LE))
.unwrap()
.binary_search(&0x0c0d0c)
}
fn varzeroslice_parse_get() -> Option<&'static str> {
let slice: &'static VarZeroSlice<str> =
VarZeroSlice::parse_byte_slice(black_box(TEST_VARZEROSLICE_BYTES)).unwrap();
slice.get(black_box(1))
}
fn varzeroslice_get() -> Option<&'static str> {
// Safety: The bytes are valid.
let slice: &'static VarZeroSlice<str> =
unsafe { VarZeroSlice::from_byte_slice_unchecked(black_box(TEST_VARZEROSLICE_BYTES)) };
slice.get(black_box(1))
}
fn varzeroslice_get_unchecked() -> &'static str {
// Safety: The bytes are valid.
let slice: &'static VarZeroSlice<str> =
unsafe { VarZeroSlice::from_byte_slice_unchecked(black_box(TEST_VARZEROSLICE_BYTES)) };
// Safety: The VarZeroVec has length 4.
unsafe { slice.get_unchecked(black_box(1)) }
}
iai::main!(
sum_slice,
sum_zerovec,
binarysearch_slice,
binarysearch_zerovec,
varzeroslice_parse_get,
varzeroslice_get,
varzeroslice_get_unchecked,
);
|