Struct alloy_dyn_abi::DynSolError

source ·
pub struct DynSolError { /* private fields */ }
Expand description

A dynamic ABI error.

This is a representation of a Solidity error, which can be used to decode error events.

Implementations§

source§

impl DynSolError

source

pub fn revert() -> Self

Represents a standard Solidity revert. These are thrown by revert(reason) or require(condition, reason) statements in Solidity.

Note: Usage of this instantiator is not recommended. It is better to use alloy_sol_types::Revert in almost all cases.

source

pub fn panic() -> Self

A Solidity panic.

Note: Usage of this instantiator is not recommended. It is better to use alloy_sol_types::Panic in almost all cases.

These are thrown by assert(condition) and by internal Solidity checks, such as arithmetic overflow or array bounds checks.

The list of all known panic codes can be found in the PanicKind enum.

source

pub const fn new_unchecked(selector: Selector, body: DynSolType) -> Self

Creates a new error, without length-checking the body. This allows creation of invalid errors.

source

pub fn new(selector: Selector, body: DynSolType) -> Option<Self>

Creates a new error from a selector.

source

pub const fn selector(&self) -> Selector

Error selector is the first 4 bytes of the keccak256 hash of the error declaration.

source

pub fn body(&self) -> &[DynSolType]

Error body types.

source

pub fn decode_error(&self, data: &[u8]) -> Result<DecodedError>

Decode the error from the given data.

Trait Implementations§

source§

impl Clone for DynSolError

source§

fn clone(&self) -> DynSolError

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 DynSolError

source§

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

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

impl PartialEq for DynSolError

source§

fn eq(&self, other: &DynSolError) -> 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 Specifier<DynSolError> for Error

source§

fn resolve(&self) -> Result<DynSolError>

Resolve the type into a value.
source§

impl StructuralPartialEq for DynSolError

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where 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, U> Into<U> for T
where 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.

source§

impl<T> ToOwned for T
where 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, U> TryFrom<U> for T
where 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 T
where 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.
source§

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

source§

fn vzip(self) -> V