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
use std::fmt::{self, Display};

use serde::{de, ser};

pub type Result<T> = std::result::Result<T, Error>;

/// This type represents actions a user may take while interacting with the
/// deserialiser.
#[derive(Copy, Clone, Debug, PartialEq)]
pub enum UserAction {
  /// Cancel deserialising.
  Cancel,
  /// Restart deserialising from response `n`.
  Restart(usize),
  /// Undo the last `n` responses to the deserialiser.
  Undo(usize),
}

/// This type represents errors that may occur.
#[derive(Clone, Debug, PartialEq)]
pub enum Error {
  SerdeError(String),
  IoError(String),
  UserAction(UserAction),
  BadResponse,
  CannotReplay,
}

impl ser::Error for Error {
  fn custom<T: Display>(msg: T) -> Self {
    Error::SerdeError(msg.to_string())
  }
}

impl de::Error for Error {
  fn custom<T: Display>(msg: T) -> Self {
    Error::SerdeError(msg.to_string())
  }
}

impl Display for Error {
  fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
    match self {
      Error::SerdeError(msg) => write!(fmt, "Serde: {}", msg),
      Error::IoError(msg) => write!(fmt, "I/O: {}", msg),
      Error::UserAction(action) => write!(fmt, "UserAction: {:?}", action),
      Error::BadResponse => write!(fmt, "Bad Response"),
      Error::CannotReplay => write!(fmt, "Cannot Replay"),
    }
  }
}

impl std::error::Error for Error {}