pub struct InstructionContext { /* private fields */ }
Expand description

Loaded instruction shared between runtime and programs.

This context is valid for the entire duration of a (possibly cross program) instruction being processed.

Implementations§

source§

impl InstructionContext

source

pub fn configure( &mut self, program_accounts: &[IndexOfAccount], instruction_accounts: &[InstructionAccount], instruction_data: &[u8] )

Used together with TransactionContext::get_next_instruction_context()

source

pub fn get_stack_height(&self) -> usize

How many Instructions were on the stack after this one was pushed

That is the number of nested parent Instructions plus one (itself).

source

pub fn get_number_of_program_accounts(&self) -> IndexOfAccount

Number of program accounts

source

pub fn get_number_of_instruction_accounts(&self) -> IndexOfAccount

Number of accounts in this Instruction (without program accounts)

source

pub fn check_number_of_instruction_accounts( &self, expected_at_least: IndexOfAccount ) -> Result<(), InstructionError>

Assert that enough accounts were supplied to this Instruction

source

pub fn get_instruction_data(&self) -> &[u8]

Data parameter for the programs process_instruction handler

source

pub fn find_index_of_program_account( &self, transaction_context: &TransactionContext, pubkey: &Pubkey ) -> Option<IndexOfAccount>

Searches for a program account by its key

source

pub fn find_index_of_instruction_account( &self, transaction_context: &TransactionContext, pubkey: &Pubkey ) -> Option<IndexOfAccount>

Searches for an instruction account by its key

source

pub fn get_index_of_program_account_in_transaction( &self, program_account_index: IndexOfAccount ) -> Result<IndexOfAccount, InstructionError>

Translates the given instruction wide program_account_index into a transaction wide index

source

pub fn get_index_of_instruction_account_in_transaction( &self, instruction_account_index: IndexOfAccount ) -> Result<IndexOfAccount, InstructionError>

Translates the given instruction wide instruction_account_index into a transaction wide index

source

pub fn is_instruction_account_duplicate( &self, instruction_account_index: IndexOfAccount ) -> Result<Option<IndexOfAccount>, InstructionError>

Returns Some(instruction_account_index) if this is a duplicate and None if it is the first account with this key

source

pub fn get_last_program_key<'a, 'b: 'a>( &'a self, transaction_context: &'b TransactionContext ) -> Result<&'b Pubkey, InstructionError>

Gets the key of the last program account of this Instruction

source

pub fn try_borrow_last_program_account<'a, 'b: 'a>( &'a self, transaction_context: &'b TransactionContext ) -> Result<BorrowedAccount<'a>, InstructionError>

Gets the last program account of this Instruction

source

pub fn try_borrow_program_account<'a, 'b: 'a>( &'a self, transaction_context: &'b TransactionContext, program_account_index: IndexOfAccount ) -> Result<BorrowedAccount<'a>, InstructionError>

Tries to borrow a program account from this Instruction

source

pub fn try_borrow_instruction_account<'a, 'b: 'a>( &'a self, transaction_context: &'b TransactionContext, instruction_account_index: IndexOfAccount ) -> Result<BorrowedAccount<'a>, InstructionError>

Gets an instruction account of this Instruction

source

pub fn is_instruction_account_signer( &self, instruction_account_index: IndexOfAccount ) -> Result<bool, InstructionError>

Returns whether an instruction account is a signer

source

pub fn is_instruction_account_writable( &self, instruction_account_index: IndexOfAccount ) -> Result<bool, InstructionError>

Returns whether an instruction account is writable

source

pub fn get_signers( &self, transaction_context: &TransactionContext ) -> Result<HashSet<Pubkey>, InstructionError>

Calculates the set of all keys of signer instruction accounts in this Instruction

Trait Implementations§

source§

impl Clone for InstructionContext

source§

fn clone(&self) -> InstructionContext

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 InstructionContext

source§

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

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

impl Default for InstructionContext

source§

fn default() -> InstructionContext

Returns the “default value” for a type. Read more
source§

impl PartialEq for InstructionContext

source§

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

source§

impl StructuralPartialEq for InstructionContext

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> AbiExample for T

source§

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

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

source§

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.

source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

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

Initializes a with the given initializer. Read more
source§

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

Dereferences the given pointer. Read more
source§

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

Mutably dereferences the given pointer. Read more
source§

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

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

source§

fn vzip(self) -> V