pub enum InstructionError {
Show 52 variants
    GenericError,
    InvalidArgument,
    InvalidInstructionData,
    InvalidAccountData,
    AccountDataTooSmall,
    InsufficientFunds,
    IncorrectProgramId,
    MissingRequiredSignature,
    AccountAlreadyInitialized,
    UninitializedAccount,
    UnbalancedInstruction,
    ModifiedProgramId,
    ExternalAccountLamportSpend,
    ExternalAccountDataModified,
    ReadonlyLamportChange,
    ReadonlyDataModified,
    DuplicateAccountIndex,
    ExecutableModified,
    RentEpochModified,
    NotEnoughAccountKeys,
    AccountDataSizeChanged,
    AccountNotExecutable,
    AccountBorrowFailed,
    AccountBorrowOutstanding,
    DuplicateAccountOutOfSync,
    Custom(u32),
    InvalidError,
    ExecutableDataModified,
    ExecutableLamportChange,
    ExecutableAccountNotRentExempt,
    UnsupportedProgramId,
    CallDepth,
    MissingAccount,
    ReentrancyNotAllowed,
    MaxSeedLengthExceeded,
    InvalidSeeds,
    InvalidRealloc,
    ComputationalBudgetExceeded,
    PrivilegeEscalation,
    ProgramEnvironmentSetupFailure,
    ProgramFailedToComplete,
    ProgramFailedToCompile,
    Immutable,
    IncorrectAuthority,
    BorshIoError(String),
    AccountNotRentExempt,
    InvalidAccountOwner,
    ArithmeticOverflow,
    UnsupportedSysvar,
    IllegalOwner,
    MaxAccountsDataSizeExceeded,
    ActiveVoteAccountClose,
}Expand description
Reasons the runtime might have rejected an instruction.
Instructions errors are included in the bank hashes and therefore are included as part of the transaction results when determining consensus. Because of this, members of this enum must not be removed, but new ones can be added. Also, it is crucial that meta-information if any that comes along with an error be consistent across software versions. For example, it is dangerous to include error strings from 3rd party crates because they could change at any time and changes to them are difficult to detect.
Variants
GenericError
Deprecated! Use CustomError instead! The program instruction returned an error
InvalidArgument
The arguments provided to a program were invalid
InvalidInstructionData
An instruction’s data contents were invalid
InvalidAccountData
An account’s data contents was invalid
AccountDataTooSmall
An account’s data was too small
InsufficientFunds
An account’s balance was too small to complete the instruction
IncorrectProgramId
The account did not have the expected program id
MissingRequiredSignature
A signature was required but not found
AccountAlreadyInitialized
An initialize instruction was sent to an account that has already been initialized.
UninitializedAccount
An attempt to operate on an account that hasn’t been initialized.
UnbalancedInstruction
Program’s instruction lamport balance does not equal the balance after the instruction
ModifiedProgramId
Program illegally modified an account’s program id
ExternalAccountLamportSpend
Program spent the lamports of an account that doesn’t belong to it
ExternalAccountDataModified
Program modified the data of an account that doesn’t belong to it
ReadonlyLamportChange
Read-only account’s lamports modified
ReadonlyDataModified
Read-only account’s data was modified
DuplicateAccountIndex
An account was referenced more than once in a single instruction
ExecutableModified
Executable bit on account changed, but shouldn’t have
RentEpochModified
Rent_epoch account changed, but shouldn’t have
NotEnoughAccountKeys
The instruction expected additional account keys
AccountDataSizeChanged
Program other than the account’s owner changed the size of the account data
AccountNotExecutable
The instruction expected an executable account
AccountBorrowFailed
Failed to borrow a reference to account data, already borrowed
AccountBorrowOutstanding
Account data has an outstanding reference after a program’s execution
DuplicateAccountOutOfSync
The same account was multiply passed to an on-chain program’s entrypoint, but the program modified them differently. A program can only modify one instance of the account because the runtime cannot determine which changes to pick or how to merge them if both are modified
Custom(u32)
Allows on-chain programs to implement program-specific error types and see them returned by the Solana runtime. A program-specific error may be any type that is represented as or serialized to a u32 integer.
InvalidError
The return value from the program was invalid. Valid errors are either a defined builtin error value or a user-defined error in the lower 32 bits.
ExecutableDataModified
Executable account’s data was modified
ExecutableLamportChange
Executable account’s lamports modified
ExecutableAccountNotRentExempt
Executable accounts must be rent exempt
UnsupportedProgramId
Unsupported program id
CallDepth
Cross-program invocation call depth too deep
MissingAccount
An account required by the instruction is missing
ReentrancyNotAllowed
Cross-program invocation reentrancy not allowed for this instruction
MaxSeedLengthExceeded
Length of the seed is too long for address generation
InvalidSeeds
Provided seeds do not result in a valid address
InvalidRealloc
Failed to reallocate account data of this length
ComputationalBudgetExceeded
Computational budget exceeded
PrivilegeEscalation
Cross-program invocation with unauthorized signer or writable account
ProgramEnvironmentSetupFailure
Failed to create program execution environment
ProgramFailedToComplete
Program failed to complete
ProgramFailedToCompile
Program failed to compile
Immutable
Account is immutable
IncorrectAuthority
Incorrect authority provided
BorshIoError(String)
Failed to serialize or deserialize account data
Warning: This error should never be emitted by the runtime.
This error includes strings from the underlying 3rd party Borsh crate which can be dangerous because the error strings could change across Borsh versions. Only programs can use this error because they are consistent across Solana software versions.
AccountNotRentExempt
An account does not have enough lamports to be rent-exempt
InvalidAccountOwner
Invalid account owner
ArithmeticOverflow
Program arithmetic overflowed
UnsupportedSysvar
Unsupported sysvar
IllegalOwner
Illegal account owner
MaxAccountsDataSizeExceeded
Account data allocation exceeded the maximum accounts data size limit
ActiveVoteAccountClose
Active vote account close
Trait Implementations
sourceimpl AbiEnumVisitor for InstructionError
 
