use crate::jserror::JsErrorData;
use thiserror::Error;
use wasm_bindgen::prelude::*;
#[derive(Error, Debug, Clone)]
pub enum Error {
#[error("{0}")]
Custom(String),
#[error("type error: {0}")]
WrongType(String),
#[error("size error: {0}")]
WrongSize(String),
#[error("missing property `{0}`")]
MissingProperty(String),
#[error("error accessing property `{0}`")]
PropertyAccess(String),
#[error("{0}")]
Bounds(String),
#[error("{0}")]
Convert(String),
#[error("hex string must have an even number of characters: `{0}`")]
HexStringNotEven(String),
#[error(transparent)]
FasterHex(#[from] faster_hex::Error),
#[error(transparent)]
JsValue(JsErrorData),
#[error("WASM ABI: {0}")]
Abi(String),
#[error("supplied argument is not an object")]
NotAnObject,
#[error("supplied object is not a WASM ABI pointer")]
NotWasmAbiPointer,
#[error("supplied object is not a WASM ABI pointer for class `{0}`")]
NotWasmAbiPointerForClass(String),
#[error("supplied argument is not an object of class type `{0}`")]
NotAnObjectOfClass(String),
#[error("unable to obtain object constructor (for expected class `{0}`)")]
NoConstructorOfClass(String),
#[error("unable to obtain object constructor name (for expected class `{0}`)")]
UnableToObtainConstructorName(String),
#[error("object constructor `{0}` does not match expected class `{1}`")]
ClassConstructorMatch(String, String),
}
impl From<Error> for JsValue {
fn from(err: Error) -> Self {
JsValue::from_str(&err.to_string())
}
}
impl From<JsValue> for Error {
fn from(error: JsValue) -> Self {
Error::JsValue(error.into())
}
}
impl Error {
pub fn custom<S: ToString>(msg: S) -> Self {
Self::Custom(msg.to_string())
}
pub fn convert<S: std::fmt::Display>(msg: S) -> Self {
Self::Convert(msg.to_string())
}
}