zksync_error::anvil_zksync::halt

Enum HaltError

Source
#[non_exhaustive]
#[repr(u32)]
pub enum HaltError {
Show 22 variants ValidationFailed { msg: String, data: String, }, PaymasterValidationFailed { msg: String, data: String, }, PrePaymasterPreparationFailed { msg: String, data: String, }, PayForTxFailed { msg: String, data: String, }, FailedToMarkFactoryDependencies { msg: String, data: String, }, FailedToChargeFee { msg: String, data: String, }, FromIsNotAnAccount = 7, InnerTxError = 8, Unknown { msg: String, data: String, }, UnexpectedVMBehavior { problem: String, }, BootloaderOutOfGas = 11, ValidationOutOfGas = 12, TooBigGasLimit = 13, NotEnoughGasProvided = 14, MissingInvocationLimitReached = 15, FailedToSetL2Block { msg: String, }, FailedToAppendTransactionToL2Block { msg: String, }, VMPanic = 18, TracerCustom { msg: String, }, FailedToPublishCompressedBytecodes = 20, FailedBlockTimestampAssertion = 21, GenericError { message: String, },
}
Expand description

Domain: AnvilZKsync

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.
§

ValidationFailed

§Summary

Account validation failed during execution.

§Description

This error occurs when the account validation step fails during the verification and execution of a transaction.

Fields

§data: String
§

PaymasterValidationFailed

§Summary

Paymaster validation failed.

§Description

This error is emitted when the paymaster validation process fails during transaction execution.

Fields

§data: String
§

PrePaymasterPreparationFailed

§Summary

Pre-paymaster preparation step failed.

§Description

This error occurs during pre-transaction paymaster preparation if the paymaster input is too short (less than 4 bytes) or its selector is unsupported.

Fields

§data: String
§

PayForTxFailed

§Summary

Payment for the transaction failed.

§Description

This error is emitted when the system fails to deduct the required fees for executing the transaction.

Fields

§data: String
§

FailedToMarkFactoryDependencies

§Summary

Failed to register factory dependencies for L1 transactions.

§Description

This error occurs when the system is unable to mark the factory dependencies for an L1 transaction in the known code storage. For L1 transactions, factory dependencies must be recorded as known to ensure that all required code components are available. A failure here may indicate that the dependency data is missing or malformed.

Fields

§data: String
§

FailedToChargeFee

§Summary

Transaction fee deduction failed.

§Description

This error is raised when the funds transferred to the bootloader are insufficient compared to the required fee (calculated as gasLimit * gasPrice). This may occur when the payer (account or paymaster) does not send enough ETH or when fee parameters are misconfigured.

Fields

§data: String
§

FromIsNotAnAccount = 7

§Summary

The sender address is not a valid account.

§Description

This error occurs when a transaction is attempted from an address that has not been deployed as an account, meaning the from address is just a contract.

§

InnerTxError = 8

§Summary

An inner transaction error occurred.

§Description

Transaction reverted due to a contract call that failed during execution.

§

Unknown

§Summary

An unknown error occurred.

§Description

This error is emitted when the system encounters an unspecified reason for halting.

Fields

§data: String
§

UnexpectedVMBehavior

§Summary

The bootloader encountered an unexpected state.

§Description

This error can be triggered by various bootloader anomalies such as mismatched fee parameters (e.g., baseFee greater than maxFeePerGas), unaccepted pubdata price, failed system calls (like L1 messenger or System Context), or internal assertion failures.

Fields

§problem: String
§

BootloaderOutOfGas = 11

§Summary

The bootloader has run out of gas.

§Description

This error occurs when the bootloader does not have enough gas to continue executing the transaction.

§

ValidationOutOfGas = 12

§Summary

The validation step ran out of gas.

§Description

Validation step of transaction execution exceeds the allocated gas limit.

§

TooBigGasLimit = 13

§Summary

The transaction’s gas limit is excessively high.

§Description

This error occurs when the gas limit set for the transaction is too large for the server to handle.

§

NotEnoughGasProvided = 14

§Summary

Insufficient gas for the bootloader to continue the transaction.

§Description

The bootloader checks if it can supply the requested gas plus overhead. If the remaining gas is below this threshold, it reverts.

§

MissingInvocationLimitReached = 15

§Summary

The transaction exceeded the allowed number of storage invocations.

§Description

This error occurs when the transaction makes too many missing invocations to memory, surpassing the allowed limit.

§

FailedToSetL2Block

§Summary

Unable to set L2 block information.

§Description

System failed to set the necessary information for the L2 block during execution.

Fields

§

FailedToAppendTransactionToL2Block

§Summary

Unable to append the transaction hash to the ongoing L2 block.

§Description

The system context call to record this transaction in the current L2 block failed. Common causes include invalid or corrupted L2 block data, insufficient gas, or unforeseen internal errors in the system context.

Fields

§

VMPanic = 18

§Summary

The virtual machine encountered a panic.

§Description

VM experiences a critical failure and panic during transaction execution.

§

TracerCustom

§Summary

Tracer aborted the transaction execution.

§Description

Custom tracer used during transaction execution decides to abort the process, typically due to specific conditions being met.

Fields

§

FailedToPublishCompressedBytecodes = 20

§Summary

Unable to publish compressed bytecodes.

§Description

Emitted when the system fails to publish the compressed bytecodes during execution.

§

FailedBlockTimestampAssertion = 21

§Summary

Block timestamp assertion failed during the transaction.

§Description

This error often occurs if the transaction’s timestamp is behind the last known block or conflicts with expected chronological order.

§

GenericError

Fields

§message: String

Trait Implementations§

Source§

impl AsRef<str> for Halt

Source§

fn as_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Clone for Halt

Source§

fn clone(&self) -> Halt

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 CustomErrorMessage for Halt

Source§

impl Debug for Halt

Source§

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

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

impl<'de> Deserialize<'de> for Halt

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for Halt

Source§

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

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

impl Documented for Halt

Source§

type Documentation = &'static ErrorDocumentation

Source§

fn get_documentation( &self, ) -> Result<Option<Self::Documentation>, DocumentationError>

Source§

impl Error for Halt

1.30.0 · Source§

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

Returns 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<'_enum> From<&'_enum Halt> for HaltCode

Source§

fn from(val: &'_enum Halt) -> HaltCode

Converts to this type from the input type.
Source§

impl From<Error> for Halt

Source§

fn from(value: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Halt> for AnvilZksync

Source§

fn from(val: Halt) -> Self

Converts to this type from the input type.
Source§

impl From<Halt> for HaltCode

Source§

fn from(val: Halt) -> HaltCode

Converts to this type from the input type.
Source§

impl From<Halt> for PackedError<ZksyncError>

Source§

fn from(value: Halt) -> Self

Converts to this type from the input type.
Source§

impl From<Halt> for SerializedError

Source§

fn from(value: Halt) -> Self

Converts to this type from the input type.
Source§

impl From<Halt> for ZksyncError

Source§

fn from(val: Halt) -> Self

Converts to this type from the input type.
Source§

impl ICustomError<ZksyncError, ZksyncError> for Halt

Source§

impl NamedError for Halt

Source§

impl PartialEq for Halt

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for Halt

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for Halt

Source§

impl StructuralPartialEq for Halt

Auto Trait Implementations§

§

impl Freeze for Halt

§

impl RefUnwindSafe for Halt

§

impl Send for Halt

§

impl Sync for Halt

§

impl Unpin for Halt

§

impl UnwindSafe for Halt

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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,

Source§

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 T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

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

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

Source§

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>,

Source§

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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,