1use core::fmt::{self, Debug, Formatter};
4
5pub(crate) const MAX_PARAMS: usize = 32;
6
7#[derive(#[automatically_derived]
impl ::core::default::Default for Params {
#[inline]
fn default() -> Params {
Params {
subparams: ::core::default::Default::default(),
params: ::core::default::Default::default(),
current_subparams: ::core::default::Default::default(),
len: ::core::default::Default::default(),
}
}
}Default, #[automatically_derived]
impl ::core::clone::Clone for Params {
#[inline]
fn clone(&self) -> Params {
Params {
subparams: ::core::clone::Clone::clone(&self.subparams),
params: ::core::clone::Clone::clone(&self.params),
current_subparams: ::core::clone::Clone::clone(&self.current_subparams),
len: ::core::clone::Clone::clone(&self.len),
}
}
}Clone, #[automatically_derived]
impl ::core::cmp::PartialEq for Params {
#[inline]
fn eq(&self, other: &Params) -> bool {
self.current_subparams == other.current_subparams &&
self.subparams == other.subparams &&
self.params == other.params && self.len == other.len
}
}PartialEq, #[automatically_derived]
impl ::core::cmp::Eq for Params {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {
let _: ::core::cmp::AssertParamIsEq<[u8; MAX_PARAMS]>;
let _: ::core::cmp::AssertParamIsEq<[u16; MAX_PARAMS]>;
let _: ::core::cmp::AssertParamIsEq<u8>;
let _: ::core::cmp::AssertParamIsEq<usize>;
}
}Eq)]
8pub struct Params {
9 subparams: [u8; MAX_PARAMS],
16
17 params: [u16; MAX_PARAMS],
19
20 current_subparams: u8,
22
23 len: usize,
25}
26
27impl Params {
28 #[inline]
30 pub fn len(&self) -> usize {
31 self.len
32 }
33
34 #[inline]
36 pub fn is_empty(&self) -> bool {
37 self.len == 0
38 }
39
40 #[inline]
42 pub fn iter(&self) -> ParamsIter<'_> {
43 ParamsIter::new(self)
44 }
45
46 #[inline]
48 pub(crate) fn is_full(&self) -> bool {
49 self.len == MAX_PARAMS
50 }
51
52 #[inline]
54 pub(crate) fn clear(&mut self) {
55 self.current_subparams = 0;
56 self.len = 0;
57 }
58
59 #[inline]
61 pub(crate) fn push(&mut self, item: u16) {
62 self.subparams[self.len - self.current_subparams as usize] = self.current_subparams + 1;
63 self.params[self.len] = item;
64 self.current_subparams = 0;
65 self.len += 1;
66 }
67
68 #[inline]
70 pub(crate) fn extend(&mut self, item: u16) {
71 self.subparams[self.len - self.current_subparams as usize] = self.current_subparams + 1;
72 self.params[self.len] = item;
73 self.current_subparams += 1;
74 self.len += 1;
75 }
76}
77
78impl<'a> IntoIterator for &'a Params {
79 type IntoIter = ParamsIter<'a>;
80 type Item = &'a [u16];
81
82 fn into_iter(self) -> Self::IntoIter {
83 self.iter()
84 }
85}
86
87pub struct ParamsIter<'a> {
89 params: &'a Params,
90 index: usize,
91}
92
93impl<'a> ParamsIter<'a> {
94 fn new(params: &'a Params) -> Self {
95 Self { params, index: 0 }
96 }
97}
98
99impl<'a> Iterator for ParamsIter<'a> {
100 type Item = &'a [u16];
101
102 fn next(&mut self) -> Option<Self::Item> {
103 if self.index >= self.params.len() {
104 return None;
105 }
106
107 let num_subparams = self.params.subparams[self.index];
109 let param = &self.params.params[self.index..self.index + num_subparams as usize];
110
111 self.index += num_subparams as usize;
113
114 Some(param)
115 }
116
117 fn size_hint(&self) -> (usize, Option<usize>) {
118 let remaining = self.params.len() - self.index;
119 (remaining, Some(remaining))
120 }
121}
122
123impl Debug for Params {
124 fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
125 f.write_fmt(format_args!("["))write!(f, "[")?;
126
127 for (i, param) in self.iter().enumerate() {
128 if i != 0 {
129 f.write_fmt(format_args!(";"))write!(f, ";")?;
130 }
131
132 for (i, subparam) in param.iter().enumerate() {
133 if i != 0 {
134 f.write_fmt(format_args!(":"))write!(f, ":")?;
135 }
136
137 subparam.fmt(f)?;
138 }
139 }
140
141 f.write_fmt(format_args!("]"))write!(f, "]")
142 }
143}