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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
use core::any::TypeId;
use crate::{
order::BitOrder,
store::BitStore,
};
macro_rules! easy_fmt {
($(impl $fmt:ident)+ for BitArray) => { $(
impl<A, O> core::fmt::$fmt for $crate::array::BitArray<A, O>
where
O: $crate::order::BitOrder,
A: $crate::view::BitViewSized,
{
#[inline]
#[cfg(not(tarpaulin_include))]
fn fmt(&self, fmt: &mut core::fmt::Formatter) -> core::fmt::Result {
core::fmt::$fmt::fmt(self.as_bitslice(), fmt)
}
}
)+ };
($(impl $fmt:ident)+ for $this:ident) => { $(
impl<T, O> core::fmt::$fmt for $this<T, O>
where
O: $crate::order::BitOrder,
T: $crate::store::BitStore,
{
#[inline]
#[cfg(not(tarpaulin_include))]
fn fmt(&self, fmt: &mut core::fmt::Formatter) -> core::fmt::Result {
core::fmt::$fmt::fmt(self.as_bitslice(), fmt)
}
}
)+ };
}
macro_rules! easy_iter {
() => {
#[inline]
fn size_hint(&self) -> (usize, Option<usize>) {
let len = self.len();
(len, Some(len))
}
#[inline]
fn count(self) -> usize {
self.len()
}
#[inline]
fn last(mut self) -> Option<Self::Item> {
self.next_back()
}
};
}
#[inline]
pub fn match_order<O, P>() -> bool
where
O: BitOrder,
P: BitOrder,
{
eq_types::<O, P>()
}
#[inline]
pub fn match_store<T, U>() -> bool
where
T: BitStore,
U: BitStore,
{
eq_types::<T, U>()
}
#[inline]
pub fn match_types<T1, O1, T2, O2>() -> bool
where
O1: BitOrder,
T1: BitStore,
O2: BitOrder,
T2: BitStore,
{
match_order::<O1, O2>() && match_store::<T1, T2>()
}
#[inline]
pub fn is_unsigned<T>() -> bool
where T: 'static {
eq_types::<T, u8>()
|| eq_types::<T, u16>()
|| eq_types::<T, u32>()
|| eq_types::<T, u64>()
|| eq_types::<T, u128>()
|| eq_types::<T, usize>()
}
#[inline]
fn eq_types<T, U>() -> bool
where
T: 'static,
U: 'static,
{
TypeId::of::<T>() == TypeId::of::<U>()
}