mirror of
https://github.com/denoland/deno.git
synced 2025-01-01 11:58:45 -05:00
b1b418b81a
Stop allowing clippy::derive-partial-eq-without-eq and fix warnings about deriving PartialEq without also deriving Eq. In one case I removed the PartialEq because it a) wasn't necessary, and b) sketchy because it was comparing floating point numbers. IMO, that's a good argument for enforcing the lint rule, because it would most likely have been caught during review if it had been enabled.
51 lines
1 KiB
Rust
51 lines
1 KiB
Rust
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
|
use std::fmt::{self, Display};
|
|
|
|
use serde::{de, ser};
|
|
|
|
pub type Result<T> = std::result::Result<T, Error>;
|
|
|
|
#[derive(Clone, Debug, Eq, PartialEq)]
|
|
#[non_exhaustive]
|
|
pub enum Error {
|
|
Message(String),
|
|
|
|
ExpectedBoolean,
|
|
ExpectedInteger,
|
|
ExpectedNumber,
|
|
ExpectedString,
|
|
ExpectedArray,
|
|
ExpectedMap,
|
|
ExpectedEnum,
|
|
ExpectedObject,
|
|
ExpectedBuffer,
|
|
ExpectedDetachable,
|
|
|
|
ExpectedUtf8,
|
|
ExpectedLatin1,
|
|
|
|
LengthMismatch,
|
|
}
|
|
|
|
impl ser::Error for Error {
|
|
fn custom<T: Display>(msg: T) -> Self {
|
|
Error::Message(msg.to_string())
|
|
}
|
|
}
|
|
|
|
impl de::Error for Error {
|
|
fn custom<T: Display>(msg: T) -> Self {
|
|
Error::Message(msg.to_string())
|
|
}
|
|
}
|
|
|
|
impl Display for Error {
|
|
fn fmt(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
|
|
match self {
|
|
Error::Message(msg) => formatter.write_str(msg),
|
|
err => formatter.write_str(format!("serde_v8 error: {:?}", err).as_ref()),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl std::error::Error for Error {}
|