[][src]Struct solana_runtime::bank::Bank

pub struct Bank {
    pub rc: BankRc,
    pub src: StatusCacheRc,
    pub ancestors: HashMap<Slot, usize>,
    pub last_vote_sync: AtomicU64,
    pub rewards: Option<Vec<(Pubkey, i64)>>,
    // some fields omitted
}

Manager for the state of all accounts and programs after processing its entries.

Fields

rc: BankRc

References to accounts, parent and signature status

src: StatusCacheRcancestors: HashMap<Slot, usize>

The set of parents including this bank

last_vote_sync: AtomicU64

Last time when the cluster info vote listener has synced with this bank

rewards: Option<Vec<(Pubkey, i64)>>

Rewards that were paid out immediately after this bank was created

Methods

impl Bank[src]

pub fn new(genesis_config: &GenesisConfig) -> Self[src]

pub fn new_with_paths(
    genesis_config: &GenesisConfig,
    paths: Vec<PathBuf>,
    frozen_account_pubkeys: &[Pubkey]
) -> Self
[src]

pub fn new_from_parent(
    parent: &Arc<Bank>,
    collector_id: &Pubkey,
    slot: Slot
) -> Self
[src]

Create a new bank that points to an immutable checkpoint of another bank.

pub fn collector_id(&self) -> &Pubkey[src]

pub fn slot(&self) -> Slot[src]

pub fn epoch(&self) -> Epoch[src]

pub fn freeze_lock(&self) -> RwLockReadGuard<Hash>[src]

pub fn hash(&self) -> Hash[src]

pub fn is_frozen(&self) -> bool[src]

pub fn status_cache_ancestors(&self) -> Vec<u64>[src]

pub fn unix_timestamp(&self) -> i64[src]

computed unix_timestamp at this slot height

pub fn update_recent_blockhashes(&self)[src]

pub fn freeze(&self)[src]

pub fn epoch_schedule(&self) -> &EpochSchedule[src]

pub fn squash(&self)[src]

squash the parent's state up into this Bank, this Bank becomes a root

pub fn parent(&self) -> Option<Arc<Bank>>[src]

Return the more recent checkpoint of this bank instance.

pub fn parent_slot(&self) -> Slot[src]

pub fn register_native_instruction_processor(
    &self,
    name: &str,
    program_id: &Pubkey
)
[src]

pub fn last_blockhash(&self) -> Hash[src]

Return the last block hash registered.

pub fn get_minimum_balance_for_rent_exemption(&self, data_len: usize) -> u64[src]

pub fn last_blockhash_with_fee_calculator(&self) -> (Hash, FeeCalculator)[src]

pub fn get_fee_calculator(&self, hash: &Hash) -> Option<FeeCalculator>[src]

pub fn get_fee_rate_governor(&self) -> &FeeRateGovernor[src]

pub fn confirmed_last_blockhash(&self) -> (Hash, FeeCalculator)[src]

pub fn clear_signatures(&self)[src]

Forget all signatures. Useful for benchmarking.

pub fn can_commit(result: &Result<()>) -> bool[src]

pub fn register_tick(&self, hash: &Hash)[src]

Tell the bank which Entry IDs exist on the ledger. This function assumes subsequent calls correspond to later entries, and will boot the oldest ones once its internal cache is full. Once boot, the bank will reject transactions using that hash.

pub fn is_complete(&self) -> bool[src]

pub fn is_block_boundary(&self, tick_height: u64) -> bool[src]

pub fn process_transaction(&self, tx: &Transaction) -> Result<()>[src]

Process a Transaction. This is used for unit tests and simply calls the vector Bank::process_transactions method

pub fn prepare_batch<'a, 'b>(
    &'a self,
    txs: &'b [Transaction],
    iteration_order: Option<Vec<usize>>
) -> TransactionBatch<'a, 'b>
[src]

pub fn unlock_accounts(&self, batch: &mut TransactionBatch)[src]

pub fn check_hash_age(&self, hash: &Hash, max_age: usize) -> Option<bool>[src]

pub fn check_tx_durable_nonce(
    &self,
    tx: &Transaction
) -> Option<(Pubkey, Account)>
[src]

pub fn check_transactions(
    &self,
    txs: &[Transaction],
    iteration_order: Option<&[usize]>,
    lock_results: &[Result<()>],
    max_age: usize,
    error_counters: &mut ErrorCounters
) -> Vec<TransactionProcessResult>
[src]

pub fn collect_balances(&self, batch: &[Transaction]) -> TransactionBalances[src]

pub fn load_and_execute_transactions(
    &self,
    batch: &TransactionBatch,
    max_age: usize
) -> (Vec<(Result<TransactionLoadResult>, Option<HashAgeKind>)>, Vec<TransactionProcessResult>, Vec<usize>, u64, u64)
[src]

pub fn commit_transactions(
    &self,
    txs: &[Transaction],
    iteration_order: Option<&[usize]>,
    loaded_accounts: &mut [(Result<TransactionLoadResult>, Option<HashAgeKind>)],
    executed: &[TransactionProcessResult],
    tx_count: u64,
    signature_count: u64
) -> TransactionResults
[src]

#[must_use]pub fn load_execute_and_commit_transactions(
    &self,
    batch: &TransactionBatch,
    max_age: usize,
    collect_balances: bool
) -> (TransactionResults, TransactionBalancesSet)
[src]

Process a batch of transactions.

#[must_use]pub fn process_transactions(&self, txs: &[Transaction]) -> Vec<Result<()>>[src]

pub fn transfer(
    &self,
    n: u64,
    keypair: &Keypair,
    to: &Pubkey
) -> Result<Signature>
[src]

