ecma-runtime-cat 0.3.3

ECMAScript runtime: native built-ins (console, Math, JSON, parseInt, isNaN, Promise, Object, Array, ...) that the boa-cat engine exposes to scripts. v0.3.3 adds `Object.{keys, values, entries, assign}` and `Array.isArray` static methods. All four `Object` methods walk own data properties and skip the synthetic `length` slot when the source looks like an array; `Object.assign` also copies accessor pairs onto the target so getter/setter semantics survive the merge. `Array.isArray(value)` returns `true` when `value` is an object whose own data-property keys are numeric or `length`.
//! Runtime error type.

use boa_cat::Error as EngineError;

/// All errors the runtime can produce.  Currently a thin wrapper around
/// [`boa_cat::Error`] since the runtime itself only contributes native
/// callables whose failures surface as `Outcome::Throw` values rather
/// than `Error`s.
#[derive(Debug, Clone, PartialEq, Eq)]
pub enum Error {
    /// An error from the boa-cat engine (lex/parse/syntax/fuel/uncaught
    /// exception).
    Engine(EngineError),
}

impl From<EngineError> for Error {
    fn from(value: EngineError) -> Self {
        Self::Engine(value)
    }
}

impl std::fmt::Display for Error {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            Self::Engine(e) => write!(f, "engine error: {e}"),
        }
    }
}

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