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

pub struct Bank {
    pub rc: BankRc,
    pub src: StatusCacheRc,
    pub ancestors: Ancestors,
    pub last_vote_sync: AtomicU64,
    pub rewards: Option<Vec<(Pubkey, i64)>>,
    pub skip_drop: AtomicBool,
    pub cluster_type: Option<ClusterType>,
    pub lazy_rent_collection: AtomicBool,
    pub rewards_pool_pubkeys: Arc<HashSet<Pubkey>>,
    pub feature_set: Arc<FeatureSet>,
    // some fields omitted
}

Manager for the state of all accounts and programs after processing its entries. AbiExample is needed even without Serialize/Deserialize; actual (de-)serialization are implemented elsewhere for versioning

Fields

rc: BankRc

References to accounts, parent and signature status

src: StatusCacheRcancestors: Ancestors

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

skip_drop: AtomicBoolcluster_type: Option<ClusterType>lazy_rent_collection: AtomicBoolrewards_pool_pubkeys: Arc<HashSet<Pubkey>>feature_set: Arc<FeatureSet>

Implementations

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],
    debug_keys: Option<Arc<HashSet<Pubkey>>>,
    additional_builtins: Option<&Builtins>
) -> 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 warp_from_parent(
    parent: &Arc<Bank>,
    collector_id: &Pubkey,
    slot: Slot
) -> Self
[src]

Like new_from_parent but additionally:

  • Doesn't assume that the parent is anywhere near slot, parent could be millions of slots in the past
  • Adjusts the new bank's tick height to avoid having to run PoH for millions of slots
  • Freezes the new bank, assuming that the user will Bank::new_from_parent from this bank

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

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

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

pub fn first_normal_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 get_unused_from_slot(rooted_slot: Slot, unused: u64) -> u64[src]

Unused conversion

pub fn clock(&self) -> Clock[src]

pub fn update_recent_blockhashes(&self)[src]

pub fn rehash(&self)[src]

pub fn freeze(&self)[src]

pub fn exhaustively_free_unused_resource(&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 add_native_program(&self, name: &str, program_id: &Pubkey)[src]

pub fn set_cross_program_support(&mut self, is_supported: bool)[src]

pub fn set_compute_budget(&mut self, budget: ComputeBudget)[src]

pub fn set_rent_burn_percentage(&mut self, burn_percent: u8)[src]

pub fn set_hashes_per_tick(&mut self, hashes_per_tick: Option<u64>)[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 get_blockhash_last_valid_slot(&self, blockhash: &Hash) -> Option<Slot>[src]

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

pub fn clear_signatures(&self)[src]

Forget all signatures. Useful for benchmarking.

pub fn clear_slot_signatures(&self, slot: Slot)[src]

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 prepare_simulation_batch<'a, 'b>(
    &'a self,
    txs: &'b [Transaction]
) -> TransactionBatch<'a, 'b>
[src]

pub fn simulate_transaction(
    &self,
    transaction: Transaction
) -> (Result<()>, Vec<String>)
[src]

Run transactions against a frozen bank without committing the results

pub fn unlock_accounts(&self, batch: &mut TransactionBatch<'_, '_>)[src]

pub fn remove_unrooted_slot(&self, slot: Slot)[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: &TransactionBatch<'_, '_>
) -> TransactionBalances
[src]

pub fn remove_executor(&self, pubkey: &Pubkey)[src]

Remove an executor from the bank's cache

pub fn load_and_execute_transactions(
    &self,
    batch: &TransactionBatch<'_, '_>,
    max_age: usize,
    log_collector: Option<Rc<LogCollector>>,
    enable_cpi_recording: bool
) -> (Vec<(Result<TransactionLoadResult>, Option<HashAgeKind>)>, Vec<TransactionProcessResult>, Vec<Option<InnerInstructionsList>>, 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]

pub fn cluster_type(&self) -> ClusterType[src]

#[must_use]pub fn load_execute_and_commit_transactions(
    &self,
    batch: &TransactionBatch<'_, '_>,
    max_age: usize,
    collect_balances: bool,
    enable_cpi_recording: bool
) -> (TransactionResults, TransactionBalancesSet, Vec<Option<InnerInstructionsList>>)
[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_inflation(&self, inflation: Inflation)[src]

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

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

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

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

pub fn get_all_accounts_with_modified_slots(
    &self
) -> Vec<(Pubkey, Account, Slot)>
[src]

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

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

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

pub fn get_largest_accounts(
    &self,
    num: usize,
    filter_by_address: &HashSet<Pubkey>,
    filter: AccountAddressFilter
) -> Vec<(Pubkey, u64)>
[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_status_slot(
    &self,
    signature: &Signature
) -> Option<(Slot, 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 calculate_capitalization(&self) -> u64[src]

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

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

Forcibly overwrites current capitalization by actually recalculating accounts' balances. This should only be used for developing purposes.

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 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 capitalization 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 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_stakes(&self, epoch: Epoch) -> Option<&EpochStakes>[src]

Get the EpochStakes for a given epoch

pub fn epoch_stakes_map(&self) -> &HashMap<Epoch, EpochStakes>[src]

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 epoch_authorized_voter(&self, vote_account: &Pubkey) -> Option<&Pubkey>[src]

Get the fixed authorized voter for the given vote account for the current epoch

pub fn epoch_vote_accounts_for_node_id(
    &self,
    node_id: &Pubkey
) -> Option<&NodeVoteAccounts>
[src]

Get the fixed set of vote accounts for the given node id for the current epoch

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

Get the fixed total stake of all vote accounts for current epoch

pub fn epoch_vote_account_stake(&self, vote_account: &Pubkey) -> u64[src]

Get the fixed stake of the given vote account for the current epoch

pub fn get_epoch_and_slot_index(&self, slot: Slot) -> (Epoch, SlotIndex)[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 get_epoch_info(&self) -> EpochInfo[src]

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

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

pub fn add_builtin_loader(
    &mut self,
    name: &str,
    program_id: Pubkey,
    process_instruction_with_context: ProcessInstructionWithContext
)
[src]

pub fn add_builtin(
    &mut self,
    name: &str,
    program_id: Pubkey,
    entrypoint: Entrypoint
)
[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]

pub fn process_dead_slots(&self)[src]

pub fn shrink_all_slots(&self)[src]

pub fn print_accounts_stats(&self)[src]

pub fn process_stale_slot_with_budget(
    &self,
    consumed_budget: usize,
    budget_recovery_delta: usize
) -> usize
[src]

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

Trait Implementations

impl AbiExample for Bank[src]

impl Default for Bank[src]

impl Drop 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> AbiExample for T[src]

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> From<T> for T[src]

impl<T> Instrument for T[src]

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