Create, sign, and process a Transaction from keypair to to of n lamports where blockhash is the last Entry ID observed by the client.

pub fn read_balance(account: &Account) -> u64[src]

pub fn get_balance(&self, pubkey: &Pubkey) -> u64[src]

Each program would need to be able to introspect its own state this is hard-coded to the Budget language

pub fn parents(&self) -> Vec<Arc<Bank>>[src]

Compute all the parents of the bank in order

pub fn store_account(&self, pubkey: &Pubkey, account: &Account)[src]

pub fn withdraw(&self, pubkey: &Pubkey, lamports: u64) -> Result<()>[src]

pub fn deposit(&self, pubkey: &Pubkey, lamports: u64)[src]

pub fn accounts(&self) -> Arc<Accounts>[src]

pub fn set_bank_rc(&mut self, bank_rc: BankRc, status_cache_rc: StatusCacheRc)[src]

pub fn set_parent(&mut self, parent: &Arc<Bank>)[src]

pub fn set_inflation(&self, inflation: Inflation)[src]

pub fn hard_forks(&self) -> Arc<RwLock<HardForks>>[src]

pub fn set_entered_epoch_callback(
    &self,
    entered_epoch_callback: EnteredEpochCallback
)
[src]

pub fn get_account(&self, pubkey: &Pubkey) -> Option<Account>[src]

pub fn get_program_accounts(
    &self,
    program_id: Option<&Pubkey>
) -> Vec<(Pubkey, Account)>
[src]

pub fn get_program_accounts_modified_since_parent(
    &self,
    program_id: &Pubkey
) -> Vec<(Pubkey, Account)>
[src]

pub fn get_account_modified_since_parent(
    &self,
    pubkey: &Pubkey
) -> Option<(Account, Slot)>
[src]

pub fn transaction_count(&self) -> u64[src]

pub fn signature_count(&self) -> u64[src]

pub fn get_signature_status_processed_since_parent(
    &self,
    signature: &Signature
) -> Option<Result<()>>
[src]

pub fn get_signature_confirmation_status(
    &self,
    signature: &Signature
) -> Option<SignatureConfirmationStatus<Result<()>>>
[src]

pub fn get_signature_status(&self, signature: &Signature) -> Option<Result<()>>[src]

pub fn has_signature(&self, signature: &Signature) -> bool[src]

pub fn get_snapshot_storages(&self) -> SnapshotStorages[src]

pub fn get_accounts_hash(&self) -> Hash[src]

pub fn update_accounts_hash(&self) -> Hash[src]

pub fn verify_snapshot_bank(&self) -> bool[src]

A snapshot bank should be purged of 0 lamport accounts which are not part of the hash calculation and could shield other real accounts.

pub fn hashes_per_tick(&self) -> &Option<u64>[src]

Return the number of hashes per tick

pub fn ticks_per_slot(&self) -> u64[src]

Return the number of ticks per slot

pub fn slots_per_year(&self) -> f64[src]

Return the number of slots per year

pub fn slots_per_segment(&self) -> u64[src]

Return the number of slots per segment

pub fn tick_height(&self) -> u64[src]

Return the number of ticks since genesis.

pub fn inflation(&self) -> Inflation[src]

Return the inflation parameters of the Bank

pub fn capitalization(&self) -> u64[src]

Return the total capititalization of the Bank

pub fn max_tick_height(&self) -> u64[src]

Return this bank's max_tick_height

pub fn block_height(&self) -> u64[src]

Return the block_height of this bank

pub fn get_slots_in_epoch(&self, epoch: Epoch) -> u64[src]

Return the number of slots per epoch for the given epoch

pub fn get_leader_schedule_epoch(&self, slot: Slot) -> Epoch[src]

returns the epoch for which this bank's leader_schedule_slot_offset and slot would need to cache leader_schedule

pub fn storage_accounts(&self) -> StorageAccounts[src]

pub fn stake_delegations(&self) -> HashMap<Pubkey, Delegation>[src]

current stake delegations for this bank Note: this method is exposed publicly for external usage

pub fn vote_accounts(&self) -> HashMap<Pubkey, (u64, Account)>[src]

current vote accounts for this bank along with the stake attributed to each account

pub fn epoch_vote_accounts(
    &self,
    epoch: Epoch
) -> Option<&HashMap<Pubkey, (u64, Account)>>
[src]

vote accounts for the specific epoch along with the stake attributed to each account

pub fn get_epoch_and_slot_index(&self, slot: Slot) -> (u64, u64)[src]

given a slot, return the epoch and offset into the epoch this slot falls e.g. with a fixed number for slots_per_epoch, the calculation is simply:

( slot/slots_per_epoch, slot % slots_per_epoch )

pub fn is_empty(&self) -> bool[src]

pub fn add_instruction_processor(
    &mut self,
    program_id: Pubkey,
    process_instruction: ProcessInstruction
)
[src]

Add an instruction processor to intercept instructions before the dynamic loader.

pub fn compare_bank(&self, dbank: &Bank)[src]

pub fn clean_accounts(&self)[src]

Trait Implementations

impl Default for Bank[src]

impl<'de> Deserialize<'de> for Bank[src]

impl Drop for Bank[src]

impl Serialize for Bank[src]

Auto Trait Implementations

impl !RefUnwindSafe for Bank

impl Send for Bank

impl Sync for Bank

impl Unpin for Bank

impl !UnwindSafe for Bank

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Clear for T where
    T: InitializableFromZeroed + ?Sized

impl<T> DeserializeOwned for T where
    T: Deserialize<'de>, 
[src]

impl<T> From<T> for T[src]

impl<T> InitializableFromZeroed for T where
    T: Default

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

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