1use serde::de::{self, IntoDeserializer};
4
5use crate::error::Error;
6use crate::float::{FloatPolicy, FloatRepr};
7use crate::key::{Float, Integer, Key};
8
9pub fn from_key<T, F>(value: &Key<F>) -> Result<T, crate::error::Error>
83where
84 T: de::DeserializeOwned,
85 F: FloatPolicy,
86{
87 T::deserialize(Deserializer::new(value))
88}
89
90impl<'de, F> IntoDeserializer<'de, Error> for &'de Key<F>
91where
92 F: FloatPolicy,
93{
94 type Deserializer = Deserializer<'de, F>;
95
96 fn into_deserializer(self) -> Self::Deserializer {
97 Deserializer::new(self)
98 }
99}
100
101pub struct Deserializer<'de, F>
102where
103 F: FloatPolicy,
104{
105 value: &'de Key<F>,
106}
107
108impl<'de, F> Deserializer<'de, F>
109where
110 F: FloatPolicy,
111{
112 pub fn new(value: &'de Key<F>) -> Self {
113 Self { value }
114 }
115}
116
117impl<'de, F> de::Deserializer<'de> for Deserializer<'de, F>
118where
119 F: FloatPolicy,
120{
121 type Error = Error;
122
123 #[inline]
124 fn deserialize_any<V>(self, visitor: V) -> Result<V::Value, Error>
125 where
126 V: de::Visitor<'de>,
127 {
128 return match self.value {
129 Key::Unit => visitor.visit_unit(),
130 Key::Bool(b) => visitor.visit_bool(*b),
131 Key::Integer(Integer::U8(v)) => visitor.visit_u8(*v),
132 Key::Integer(Integer::U16(v)) => visitor.visit_u16(*v),
133 Key::Integer(Integer::U32(v)) => visitor.visit_u32(*v),
134 Key::Integer(Integer::U64(v)) => visitor.visit_u64(*v),
135 Key::Integer(Integer::U128(v)) => visitor.visit_u128(*v),
136 Key::Integer(Integer::I8(v)) => visitor.visit_i8(*v),
137 Key::Integer(Integer::I16(v)) => visitor.visit_i16(*v),
138 Key::Integer(Integer::I32(v)) => visitor.visit_i32(*v),
139 Key::Integer(Integer::I64(v)) => visitor.visit_i64(*v),
140 Key::Integer(Integer::I128(v)) => visitor.visit_i128(*v),
141 Key::Float(Float::F32(float)) => <F::F32 as FloatRepr<f32>>::visit(float, visitor),
142 Key::Float(Float::F64(float)) => <F::F64 as FloatRepr<f64>>::visit(float, visitor),
143 Key::String(s) => visitor.visit_str(s),
144 Key::Seq(array) => visitor.visit_seq(SeqDeserializer::new(array)),
145 Key::Map(m) => visitor.visit_map(MapDeserializer::new(m)),
146 Key::Bytes(bytes) => visitor.visit_borrowed_bytes(bytes),
147 };
148 }
149
150 #[inline]
151 fn deserialize_option<V>(self, visitor: V) -> Result<V::Value, Error>
152 where
153 V: de::Visitor<'de>,
154 {
155 match self.value {
156 Key::Unit => visitor.visit_none(),
157 _ => visitor.visit_some(self),
158 }
159 }
160
161 #[inline]
162 fn deserialize_newtype_struct<V>(self, _name: &str, visitor: V) -> Result<V::Value, Error>
163 where
164 V: de::Visitor<'de>,
165 {
166 visitor.visit_newtype_struct(self)
167 }
168
169 #[inline]
170 fn deserialize_enum<V>(
171 self,
172 _name: &str,
173 _variants: &'static [&'static str],
174 visitor: V,
175 ) -> Result<V::Value, Error>
176 where
177 V: de::Visitor<'de>,
178 {
179 let (variant, value) = match self.value {
180 Key::Map(value) => {
181 let mut iter = value.iter();
182
183 let (variant, value) = match iter.next() {
184 Some(v) => v,
185 None => {
186 return Err(Error::Unexpected("map with a single key"));
187 }
188 };
189
190 if iter.next().is_some() {
192 return Err(Error::Unexpected("map with a single key"));
193 }
194
195 (variant, Some(value))
196 }
197 Key::String(_) => (self.value, None),
198 _ => {
199 return Err(Error::Unexpected("string or map"));
200 }
201 };
202
203 visitor.visit_enum(EnumDeserializer { variant, value })
204 }
205
206 #[inline]
207 fn is_human_readable(&self) -> bool {
208 false
209 }
210
211 serde::forward_to_deserialize_any! {
212 bool i8 i16 i32 i64 i128 u8 u16 u32 u64 u128 f32 f64 char str string unit
213 unit_struct seq tuple tuple_struct map struct identifier ignored_any
214 bytes byte_buf
215 }
216}
217
218struct EnumDeserializer<'de, F>
219where
220 F: FloatPolicy,
221{
222 variant: &'de Key<F>,
223 value: Option<&'de Key<F>>,
224}
225
226impl<'de, F> de::EnumAccess<'de> for EnumDeserializer<'de, F>
227where
228 F: FloatPolicy,
229{
230 type Error = Error;
231 type Variant = VariantDeserializer<'de, F>;
232
233 fn variant_seed<V>(self, seed: V) -> Result<(V::Value, Self::Variant), Error>
234 where
235 V: de::DeserializeSeed<'de>,
236 {
237 let variant = self.variant.into_deserializer();
238 let visitor = VariantDeserializer { value: self.value };
239 seed.deserialize(variant).map(|v| (v, visitor))
240 }
241}
242
243struct VariantDeserializer<'de, F>
244where
245 F: FloatPolicy,
246{
247 value: Option<&'de Key<F>>,
248}
249
250impl<'de, F> de::VariantAccess<'de> for VariantDeserializer<'de, F>
251where
252 F: FloatPolicy,
253{
254 type Error = Error;
255
256 fn unit_variant(self) -> Result<(), Error> {
257 match self.value {
258 Some(value) => de::Deserialize::deserialize(Deserializer::new(value)),
259 None => Ok(()),
260 }
261 }
262
263 fn newtype_variant_seed<T>(self, seed: T) -> Result<T::Value, Error>
264 where
265 T: de::DeserializeSeed<'de>,
266 {
267 match self.value {
268 Some(value) => seed.deserialize(Deserializer::new(value)),
269 None => Err(Error::UnexpectedVariant("newtype variant")),
270 }
271 }
272
273 fn tuple_variant<V>(self, _len: usize, visitor: V) -> Result<V::Value, Error>
274 where
275 V: de::Visitor<'de>,
276 {
277 match self.value {
278 Some(Key::Seq(values)) => {
279 de::Deserializer::deserialize_any(SeqDeserializer::new(values), visitor)
280 }
281 Some(_) => Err(Error::UnexpectedVariant("tuple variant")),
282 None => Err(Error::UnexpectedVariant("tuple variant")),
283 }
284 }
285
286 fn struct_variant<V>(
287 self,
288 _fields: &'static [&'static str],
289 visitor: V,
290 ) -> Result<V::Value, Error>
291 where
292 V: de::Visitor<'de>,
293 {
294 match self.value {
295 Some(Key::Map(v)) => {
296 de::Deserializer::deserialize_any(MapDeserializer::new(v), visitor)
297 }
298 Some(_) => Err(Error::UnexpectedVariant("struct variant")),
299 _ => Err(Error::UnexpectedVariant("struct variant")),
300 }
301 }
302}
303
304struct SeqDeserializer<'de, F>
305where
306 F: FloatPolicy,
307{
308 values: &'de [Key<F>],
309}
310
311impl<'de, F> SeqDeserializer<'de, F>
312where
313 F: FloatPolicy,
314{
315 pub fn new(values: &'de [Key<F>]) -> Self {
316 Self { values }
317 }
318}
319
320impl<'de, F> serde::Deserializer<'de> for SeqDeserializer<'de, F>
321where
322 F: FloatPolicy,
323{
324 type Error = Error;
325
326 #[inline]
327 fn deserialize_any<V>(mut self, visitor: V) -> Result<V::Value, Error>
328 where
329 V: de::Visitor<'de>,
330 {
331 let len = self.values.len();
332
333 if len == 0 {
334 return visitor.visit_unit();
335 }
336
337 let ret = visitor.visit_seq(&mut self)?;
338
339 if self.values.is_empty() {
340 return Ok(ret);
341 }
342
343 Err(Error::InvalidLength)
344 }
345
346 serde::forward_to_deserialize_any! {
347 bool i8 i16 i32 i64 i128 u8 u16 u32 u64 u128 f32 f64 char str string
348 bytes byte_buf option unit unit_struct newtype_struct seq tuple
349 tuple_struct map struct enum identifier ignored_any
350 }
351}
352
353impl<'de, F> de::SeqAccess<'de> for SeqDeserializer<'de, F>
354where
355 F: FloatPolicy,
356{
357 type Error = Error;
358
359 fn next_element_seed<T>(&mut self, seed: T) -> Result<Option<T::Value>, Self::Error>
360 where
361 T: de::DeserializeSeed<'de>,
362 {
363 let (first, rest) = match self.values.split_first() {
364 Some((first, rest)) => (first, rest),
365 None => return Ok(None),
366 };
367
368 self.values = rest;
369 let value = seed.deserialize(Deserializer::new(first))?;
370 Ok(Some(value))
371 }
372}
373
374struct MapDeserializer<'de, F>
375where
376 F: FloatPolicy,
377{
378 map: &'de [(Key<F>, Key<F>)],
379 value: Option<&'de Key<F>>,
380}
381
382impl<'de, F> MapDeserializer<'de, F>
383where
384 F: FloatPolicy,
385{
386 pub fn new(map: &'de [(Key<F>, Key<F>)]) -> Self {
387 Self { map, value: None }
388 }
389}
390
391impl<'de, F> serde::Deserializer<'de> for MapDeserializer<'de, F>
392where
393 F: FloatPolicy,
394{
395 type Error = Error;
396
397 #[inline]
398 fn deserialize_any<V>(self, visitor: V) -> Result<V::Value, Error>
399 where
400 V: de::Visitor<'de>,
401 {
402 visitor.visit_map(self)
403 }
404
405 serde::forward_to_deserialize_any! {
406 bool i8 i16 i32 i64 i128 u8 u16 u32 u64 u128 f32 f64 char str string
407 bytes byte_buf option unit unit_struct newtype_struct seq tuple
408 tuple_struct map struct enum identifier ignored_any
409 }
410}
411
412impl<'de, F> de::MapAccess<'de> for MapDeserializer<'de, F>
413where
414 F: FloatPolicy,
415{
416 type Error = Error;
417
418 fn next_key_seed<K>(&mut self, seed: K) -> Result<Option<K::Value>, Self::Error>
419 where
420 K: de::DeserializeSeed<'de>,
421 {
422 let next = self.map.split_first();
423
424 match next {
425 Some(((key, value), map)) => {
426 self.value = Some(value);
427 self.map = map;
428 let value = seed.deserialize(key.into_deserializer())?;
429 Ok(Some(value))
430 }
431 None => Ok(None),
432 }
433 }
434
435 fn next_value_seed<V>(&mut self, seed: V) -> Result<V::Value, Self::Error>
436 where
437 V: de::DeserializeSeed<'de>,
438 {
439 let value = match self.value.take() {
440 Some(value) => value,
441 None => return Err(Error::MissingValue),
442 };
443
444 seed.deserialize(Deserializer::new(value))
445 }
446}