Enum fuel_asm::PanicReason
source · #[non_exhaustive]#[repr(u8)]pub enum PanicReason {
Show 54 variants
UnknownPanicReason = 0,
Revert = 1,
OutOfGas = 2,
TransactionValidity = 3,
MemoryOverflow = 4,
ArithmeticOverflow = 5,
ContractNotFound = 6,
MemoryOwnership = 7,
NotEnoughBalance = 8,
ExpectedInternalContext = 9,
AssetIdNotFound = 10,
InputNotFound = 11,
OutputNotFound = 12,
WitnessNotFound = 13,
TransactionMaturity = 14,
InvalidMetadataIdentifier = 15,
MalformedCallStructure = 16,
ReservedRegisterNotWritable = 17,
InvalidFlags = 18,
InvalidImmediateValue = 19,
ExpectedCoinInput = 20,
EcalError = 21,
MemoryWriteOverlap = 22,
ContractNotInInputs = 23,
InternalBalanceOverflow = 24,
ContractMaxSize = 25,
ExpectedUnallocatedStack = 26,
MaxStaticContractsReached = 27,
TransferAmountCannotBeZero = 28,
ExpectedOutputVariable = 29,
ExpectedParentInternalContext = 30,
PredicateReturnedNonOne = 31,
ContractIdAlreadyDeployed = 32,
ContractMismatch = 33,
MessageDataTooLong = 34,
ArithmeticError = 35,
ContractInstructionNotAllowed = 36,
TransferZeroCoins = 37,
InvalidInstruction = 38,
MemoryNotExecutable = 39,
PolicyIsNotSet = 40,
PolicyNotFound = 41,
TooManyReceipts = 42,
BalanceOverflow = 43,
InvalidBlockHeight = 44,
TooManySlots = 45,
ExpectedNestedCaller = 46,
MemoryGrowthOverlap = 47,
UninitalizedMemoryAccess = 48,
OverridingConsensusParameters = 49,
UnknownStateTransactionBytecodeRoot = 50,
OverridingStateTransactionBytecode = 51,
BytecodeAlreadyUploaded = 52,
ThePartIsNotSequentiallyConnected = 53,
}
Expand description
Panic reason representation for the interpreter.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
UnknownPanicReason = 0
The byte can’t be mapped to any known PanicReason
.
Revert = 1
Found RVRT
instruction.
OutOfGas = 2
Execution ran out of gas.
TransactionValidity = 3
The transaction validity is violated.
MemoryOverflow = 4
Attempt to write outside interpreter memory boundaries.
ArithmeticOverflow = 5
Overflow while executing arithmetic operation. These errors are ignored using the WRAPPING flag.
ContractNotFound = 6
Designed contract was not found in the storage.
MemoryOwnership = 7
Memory ownership rules are violated.
NotEnoughBalance = 8
The asset ID balance isn’t enough for the instruction.
ExpectedInternalContext = 9
The interpreter is expected to be in internal context.
AssetIdNotFound = 10
The queried asset ID was not found in the state.
InputNotFound = 11
The provided input is not found in the transaction.
OutputNotFound = 12
The provided output is not found in the transaction.
WitnessNotFound = 13
The provided witness is not found in the transaction.
TransactionMaturity = 14
The transaction maturity is not valid for this request.
InvalidMetadataIdentifier = 15
The metadata identifier is invalid.
MalformedCallStructure = 16
The call structure is not valid.
ReservedRegisterNotWritable = 17
The provided register does not allow write operations.
InvalidFlags = 18
The execution resulted in an erroneous state of the interpreter.
InvalidImmediateValue = 19
The provided immediate value is not valid for this instruction.
ExpectedCoinInput = 20
The provided transaction input is not of type Coin
.
EcalError = 21
ECAL
instruction failed.
MemoryWriteOverlap = 22
Two segments of the interpreter memory should not intersect for write operations.
ContractNotInInputs = 23
The requested contract is not listed in the transaction inputs.
InternalBalanceOverflow = 24
The internal asset ID balance overflowed with the provided instruction.
ContractMaxSize = 25
The maximum allowed contract size is violated.
ExpectedUnallocatedStack = 26
This instruction expects the stack area to be unallocated for this call.
MaxStaticContractsReached = 27
The maximum allowed number of static contracts was reached for this transaction.
TransferAmountCannotBeZero = 28
The requested transfer amount cannot be zero.
ExpectedOutputVariable = 29
The provided transaction output should be of type Variable
.
ExpectedParentInternalContext = 30
The expected context of the stack parent is internal.
PredicateReturnedNonOne = 31
The predicate returned non 1
. The 1
means successful verification
of the predicate, all other values means unsuccessful.
ContractIdAlreadyDeployed = 32
The contract ID is already deployed and can’t be overwritten.
ContractMismatch = 33
The loaded contract mismatch expectations.
MessageDataTooLong = 34
Attempting to send message data longer than MAX_MESSAGE_DATA_LENGTH
ArithmeticError = 35
Mathematically invalid arguments where given to an arithmetic instruction. For instance, division by zero produces this. These errors are ignored using the UNSAFEMATH flag.
ContractInstructionNotAllowed = 36
The contract instruction is not allowed in predicates.
TransferZeroCoins = 37
Transfer of zero coins is not allowed.
InvalidInstruction = 38
Attempted to execute an invalid instruction
MemoryNotExecutable = 39
Memory outside $is..$ssp range is not executable
PolicyIsNotSet = 40
The policy is not set.
PolicyNotFound = 41
The policy is not found across policies.
TooManyReceipts = 42
Receipt context is full
BalanceOverflow = 43
Balance of a contract overflowed
InvalidBlockHeight = 44
Block height value is invalid, typically because it is too large
TooManySlots = 45
Attempt to use sequential memory instructions with too large slot count, typically because it cannot fit into usize
ExpectedNestedCaller = 46
Caller of this internal context is also expected to be internal, i.e. $fp->$fp must be non-zero.
MemoryGrowthOverlap = 47
During memory growth, the stack overlapped with the heap
UninitalizedMemoryAccess = 48
Attempting to read or write uninitialized memory. Also occurs when boundary crosses from stack to heap.
OverridingConsensusParameters = 49
Overriding consensus parameters is not allowed.
UnknownStateTransactionBytecodeRoot = 50
The storage doesn’t know about the hash of the state transition bytecode.
OverridingStateTransactionBytecode = 51
Overriding the state transition bytecode is not allowed.
BytecodeAlreadyUploaded = 52
The bytecode is already uploaded and cannot be uploaded again.
ThePartIsNotSequentiallyConnected = 53
The part of the bytecode is not sequentially connected to the previous parts.
Trait Implementations§
source§impl<'arbitrary> Arbitrary<'arbitrary> for PanicReason
impl<'arbitrary> Arbitrary<'arbitrary> for PanicReason
source§fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
Self
from the given unstructured data. Read moresource§fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
Self
from the entirety of the given
unstructured data. Read moresource§impl Clone for PanicReason
impl Clone for PanicReason
source§fn clone(&self) -> PanicReason
fn clone(&self) -> PanicReason
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for PanicReason
impl Debug for PanicReason
source§impl<'de> Deserialize<'de> for PanicReason
impl<'de> Deserialize<'de> for PanicReason
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl Deserialize for PanicReason
impl Deserialize for PanicReason
source§fn decode_static<I: Input + ?Sized>(buffer: &mut I) -> Result<Self, Error>
fn decode_static<I: Input + ?Sized>(buffer: &mut I) -> Result<Self, Error>
Self
from the buffer
.source§fn decode_dynamic<I: Input + ?Sized>(
&mut self,
buffer: &mut I,
) -> Result<(), Error>
fn decode_dynamic<I: Input + ?Sized>( &mut self, buffer: &mut I, ) -> Result<(), Error>
buffer
to fill Self
.
The default implementation does nothing. Dynamically-sized contains should
override this.source§impl Display for PanicReason
impl Display for PanicReason
source§impl From<PanicReason> for JsValue
impl From<PanicReason> for JsValue
source§fn from(value: PanicReason) -> Self
fn from(value: PanicReason) -> Self
source§impl From<TryFromSliceError> for PanicReason
impl From<TryFromSliceError> for PanicReason
source§fn from(_: TryFromSliceError) -> Self
fn from(_: TryFromSliceError) -> Self
source§impl From<u8> for PanicReason
impl From<u8> for PanicReason
source§impl FromWasmAbi for PanicReason
impl FromWasmAbi for PanicReason
source§impl Hash for PanicReason
impl Hash for PanicReason
source§impl IntoEnumIterator for PanicReason
impl IntoEnumIterator for PanicReason
source§impl IntoWasmAbi for PanicReason
impl IntoWasmAbi for PanicReason
source§impl OptionFromWasmAbi for PanicReason
impl OptionFromWasmAbi for PanicReason
source§impl OptionIntoWasmAbi for PanicReason
impl OptionIntoWasmAbi for PanicReason
source§impl PartialEq for PanicReason
impl PartialEq for PanicReason
source§fn eq(&self, other: &PanicReason) -> bool
fn eq(&self, other: &PanicReason) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl Serialize for PanicReason
impl Serialize for PanicReason
source§fn size_static(&self) -> usize
fn size_static(&self) -> usize
source§fn size_dynamic(&self) -> usize
fn size_dynamic(&self) -> usize
source§fn encode_static<O: Output + ?Sized>(&self, buffer: &mut O) -> Result<(), Error>
fn encode_static<O: Output + ?Sized>(&self, buffer: &mut O) -> Result<(), Error>
Self
.source§fn encode_dynamic<O: Output + ?Sized>(
&self,
buffer: &mut O,
) -> Result<(), Error>
fn encode_dynamic<O: Output + ?Sized>( &self, buffer: &mut O, ) -> Result<(), Error>
Self
.
The default implementation does nothing. Dynamically-sized contains should
override this.source§fn size(&self) -> usize
fn size(&self) -> usize
source§impl Serialize for PanicReason
impl Serialize for PanicReason
source§impl TryFromJsValue for PanicReason
impl TryFromJsValue for PanicReason
source§fn try_from_js_value(
value: JsValue,
) -> Result<Self, <PanicReason as TryFromJsValue>::Error>
fn try_from_js_value( value: JsValue, ) -> Result<Self, <PanicReason as TryFromJsValue>::Error>
source§impl VectorFromWasmAbi for PanicReason
impl VectorFromWasmAbi for PanicReason
type Abi = <Box<[JsValue]> as FromWasmAbi>::Abi
unsafe fn vector_from_abi(js: Self::Abi) -> Box<[PanicReason]>
source§impl VectorIntoWasmAbi for PanicReason
impl VectorIntoWasmAbi for PanicReason
type Abi = <Box<[JsValue]> as IntoWasmAbi>::Abi
fn vector_into_abi(vector: Box<[PanicReason]>) -> Self::Abi
source§impl WasmDescribeVector for PanicReason
impl WasmDescribeVector for PanicReason
impl Copy for PanicReason
impl Eq for PanicReason
impl StructuralPartialEq for PanicReason
Auto Trait Implementations§
impl Freeze for PanicReason
impl RefUnwindSafe for PanicReason
impl Send for PanicReason
impl Sync for PanicReason
impl Unpin for PanicReason
impl UnwindSafe for PanicReason
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> ReturnWasmAbi for Twhere
T: IntoWasmAbi,
impl<T> ReturnWasmAbi for Twhere
T: IntoWasmAbi,
§type Abi = <T as IntoWasmAbi>::Abi
type Abi = <T as IntoWasmAbi>::Abi
IntoWasmAbi::Abi
source§fn return_abi(self) -> <T as ReturnWasmAbi>::Abi
fn return_abi(self) -> <T as ReturnWasmAbi>::Abi
IntoWasmAbi::into_abi
, except that it may throw and never
return in the case of Err
.