Documentation ¶
Index ¶
- type Block
- type BlockWrapper
- type Config
- type State
- func (s *State) BuildBlock() (snowman.Block, error)
- func (s *State) Flush()
- func (s *State) GetBlock(blkID ids.ID) (snowman.Block, error)
- func (s *State) GetBlockInternal(blkID ids.ID) (snowman.Block, error)
- func (s *State) LastAccepted() (ids.ID, error)
- func (s *State) LastAcceptedBlock() *BlockWrapper
- func (s *State) LastAcceptedBlockInternal() snowman.Block
- func (s *State) ParseBlock(b []byte) (snowman.Block, error)
- func (s *State) SetLastAcceptedBlock(lastAcceptedBlock snowman.Block) error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Block ¶
Block is an interface wrapping the normal snowman.Block interface to be used in association with passing in a non-nil function to GetBlockIDAtHeight
type BlockWrapper ¶
BlockWrapper wraps a snowman Block while adding a smart caching layer to improve VM performance.
func (*BlockWrapper) Accept ¶
func (bw *BlockWrapper) Accept() error
Accept accepts the underlying block, removes it from verifiedBlocks, caches it as a decided block, and updates the last accepted block.
func (*BlockWrapper) Reject ¶
func (bw *BlockWrapper) Reject() error
Reject rejects the underlying block, removes it from processing blocks, and caches it as a decided block.
func (*BlockWrapper) Verify ¶
func (bw *BlockWrapper) Verify() error
Verify verifies the underlying block, evicts from the unverified block cache and if the block passes verification, adds it to [cache.verifiedBlocks]. Note: it is guaranteed that if a block passes verification it will be added to consensus and eventually be decided ie. either Accept/Reject will be called on [bw] removing it from [verifiedBlocks].
type Config ¶
type Config struct {
// Cache configuration:
DecidedCacheSize, MissingCacheSize, UnverifiedCacheSize, BytesToIDCacheSize int
LastAcceptedBlock snowman.Block
GetBlock func(ids.ID) (snowman.Block, error)
UnmarshalBlock func([]byte) (snowman.Block, error)
BuildBlock func() (snowman.Block, error)
GetBlockIDAtHeight func(uint64) (ids.ID, error)
}
Config defines all of the parameters necessary to initialize State
type State ¶
type State struct {
// contains filtered or unexported fields
}
State implements an efficient caching layer used to wrap a VM implementation.
func NewMeteredState ¶
func NewMeteredState( registerer prometheus.Registerer, config *Config, ) (*State, error)
func (*State) BuildBlock ¶
BuildBlock attempts to build a new internal Block, wraps it, and adds it to the appropriate caching layer if successful.
func (*State) GetBlock ¶
GetBlock returns the BlockWrapper as snowman.Block corresponding to [blkID]
func (*State) GetBlockInternal ¶
GetBlockInternal returns the internal representation of [blkID]
func (*State) LastAcceptedBlock ¶
func (s *State) LastAcceptedBlock() *BlockWrapper
LastAcceptedBlock returns the last accepted wrapped block
func (*State) LastAcceptedBlockInternal ¶
LastAcceptedBlockInternal returns the internal snowman.Block that was last accepted
func (*State) ParseBlock ¶
ParseBlock attempts to parse [b] into an internal Block and adds it to the appropriate caching layer if successful.
func (*State) SetLastAcceptedBlock ¶
SetLastAcceptedBlock sets the last accepted block to [lastAcceptedBlock]. This should be called with an internal block - not a wrapped block returned from state.
This also flushes [lastAcceptedBlock] from missingBlocks and unverifiedBlocks to ensure that their contents stay valid.