pub enum StakePoolError {
Show 43 variants AlreadyInUse, InvalidProgramAddress, InvalidState, CalculationFailure, FeeTooHigh, WrongAccountMint, WrongManager, SignatureMissing, InvalidValidatorStakeList, InvalidFeeAccount, WrongPoolMint, WrongStakeStake, UserStakeNotActive, ValidatorAlreadyAdded, ValidatorNotFound, InvalidStakeAccountAddress, StakeListOutOfDate, StakeListAndPoolOutOfDate, UnknownValidatorStakeAccount, WrongMintingAuthority, UnexpectedValidatorListAccountSize, WrongStaker, NonZeroPoolTokenSupply, StakeLamportsNotEqualToMinimum, IncorrectDepositVoteAddress, IncorrectWithdrawVoteAddress, InvalidMintFreezeAuthority, FeeIncreaseTooHigh, WithdrawalTooSmall, DepositTooSmall, InvalidStakeDepositAuthority, InvalidSolDepositAuthority, InvalidPreferredValidator, TransientAccountInUse, InvalidSolWithdrawAuthority, SolWithdrawalTooLarge, InvalidMetadataAccount, UnsupportedMintExtension, UnsupportedFeeAccountExtension, ExceededSlippage, IncorrectMintDecimals, ReserveDepleted, MissingRequiredSysvar,
}
Expand description

Errors that may be returned by the StakePool program.

Variants§

§

AlreadyInUse

The account cannot be initialized because it is already being used.

§

InvalidProgramAddress

The program address provided doesn’t match the value generated by the program.

§

InvalidState

The stake pool state is invalid.

§

CalculationFailure

The calculation failed.

§

FeeTooHigh

Stake pool fee > 1.

§

WrongAccountMint

Token account is associated with the wrong mint.

§

WrongManager

Wrong pool manager account.

§

SignatureMissing

Required signature is missing.

§

InvalidValidatorStakeList

Invalid validator stake list account.

§

InvalidFeeAccount

Invalid manager fee account.

§

WrongPoolMint

Specified pool mint account is wrong.

§

WrongStakeStake

Stake account is not in the state expected by the program.

§

UserStakeNotActive

User stake is not active

§

ValidatorAlreadyAdded

Stake account voting for this validator already exists in the pool.

§

ValidatorNotFound

Stake account for this validator not found in the pool.

§

InvalidStakeAccountAddress

Stake account address not properly derived from the validator address.

§

StakeListOutOfDate

Identify validator stake accounts with old balances and update them.

§

StakeListAndPoolOutOfDate

First update old validator stake account balances and then pool stake balance.

§

UnknownValidatorStakeAccount

Validator stake account is not found in the list storage.

§

WrongMintingAuthority

Wrong minting authority set for mint pool account

§

UnexpectedValidatorListAccountSize

The size of the given validator stake list does match the expected amount

§

WrongStaker

Wrong pool staker account.

§

NonZeroPoolTokenSupply

Pool token supply is not zero on initialization

§

StakeLamportsNotEqualToMinimum

The lamports in the validator stake account is not equal to the minimum

§

IncorrectDepositVoteAddress

The provided deposit stake account is not delegated to the preferred deposit vote account

§

IncorrectWithdrawVoteAddress

The provided withdraw stake account is not the preferred deposit vote account

§

InvalidMintFreezeAuthority

The mint has an invalid freeze authority

§

FeeIncreaseTooHigh

Proposed fee increase exceeds stipulated ratio

§

WithdrawalTooSmall

Not enough pool tokens provided to withdraw stake with one lamport

§

DepositTooSmall

Not enough lamports provided for deposit to result in one pool token

§

InvalidStakeDepositAuthority

Provided stake deposit authority does not match the program’s

§

InvalidSolDepositAuthority

Provided sol deposit authority does not match the program’s

§

InvalidPreferredValidator

Provided preferred validator is invalid

§

TransientAccountInUse

Provided validator stake account already has a transient stake account in use

§

InvalidSolWithdrawAuthority

Provided sol withdraw authority does not match the program’s

§

SolWithdrawalTooLarge

Too much SOL withdrawn from the stake pool’s reserve account

§

InvalidMetadataAccount

Provided metadata account does not match metadata account derived for pool mint

§

UnsupportedMintExtension

The mint has an unsupported extension

§

UnsupportedFeeAccountExtension

The fee account has an unsupported extension

§

ExceededSlippage

Instruction exceeds desired slippage limit

§

IncorrectMintDecimals

Provided mint does not have 9 decimals to match SOL

§

ReserveDepleted

Pool reserve does not have enough lamports to fund rent-exempt reserve in split destination. Deposit more SOL in reserve, or pre-fund split destination with the rent-exempt reserve for a stake account.

§

MissingRequiredSysvar

Missing required sysvar account

Trait Implementations§

source§

impl Clone for StakePoolError

source§

fn clone(&self) -> StakePoolError

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 StakePoolError

source§

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

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

impl<T> DecodeError<T> for StakePoolError

source§

fn type_of() -> &'static str

source§

impl Display for StakePoolError

source§

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

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

impl Error for StakePoolError

1.30.0 · source§

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

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 From<StakePoolError> for ProgramError

source§

fn from(e: StakePoolError) -> Self

Converts to this type from the input type.
source§

impl FromPrimitive for StakePoolError

source§

fn from_i64(n: i64) -> Option<Self>

Converts an i64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u64(n: u64) -> Option<Self>

Converts an u64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_isize(n: isize) -> Option<Self>

Converts an isize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i8(n: i8) -> Option<Self>

Converts an i8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i16(n: i16) -> Option<Self>

Converts an i16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i32(n: i32) -> Option<Self>

Converts an i32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_i128(n: i128) -> Option<Self>

Converts an i128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

fn from_usize(n: usize) -> Option<Self>

Converts a usize to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u8(n: u8) -> Option<Self>

Converts an u8 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u16(n: u16) -> Option<Self>

Converts an u16 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u32(n: u32) -> Option<Self>

Converts an u32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_u128(n: u128) -> Option<Self>

Converts an u128 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

fn from_f32(n: f32) -> Option<Self>

Converts a f32 to return an optional value of this type. If the value cannot be represented by this type, then None is returned.
source§

fn from_f64(n: f64) -> Option<Self>

Converts a f64 to return an optional value of this type. If the value cannot be represented by this type, then None is returned. Read more
source§

impl PartialEq for StakePoolError

source§

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

source§

fn print<E>(&self)
where E: 'static + Error + DecodeError<E> + PrintProgramError + FromPrimitive,

source§

impl Eq for StakePoolError

source§

impl StructuralEq for StakePoolError

source§

impl StructuralPartialEq for StakePoolError

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

default fn example() -> T

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
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
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> ToString for T
where T: Display + ?Sized,

source§

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

§

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

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

§

fn vzip(self) -> V