zksync_error::anvil_zksync::halt

Enum ErrorCode

Source
#[repr(u32)]
pub enum ErrorCode {
Show 22 variants ValidationFailed = 1, PaymasterValidationFailed = 2, PrePaymasterPreparationFailed = 3, PayForTxFailed = 4, FailedToMarkFactoryDependencies = 5, FailedToChargeFee = 6, FromIsNotAnAccount = 7, InnerTxError = 8, Unknown = 9, UnexpectedVMBehavior = 10, BootloaderOutOfGas = 11, ValidationOutOfGas = 12, TooBigGasLimit = 13, NotEnoughGasProvided = 14, MissingInvocationLimitReached = 15, FailedToSetL2Block = 16, FailedToAppendTransactionToL2Block = 17, VMPanic = 18, TracerCustom = 19, FailedToPublishCompressedBytecodes = 20, FailedBlockTimestampAssertion = 21, GenericError = 0,
}
Expand description

Auto-generated discriminant enum variants

Variants§

§

ValidationFailed = 1

§Summary

Account validation failed during execution.

§Description

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

§

PaymasterValidationFailed = 2

§Summary

Paymaster validation failed.

§Description

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

§

PrePaymasterPreparationFailed = 3

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

§

PayForTxFailed = 4

§Summary

Payment for the transaction failed.

§Description

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

§

FailedToMarkFactoryDependencies = 5

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

§

FailedToChargeFee = 6

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

§

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 = 9

§Summary

An unknown error occurred.

§Description

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

§

UnexpectedVMBehavior = 10

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

§

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 = 16

§Summary

Unable to set L2 block information.

§Description

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

§

FailedToAppendTransactionToL2Block = 17

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

§

VMPanic = 18

§Summary

The virtual machine encountered a panic.

§Description

VM experiences a critical failure and panic during transaction execution.

§

TracerCustom = 19

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

§

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 = 0

Implementations§

Source§

impl HaltCode

Source

pub const fn from_repr(discriminant: u32) -> Option<HaltCode>

Try to create Self from the raw representation

Trait Implementations§

Source§

impl AsRef<str> for HaltCode

Source§

fn as_ref(&self) -> &str

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

impl Clone for HaltCode

Source§

fn clone(&self) -> HaltCode

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 HaltCode

Source§

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

Formats the value using the given formatter. 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<Halt> for HaltCode

Source§

fn from(val: Halt) -> HaltCode

Converts to this type from the input type.
Source§

impl NamedError for HaltCode

Source§

impl PartialEq for HaltCode

Source§

fn eq(&self, other: &HaltCode) -> 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 Copy for HaltCode

Source§

impl Eq for HaltCode

Source§

impl StructuralPartialEq for HaltCode

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