impl AbiEnumVisitor for InstructionError
fn visit_for_abi(&self, digester: &mut AbiDigester) -> DigestResult
sourceimpl AbiExample for InstructionError
 
impl AbiExample for InstructionError
sourceimpl Clone for InstructionError
 
impl Clone for InstructionError
sourcefn clone(&self) -> InstructionError
 
fn clone(&self) -> InstructionError
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
sourceimpl Debug for InstructionError
 
impl Debug for InstructionError
sourceimpl<'de> Deserialize<'de> for InstructionError
 
impl<'de> Deserialize<'de> for InstructionError
sourcefn 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>, 
Deserialize this value from the given Serde deserializer. Read more
sourceimpl Display for InstructionError
 
impl Display for InstructionError
sourceimpl Error for InstructionError
 
impl Error for InstructionError
1.30.0 · sourcefn source(&self) -> Option<&(dyn Error + 'static)>
 
fn source(&self) -> Option<&(dyn Error + 'static)>
The lower-level source of this error, if any. Read more
sourcefn backtrace(&self) -> Option<&Backtrace>
 
fn backtrace(&self) -> Option<&Backtrace>
backtrace)Returns a stack backtrace, if available, of where this error occurred. Read more
1.0.0 · sourcefn description(&self) -> &str
 
fn description(&self) -> &str
use the Display impl or to_string()
sourceimpl From<LamportsError> for InstructionError
 
impl From<LamportsError> for InstructionError
sourcefn from(error: LamportsError) -> Self
 
fn from(error: LamportsError) -> Self
Performs the conversion.
sourceimpl<T> From<T> for InstructionError where
    T: ToPrimitive, 
 
impl<T> From<T> for InstructionError where
    T: ToPrimitive, 
sourceimpl PartialEq<InstructionError> for InstructionError
 
impl PartialEq<InstructionError> for InstructionError
sourcefn eq(&self, other: &InstructionError) -> bool
 
fn eq(&self, other: &InstructionError) -> bool
This method tests for self and other values to be equal, and is used
by ==. Read more
sourcefn ne(&self, other: &InstructionError) -> bool
 
fn ne(&self, other: &InstructionError) -> bool
This method tests for !=.
sourceimpl Serialize for InstructionError
 
impl Serialize for InstructionError
sourceimpl TryFrom<InstructionError> for ProgramError
 
impl TryFrom<InstructionError> for ProgramError
type Error = InstructionError
type Error = InstructionError
The type returned in the event of a conversion error.
sourcefn try_from(error: InstructionError) -> Result<Self, Self::Error>
 
fn try_from(error: InstructionError) -> Result<Self, Self::Error>
Performs the conversion.
impl Eq for InstructionError
impl StructuralEq for InstructionError
impl StructuralPartialEq for InstructionError
Auto Trait Implementations
impl RefUnwindSafe for InstructionError
impl Send for InstructionError
impl Sync for InstructionError
impl Unpin for InstructionError
impl UnwindSafe for InstructionError
Blanket Implementations
sourceimpl<T> AbiEnumVisitor for T where
    T: Serialize + ?Sized, 
 
impl<T> AbiEnumVisitor for T where
    T: Serialize + ?Sized, 
default fn visit_for_abi(
    &self, 
    _digester: &mut AbiDigester
) -> Result<AbiDigester, DigestError>
sourceimpl<T> AbiEnumVisitor for T where
    T: Serialize + AbiExample + ?Sized, 
 
impl<T> AbiEnumVisitor for T where
    T: Serialize + AbiExample + ?Sized, 
default fn visit_for_abi(
    &self, 
    digester: &mut AbiDigester
) -> Result<AbiDigester, DigestError>
sourceimpl<T> AbiExample for T
 
impl<T> AbiExample for T
sourceimpl<T> BorrowMut<T> for T where
    T: ?Sized, 
 
impl<T> BorrowMut<T> for T where
    T: ?Sized, 
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
    T: Clone, 
 
impl<T> ToOwned for T where
    T: Clone, 
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
 
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more