1use crate::Value;
2use serde::{de, forward_to_deserialize_any};
3use std::collections::BTreeMap;
4use std::error::Error;
5use std::fmt;
6use std::marker::PhantomData;
7
8#[derive(Debug)]
9pub enum Unexpected {
10 Bool(bool),
11 Unsigned(u64),
12 Signed(i64),
13 Float(f64),
14 Char(char),
15 Str(String),
16 Bytes(Vec<u8>),
17 Unit,
18 Option,
19 NewtypeStruct,
20 Seq,
21 Map,
22 Enum,
23 UnitVariant,
24 NewtypeVariant,
25 TupleVariant,
26 StructVariant,
27 Other(String),
28}
29
30impl From<de::Unexpected<'_>> for Unexpected {
31 fn from(unexp: de::Unexpected) -> Unexpected {
32 match unexp {
33 de::Unexpected::Bool(v) => Unexpected::Bool(v),
34 de::Unexpected::Unsigned(v) => Unexpected::Unsigned(v),
35 de::Unexpected::Signed(v) => Unexpected::Signed(v),
36 de::Unexpected::Float(v) => Unexpected::Float(v),
37 de::Unexpected::Char(v) => Unexpected::Char(v),
38 de::Unexpected::Str(v) => Unexpected::Str(v.to_owned()),
39 de::Unexpected::Bytes(v) => Unexpected::Bytes(v.to_owned()),
40 de::Unexpected::Unit => Unexpected::Unit,
41 de::Unexpected::Option => Unexpected::Option,
42 de::Unexpected::NewtypeStruct => Unexpected::NewtypeStruct,
43 de::Unexpected::Seq => Unexpected::Seq,
44 de::Unexpected::Map => Unexpected::Map,
45 de::Unexpected::Enum => Unexpected::Enum,
46 de::Unexpected::UnitVariant => Unexpected::UnitVariant,
47 de::Unexpected::NewtypeVariant => Unexpected::NewtypeVariant,
48 de::Unexpected::TupleVariant => Unexpected::TupleVariant,
49 de::Unexpected::StructVariant => Unexpected::StructVariant,
50 de::Unexpected::Other(v) => Unexpected::Other(v.to_owned()),
51 }
52 }
53}
54
55impl Unexpected {
56 pub fn to_unexpected(&self) -> de::Unexpected<'_> {
57 match *self {
58 Unexpected::Bool(v) => de::Unexpected::Bool(v),
59 Unexpected::Unsigned(v) => de::Unexpected::Unsigned(v),
60 Unexpected::Signed(v) => de::Unexpected::Signed(v),
61 Unexpected::Float(v) => de::Unexpected::Float(v),
62 Unexpected::Char(v) => de::Unexpected::Char(v),
63 Unexpected::Str(ref v) => de::Unexpected::Str(v),
64 Unexpected::Bytes(ref v) => de::Unexpected::Bytes(v),
65 Unexpected::Unit => de::Unexpected::Unit,
66 Unexpected::Option => de::Unexpected::Option,
67 Unexpected::NewtypeStruct => de::Unexpected::NewtypeStruct,
68 Unexpected::Seq => de::Unexpected::Seq,
69 Unexpected::Map => de::Unexpected::Map,
70 Unexpected::Enum => de::Unexpected::Enum,
71 Unexpected::UnitVariant => de::Unexpected::UnitVariant,
72 Unexpected::NewtypeVariant => de::Unexpected::NewtypeVariant,
73 Unexpected::TupleVariant => de::Unexpected::TupleVariant,
74 Unexpected::StructVariant => de::Unexpected::StructVariant,
75 Unexpected::Other(ref v) => de::Unexpected::Other(v),
76 }
77 }
78}
79
80#[derive(Debug)]
81pub enum DeserializerError {
82 Custom(String),
83 InvalidType(Unexpected, String),
84 InvalidValue(Unexpected, String),
85 InvalidLength(usize, String),
86 UnknownVariant(String, &'static [&'static str]),
87 UnknownField(String, &'static [&'static str]),
88 MissingField(&'static str),
89 DuplicateField(&'static str),
90}
91
92impl de::Error for DeserializerError {
93 fn custom<T: fmt::Display>(msg: T) -> Self {
94 DeserializerError::Custom(msg.to_string())
95 }
96
97 fn invalid_type(unexp: de::Unexpected, exp: &dyn de::Expected) -> Self {
98 DeserializerError::InvalidType(unexp.into(), exp.to_string())
99 }
100
101 fn invalid_value(unexp: de::Unexpected, exp: &dyn de::Expected) -> Self {
102 DeserializerError::InvalidValue(unexp.into(), exp.to_string())
103 }
104
105 fn invalid_length(len: usize, exp: &dyn de::Expected) -> Self {
106 DeserializerError::InvalidLength(len, exp.to_string())
107 }
108
109 fn unknown_variant(field: &str, expected: &'static [&'static str]) -> Self {
110 DeserializerError::UnknownVariant(field.into(), expected)
111 }
112
113 fn unknown_field(field: &str, expected: &'static [&'static str]) -> Self {
114 DeserializerError::UnknownField(field.into(), expected)
115 }
116
117 fn missing_field(field: &'static str) -> Self {
118 DeserializerError::MissingField(field)
119 }
120
121 fn duplicate_field(field: &'static str) -> Self {
122 DeserializerError::DuplicateField(field)
123 }
124}
125
126impl DeserializerError {
127 pub fn to_error<E: de::Error>(&self) -> E {
128 match *self {
129 DeserializerError::Custom(ref msg) => E::custom(msg.clone()),
130 DeserializerError::InvalidType(ref unexp, ref exp) => {
131 E::invalid_type(unexp.to_unexpected(), &&**exp)
132 }
133 DeserializerError::InvalidValue(ref unexp, ref exp) => {
134 E::invalid_value(unexp.to_unexpected(), &&**exp)
135 }
136 DeserializerError::InvalidLength(len, ref exp) => E::invalid_length(len, &&**exp),
137 DeserializerError::UnknownVariant(ref field, exp) => E::unknown_variant(field, exp),
138 DeserializerError::UnknownField(ref field, exp) => E::unknown_field(field, exp),
139 DeserializerError::MissingField(field) => E::missing_field(field),
140 DeserializerError::DuplicateField(field) => E::missing_field(field),
141 }
142 }
143
144 pub fn into_error<E: de::Error>(self) -> E {
145 self.to_error()
146 }
147}
148
149impl Error for DeserializerError {
150 fn description(&self) -> &str {
151 "Value deserializer error"
152 }
153}
154
155impl fmt::Display for DeserializerError {
156 fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
157 match *self {
158 DeserializerError::Custom(ref msg) => write!(f, "{}", msg),
159 DeserializerError::InvalidType(ref unexp, ref exp) => {
160 write!(
161 f,
162 "Invalid type {}. Expected {}",
163 unexp.to_unexpected(),
164 exp
165 )
166 }
167 DeserializerError::InvalidValue(ref unexp, ref exp) => {
168 write!(
169 f,
170 "Invalid value {}. Expected {}",
171 unexp.to_unexpected(),
172 exp
173 )
174 }
175 DeserializerError::InvalidLength(len, ref exp) => {
176 write!(f, "Invalid length {}. Expected {}", len, exp)
177 }
178 DeserializerError::UnknownVariant(ref field, exp) => {
179 write!(
180 f,
181 "Unknown variant {}. Expected one of {}",
182 field,
183 exp.join(", ")
184 )
185 }
186 DeserializerError::UnknownField(ref field, exp) => {
187 write!(
188 f,
189 "Unknown field {}. Expected one of {}",
190 field,
191 exp.join(", ")
192 )
193 }
194 DeserializerError::MissingField(field) => write!(f, "Missing field {}", field),
195 DeserializerError::DuplicateField(field) => write!(f, "Duplicate field {}", field),
196 }
197 }
198}
199
200impl From<de::value::Error> for DeserializerError {
201 fn from(e: de::value::Error) -> DeserializerError {
202 DeserializerError::Custom(e.to_string())
203 }
204}
205
206pub struct ValueVisitor;
207
208impl<'de> de::Visitor<'de> for ValueVisitor {
209 type Value = Value;
210
211 fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
212 fmt.write_str("any value")
213 }
214
215 fn visit_bool<E>(self, value: bool) -> Result<Value, E> {
216 Ok(Value::Bool(value))
217 }
218
219 fn visit_i8<E>(self, value: i8) -> Result<Value, E> {
220 Ok(Value::I8(value))
221 }
222
223 fn visit_i16<E>(self, value: i16) -> Result<Value, E> {
224 Ok(Value::I16(value))
225 }
226
227 fn visit_i32<E>(self, value: i32) -> Result<Value, E> {
228 Ok(Value::I32(value))
229 }
230
231 fn visit_i64<E>(self, value: i64) -> Result<Value, E> {
232 Ok(Value::I64(value))
233 }
234
235 fn visit_u8<E>(self, value: u8) -> Result<Value, E> {
236 Ok(Value::U8(value))
237 }
238
239 fn visit_u16<E>(self, value: u16) -> Result<Value, E> {
240 Ok(Value::U16(value))
241 }
242
243 fn visit_u32<E>(self, value: u32) -> Result<Value, E> {
244 Ok(Value::U32(value))
245 }
246
247 fn visit_u64<E>(self, value: u64) -> Result<Value, E> {
248 Ok(Value::U64(value))
249 }
250
251 fn visit_f32<E>(self, value: f32) -> Result<Value, E> {
252 Ok(Value::F32(value))
253 }
254
255 fn visit_f64<E>(self, value: f64) -> Result<Value, E> {
256 Ok(Value::F64(value))
257 }
258
259 fn visit_char<E>(self, value: char) -> Result<Value, E> {
260 Ok(Value::Char(value))
261 }
262
263 fn visit_str<E>(self, value: &str) -> Result<Value, E> {
264 Ok(Value::String(value.into()))
265 }
266
267 fn visit_string<E>(self, value: String) -> Result<Value, E> {
268 Ok(Value::String(value))
269 }
270
271 fn visit_unit<E>(self) -> Result<Value, E> {
272 Ok(Value::Unit)
273 }
274
275 fn visit_none<E>(self) -> Result<Value, E> {
276 Ok(Value::Option(None))
277 }
278
279 fn visit_some<D: de::Deserializer<'de>>(self, d: D) -> Result<Value, D::Error> {
280 d.deserialize_any(ValueVisitor)
281 .map(|v| Value::Option(Some(Box::new(v))))
282 }
283
284 fn visit_newtype_struct<D: de::Deserializer<'de>>(self, d: D) -> Result<Value, D::Error> {
285 d.deserialize_any(ValueVisitor)
286 .map(|v| Value::Newtype(Box::new(v)))
287 }
288
289 fn visit_seq<V: de::SeqAccess<'de>>(self, mut visitor: V) -> Result<Value, V::Error> {
290 let mut values = Vec::new();
291 while let Some(elem) = visitor.next_element()? {
292 values.push(elem);
293 }
294 Ok(Value::Seq(values))
295 }
296
297 fn visit_map<V: de::MapAccess<'de>>(self, mut visitor: V) -> Result<Value, V::Error> {
298 let mut values = BTreeMap::new();
299 while let Some((key, value)) = visitor.next_entry()? {
300 values.insert(key, value);
301 }
302 Ok(Value::Map(values))
303 }
304
305 fn visit_bytes<E>(self, v: &[u8]) -> Result<Value, E> {
306 Ok(Value::Bytes(v.into()))
307 }
308
309 fn visit_byte_buf<E>(self, v: Vec<u8>) -> Result<Value, E> {
310 Ok(Value::Bytes(v))
311 }
312}
313
314impl<'de> de::Deserialize<'de> for Value {
315 fn deserialize<D: de::Deserializer<'de>>(d: D) -> Result<Self, D::Error> {
316 d.deserialize_any(ValueVisitor)
317 }
318}
319
320impl de::IntoDeserializer<'_, DeserializerError> for Value {
321 type Deserializer = Value;
322
323 fn into_deserializer(self) -> Value {
324 self
325 }
326}
327
328pub struct ValueDeserializer<E> {
329 value: Value,
330 error: PhantomData<fn() -> E>,
331}
332
333impl<E> ValueDeserializer<E> {
334 pub fn new(value: Value) -> Self {
335 ValueDeserializer {
336 value,
337 error: Default::default(),
338 }
339 }
340
341 pub fn into_value(self) -> Value {
342 self.value
343 }
344}
345
346impl<'de, E> de::Deserializer<'de> for ValueDeserializer<E>
347where
348 E: de::Error,
349{
350 type Error = E;
351
352 fn deserialize_any<V: de::Visitor<'de>>(self, visitor: V) -> Result<V::Value, Self::Error> {
353 match self.value {
354 Value::Bool(v) => visitor.visit_bool(v),
355 Value::U8(v) => visitor.visit_u8(v),
356 Value::U16(v) => visitor.visit_u16(v),
357 Value::U32(v) => visitor.visit_u32(v),
358 Value::U64(v) => visitor.visit_u64(v),
359 Value::I8(v) => visitor.visit_i8(v),
360 Value::I16(v) => visitor.visit_i16(v),
361 Value::I32(v) => visitor.visit_i32(v),
362 Value::I64(v) => visitor.visit_i64(v),
363 Value::F32(v) => visitor.visit_f32(v),
364 Value::F64(v) => visitor.visit_f64(v),
365 Value::Char(v) => visitor.visit_char(v),
366 Value::String(v) => visitor.visit_string(v),
367 Value::Unit => visitor.visit_unit(),
368 Value::Option(None) => visitor.visit_none(),
369 Value::Option(Some(v)) => visitor.visit_some(ValueDeserializer::new(*v)),
370 Value::Newtype(v) => visitor.visit_newtype_struct(ValueDeserializer::new(*v)),
371 Value::Seq(v) => visitor.visit_seq(de::value::SeqDeserializer::new(
372 v.into_iter().map(ValueDeserializer::new),
373 )),
374 Value::Map(v) => visitor
375 .visit_map(de::value::MapDeserializer::new(v.into_iter().map(
376 |(k, v)| (ValueDeserializer::new(k), ValueDeserializer::new(v)),
377 ))),
378 Value::Bytes(v) => visitor.visit_byte_buf(v),
379 Value::CuTime(v) => visitor.visit_u64(v.0),
380 }
381 }
382
383 fn deserialize_option<V: de::Visitor<'de>>(self, visitor: V) -> Result<V::Value, Self::Error> {
384 match self.value {
385 Value::Option(..) => self.deserialize_any(visitor),
386 Value::Unit => visitor.visit_unit(),
387 _ => visitor.visit_some(self),
388 }
389 }
390
391 fn deserialize_enum<V: de::Visitor<'de>>(
392 self,
393 _name: &'static str,
394 _variants: &'static [&'static str],
395 visitor: V,
396 ) -> Result<V::Value, Self::Error> {
397 let (variant, value) = match self.value {
398 Value::Map(value) => {
399 let mut iter = value.into_iter();
400 let (variant, value) = match iter.next() {
401 Some(v) => v,
402 None => {
403 return Err(de::Error::invalid_value(
404 de::Unexpected::Map,
405 &"map with a single key",
406 ));
407 }
408 };
409 if iter.next().is_some() {
411 return Err(de::Error::invalid_value(
412 de::Unexpected::Map,
413 &"map with a single key",
414 ));
415 }
416 (variant, Some(value))
417 }
418 Value::String(variant) => (Value::String(variant), None),
419 other => {
420 return Err(de::Error::invalid_type(
421 other.unexpected(),
422 &"string or map",
423 ));
424 }
425 };
426
427 let d = EnumDeserializer {
428 variant,
429 value,
430 error: Default::default(),
431 };
432 visitor.visit_enum(d)
433 }
434
435 fn deserialize_newtype_struct<V: de::Visitor<'de>>(
436 self,
437 _name: &'static str,
438 visitor: V,
439 ) -> Result<V::Value, Self::Error> {
440 match self.value {
441 Value::Newtype(v) => visitor.visit_newtype_struct(ValueDeserializer::new(*v)),
442 _ => visitor.visit_newtype_struct(self),
443 }
444 }
445
446 forward_to_deserialize_any! {
447 bool u8 u16 u32 u64 i8 i16 i32 i64 f32 f64 char str string unit
448 seq bytes byte_buf map unit_struct
449 tuple_struct struct tuple ignored_any identifier
450 }
451}
452
453impl<E> de::IntoDeserializer<'_, E> for ValueDeserializer<E>
454where
455 E: de::Error,
456{
457 type Deserializer = Self;
458
459 fn into_deserializer(self) -> Self::Deserializer {
460 self
461 }
462}
463
464impl<'de> de::Deserializer<'de> for Value {
465 type Error = DeserializerError;
466
467 fn deserialize_any<V: de::Visitor<'de>>(self, visitor: V) -> Result<V::Value, Self::Error> {
468 ValueDeserializer::new(self).deserialize_any(visitor)
469 }
470
471 fn deserialize_option<V: de::Visitor<'de>>(self, visitor: V) -> Result<V::Value, Self::Error> {
472 ValueDeserializer::new(self).deserialize_option(visitor)
473 }
474
475 fn deserialize_enum<V: de::Visitor<'de>>(
476 self,
477 name: &'static str,
478 variants: &'static [&'static str],
479 visitor: V,
480 ) -> Result<V::Value, Self::Error> {
481 ValueDeserializer::new(self).deserialize_enum(name, variants, visitor)
482 }
483
484 fn deserialize_newtype_struct<V: de::Visitor<'de>>(
485 self,
486 name: &'static str,
487 visitor: V,
488 ) -> Result<V::Value, Self::Error> {
489 ValueDeserializer::new(self).deserialize_newtype_struct(name, visitor)
490 }
491
492 forward_to_deserialize_any! {
493 bool u8 u16 u32 u64 i8 i16 i32 i64 f32 f64 char str string unit
494 seq bytes byte_buf map unit_struct
495 tuple_struct struct tuple ignored_any identifier
496 }
497}
498
499struct EnumDeserializer<E> {
500 variant: Value,
501 value: Option<Value>,
502 error: PhantomData<fn() -> E>,
503}
504
505impl<'de, E> de::EnumAccess<'de> for EnumDeserializer<E>
506where
507 E: de::Error,
508{
509 type Error = E;
510 type Variant = VariantDeserializer<Self::Error>;
511
512 fn variant_seed<V>(
513 self,
514 seed: V,
515 ) -> Result<(V::Value, VariantDeserializer<Self::Error>), Self::Error>
516 where
517 V: de::DeserializeSeed<'de>,
518 {
519 let visitor = VariantDeserializer {
520 value: self.value,
521 error: Default::default(),
522 };
523 seed.deserialize(ValueDeserializer::new(self.variant))
524 .map(|v| (v, visitor))
525 }
526}
527
528struct VariantDeserializer<E> {
529 value: Option<Value>,
530 error: PhantomData<fn() -> E>,
531}
532
533impl<'de, E> de::VariantAccess<'de> for VariantDeserializer<E>
534where
535 E: de::Error,
536{
537 type Error = E;
538
539 fn unit_variant(self) -> Result<(), Self::Error> {
540 match self.value {
541 Some(value) => de::Deserialize::deserialize(ValueDeserializer::new(value)),
542 None => Ok(()),
543 }
544 }
545
546 fn newtype_variant_seed<T>(self, seed: T) -> Result<T::Value, Self::Error>
547 where
548 T: de::DeserializeSeed<'de>,
549 {
550 match self.value {
551 Some(value) => seed.deserialize(ValueDeserializer::new(value)),
552 None => Err(de::Error::invalid_type(
553 de::Unexpected::UnitVariant,
554 &"newtype variant",
555 )),
556 }
557 }
558
559 fn tuple_variant<V>(self, _len: usize, visitor: V) -> Result<V::Value, Self::Error>
560 where
561 V: de::Visitor<'de>,
562 {
563 match self.value {
564 Some(Value::Seq(v)) => de::Deserializer::deserialize_any(
565 de::value::SeqDeserializer::new(v.into_iter().map(ValueDeserializer::new)),
566 visitor,
567 ),
568 Some(other) => Err(de::Error::invalid_type(
569 other.unexpected(),
570 &"tuple variant",
571 )),
572 None => Err(de::Error::invalid_type(
573 de::Unexpected::UnitVariant,
574 &"tuple variant",
575 )),
576 }
577 }
578
579 fn struct_variant<V>(
580 self,
581 _fields: &'static [&'static str],
582 visitor: V,
583 ) -> Result<V::Value, Self::Error>
584 where
585 V: de::Visitor<'de>,
586 {
587 match self.value {
588 Some(Value::Map(v)) => de::Deserializer::deserialize_any(
589 de::value::MapDeserializer::new(
590 v.into_iter()
591 .map(|(k, v)| (ValueDeserializer::new(k), ValueDeserializer::new(v))),
592 ),
593 visitor,
594 ),
595 Some(other) => Err(de::Error::invalid_type(
596 other.unexpected(),
597 &"struct variant",
598 )),
599 None => Err(de::Error::invalid_type(
600 de::Unexpected::UnitVariant,
601 &"struct variant",
602 )),
603 }
604 }
605}