Enum dust_lib::Error

source ·
#[non_exhaustive]
pub enum Error {
Show 44 variants TypeCheckFailure { tool_info: ToolInfo<'static>, argument: Value, }, AssertEqualFailed { expected: Value, actual: Value, }, AssertFailed, WrongColumnAmount { expected: usize, actual: usize, }, ExpectedOperatorArgumentAmount { expected: usize, actual: usize, }, ExpectedFunctionArgumentAmount { identifier: String, expected: usize, actual: usize, }, ExpectedAtLeastFunctionArgumentAmount { identifier: String, minimum: usize, actual: usize, }, ExpectedString { actual: Value, }, ExpectedInt { actual: Value, }, ExpectedFloat { actual: Value, }, ExpectedNumber { actual: Value, }, ExpectedNumberOrString { actual: Value, }, ExpectedBoolean { actual: Value, }, ExpectedList { actual: Value, }, ExpectedFixedLenList { expected_len: usize, actual: Value, }, ExpectedEmpty { actual: Value, }, ExpectedMap { actual: Value, }, ExpectedTable { actual: Value, }, ExpectedFunction { actual: Value, }, ExpectedCollection { actual: Value, }, AppendedToLeafNode(Node), PrecedenceViolation, VariableIdentifierNotFound(String), FunctionIdentifierNotFound(String), TypeError { expected: &'static [ValueType], actual: Value, }, MacroArgumentType { macro_info: ToolInfo<'static>, actual: Value, }, WrongTypeCombination { operator: Operator, actual: Vec<ValueType>, }, UnmatchedLBrace, UnmatchedRBrace, MissingOperatorOutsideOfBrace, UnmatchedPartialToken { first: PartialToken, second: Option<PartialToken>, }, AdditionError { augend: Value, addend: Value, }, SubtractionError { minuend: Value, subtrahend: Value, }, NegationError { argument: Value, }, MultiplicationError { multiplicand: Value, multiplier: Value, }, DivisionError { dividend: Value, divisor: Value, }, ModulationError { dividend: Value, divisor: Value, }, InvalidRegex { regex: String, message: String, }, ContextNotMutable, IllegalEscapeSequence(String), BuiltinFunctionsCannotBeEnabled, BuiltinFunctionsCannotBeDisabled, MacroFailure(String), CustomMessage(String),
}

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

TypeCheckFailure

Fields

§tool_info: ToolInfo<'static>
§argument: Value

Dust’s internal type checking failed to identify a type mismatch. This should never happen, /// the error prompts the user to report the bug.

§

AssertEqualFailed

Fields

§expected: Value
§actual: Value

The ‘assert’ macro did not resolve successfully.

§

AssertFailed

The ‘assert’ macro did not resolve successfully.

§

WrongColumnAmount

Fields

§expected: usize
§actual: usize

A row was inserted to a table with the wrong amount of values.

§

ExpectedOperatorArgumentAmount

Fields

§expected: usize
§actual: usize

An operator was called with the wrong amount of arguments.

§

ExpectedFunctionArgumentAmount

Fields

§identifier: String
§expected: usize
§actual: usize

A function was called with the wrong amount of arguments.

§

ExpectedAtLeastFunctionArgumentAmount

Fields

§identifier: String
§minimum: usize
§actual: usize

A function was called with the wrong amount of arguments.

§

ExpectedString

Fields

§actual: Value
§

ExpectedInt

Fields

§actual: Value
§

ExpectedFloat

Fields

§actual: Value
§

ExpectedNumber

Fields

§actual: Value

An integer, floating point or value was expected.

§

ExpectedNumberOrString

Fields

§actual: Value

An integer, floating point or string value was expected.

§

ExpectedBoolean

Fields

§actual: Value
§

ExpectedList

Fields

§actual: Value
§

ExpectedFixedLenList

Fields

§expected_len: usize
§actual: Value
§

ExpectedEmpty

Fields

§actual: Value
§

ExpectedMap

Fields

§actual: Value
§

ExpectedTable

Fields

§actual: Value
§

ExpectedFunction

Fields

§actual: Value
§

ExpectedCollection

Fields

§actual: Value

A string, list, map or table value was expected.

§

AppendedToLeafNode(Node)

Tried to append a child to a leaf node. Leaf nodes cannot have children.

§

PrecedenceViolation

Tried to append a child to a node such that the precedence of the child is not higher. This error should never occur. If it does, please file a bug report.

§

VariableIdentifierNotFound(String)

A VariableIdentifier operation did not find its value in the context.

§

FunctionIdentifierNotFound(String)

A FunctionIdentifier operation did not find its value in the context.

§

TypeError

Fields

§expected: &'static [ValueType]

The expected types.

§actual: Value

The actual value.

A value has the wrong type. Only use this if there is no other error that describes the expected and provided types in more detail.

§

MacroArgumentType

Fields

§macro_info: ToolInfo<'static>

The macro that was called.

§actual: Value

The actual value.

A macro or function was called with the wrong type of input.

§

WrongTypeCombination

Fields

§operator: Operator

The operator that whose evaluation caused the error.

§actual: Vec<ValueType>

The types that were used in the operator causing it to fail.

An operator is used with a wrong combination of types.

§

UnmatchedLBrace

An opening brace without a matching closing brace was found.

§

UnmatchedRBrace

A closing brace without a matching opening brace was found.

§

MissingOperatorOutsideOfBrace

Left of an opening brace or right of a closing brace is a token that does not expect the brace next to it. For example, writing 4(5) would yield this error, as the 4 does not have any operands.

§

UnmatchedPartialToken

Fields

§first: PartialToken

The unmatched partial token.

§second: Option<PartialToken>

The token that follows the unmatched partial token and that cannot be matched to the partial token, or None, if first is the last partial token in the stream.

A PartialToken is unmatched, such that it cannot be combined into a full Token. This happens if for example a single = is found, surrounded by whitespace. It is not a token, but it is part of the string representation of some tokens.

§

AdditionError

Fields

§augend: Value

The first argument of the addition.

§addend: Value

The second argument of the addition.

An addition operation performed by Rust failed.

§

SubtractionError

Fields

§minuend: Value

The first argument of the subtraction.

§subtrahend: Value

The second argument of the subtraction.

A subtraction operation performed by Rust failed.

§

NegationError

Fields

§argument: Value

The argument of the negation.

A negation operation performed by Rust failed.

§

MultiplicationError

Fields

§multiplicand: Value

The first argument of the multiplication.

§multiplier: Value

The second argument of the multiplication.

A multiplication operation performed by Rust failed.

§

DivisionError

Fields

§dividend: Value

The first argument of the division.

§divisor: Value

The second argument of the division.

A division operation performed by Rust failed.

§

ModulationError

Fields

§dividend: Value

The first argument of the modulation.

§divisor: Value

The second argument of the modulation.

A modulation operation performed by Rust failed.

§

InvalidRegex

Fields

§regex: String

The invalid regular expression

§message: String

Failure message from the regex engine

A regular expression could not be parsed

§

ContextNotMutable

A modification was attempted on a Context that does not allow modifications.

§

IllegalEscapeSequence(String)

An escape sequence within a string literal is illegal.

§

BuiltinFunctionsCannotBeEnabled

This context does not allow enabling builtin functions.

§

BuiltinFunctionsCannotBeDisabled

This context does not allow disabling builtin functions.

§

MacroFailure(String)

The function failed due to an external error.

§

CustomMessage(String)

A custom error explained by its message.

Implementations§

source§

impl Error

source

pub fn type_error(actual: Value, expected: &'static [ValueType]) -> Self

source

pub fn wrong_type_combination( operator: Operator, actual: Vec<ValueType> ) -> Self

source

pub fn expected_string(actual: Value) -> Self

source

pub fn expected_int(actual: Value) -> Self

source

pub fn expected_float(actual: Value) -> Self

source

pub fn expected_number(actual: Value) -> Self

source

pub fn expected_number_or_string(actual: Value) -> Self

source

pub fn expected_boolean(actual: Value) -> Self

source

pub fn expected_list(actual: Value) -> Self

source

pub fn expected_fixed_len_list(expected_len: usize, actual: Value) -> Self

source

pub fn expected_empty(actual: Value) -> Self

source

pub fn expected_map(actual: Value) -> Self

source

pub fn expected_table(actual: Value) -> Self

source

pub fn expected_function(actual: Value) -> Self

source

pub fn expected_collection(actual: Value) -> Self

source

pub fn invalid_regex(regex: String, message: String) -> Self

Constructs EvalexprError::InvalidRegex(regex)

Trait Implementations§

source§

impl Clone for Error

source§

fn clone(&self) -> Error

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Error

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for Error

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Error for Error

1.30.0 · source§

fn source(&self) -> Option<&(dyn Error + 'static)>

The lower-level source of this error, if any. Read more
1.0.0 · source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type based access to context intended for error reports. Read more
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<Error> for Error

source§

fn from(value: Error) -> Self

Converts to this type from the input type.
source§

impl From<SystemTimeError> for Error

source§

fn from(value: SystemTimeError) -> Self

Converts to this type from the input type.
source§

impl PartialEq<Error> for Error

source§

fn eq(&self, other: &Error) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl StructuralPartialEq for Error

Auto Trait Implementations§

§

impl RefUnwindSafe for Error

§

impl Send for Error

§

impl Sync for Error

§

impl Unpin for Error

§

impl UnwindSafe for Error

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> SerializableAny for Twhere T: 'static + Any + Clone + Send + Sync,