Documentation ¶
Index ¶
- Constants
- Variables
- func AdvanceStateByBlock(ctx context.Context, bc *core.BlockChain, state *state.StateDB, ...) (*state.StateDB, *types.Block, error)
- func AdvanceStateUpToBlock(ctx context.Context, bc *core.BlockChain, state *state.StateDB, ...) (*state.StateDB, error)
- func ConfigAddOptions(prefix string, f *flag.FlagSet)
- func CreateFallbackClient(fallbackClientUrl string, fallbackClientTimeout time.Duration) (types.FallbackClient, error)
- func EstimateGas(ctx context.Context, b ethapi.Backend, args TransactionArgs, ...) (hexutil.Uint64, error)
- func NewRevertReason(result *core.ExecutionResult) error
- func RecordingDatabaseConfigAddOptions(prefix string, f *flag.FlagSet)
- func SendConditionalTransactionRPC(ctx context.Context, rpc *rpc.Client, tx *types.Transaction, ...) error
- func StateAndHeaderFromHeader(ctx context.Context, chainDb ethdb.Database, bc *core.BlockChain, ...) (*state.StateDB, *types.Header, error)
- func SubmitConditionalTransaction(ctx context.Context, b *APIBackend, tx *types.Transaction, ...) (common.Hash, error)
- type APIBackend
- func (a *APIBackend) AccountManager() *accounts.Manager
- func (a *APIBackend) BlockByHash(ctx context.Context, hash common.Hash) (*types.Block, error)
- func (a *APIBackend) BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error)
- func (a *APIBackend) BlockByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Block, error)
- func (a *APIBackend) BlockChain() *core.BlockChain
- func (a *APIBackend) BloomStatus() (uint64, uint64)
- func (a *APIBackend) ChainConfig() *params.ChainConfig
- func (a *APIBackend) ChainDb() ethdb.Database
- func (a *APIBackend) CurrentBlock() *types.Header
- func (a *APIBackend) CurrentHeader() *types.Header
- func (a *APIBackend) Engine() consensus.Engine
- func (a *APIBackend) ExtRPCEnabled() bool
- func (b *APIBackend) FallbackClient() types.FallbackClient
- func (a *APIBackend) FeeHistory(ctx context.Context, blocks uint64, newestBlock rpc.BlockNumber, ...) (*big.Int, [][]*big.Int, []*big.Int, []float64, error)
- func (a *APIBackend) GetAPIs(filterSystem *filters.FilterSystem) []rpc.API
- func (a *APIBackend) GetArbitrumNode() interface{}
- func (a *APIBackend) GetBody(ctx context.Context, hash common.Hash, number rpc.BlockNumber) (*types.Body, error)
- func (a *APIBackend) GetEVM(ctx context.Context, msg *core.Message, state vm.StateDB, header *types.Header, ...) *vm.EVM
- func (a *APIBackend) GetLogs(ctx context.Context, hash common.Hash, number uint64) ([][]*types.Log, error)
- func (a *APIBackend) GetPoolNonce(ctx context.Context, addr common.Address) (uint64, error)
- func (a *APIBackend) GetPoolTransaction(txHash common.Hash) *types.Transaction
- func (a *APIBackend) GetPoolTransactions() (types.Transactions, error)
- func (a *APIBackend) GetReceipts(ctx context.Context, hash common.Hash) (types.Receipts, error)
- func (a *APIBackend) GetTd(ctx context.Context, hash common.Hash) *big.Int
- func (a *APIBackend) GetTransaction(ctx context.Context, txHash common.Hash) (bool, *types.Transaction, common.Hash, uint64, uint64, error)
- func (a *APIBackend) HeaderByHash(ctx context.Context, hash common.Hash) (*types.Header, error)
- func (a *APIBackend) HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error)
- func (a *APIBackend) HeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Header, error)
- func (b *APIBackend) PendingBlockAndReceipts() (*types.Block, types.Receipts)
- func (a *APIBackend) RPCEVMTimeout() time.Duration
- func (a *APIBackend) RPCGasCap() uint64
- func (a *APIBackend) RPCTxFeeCap() float64
- func (a *APIBackend) SendConditionalTx(ctx context.Context, signedTx *types.Transaction, ...) error
- func (a *APIBackend) SendTx(ctx context.Context, signedTx *types.Transaction) error
- func (a *APIBackend) ServiceFilter(ctx context.Context, session *bloombits.MatcherSession)
- func (a *APIBackend) SetHead(number uint64)
- func (a *APIBackend) SetSyncBackend(sync SyncProgressBackend) error
- func (a *APIBackend) StateAndHeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*state.StateDB, *types.Header, error)
- func (a *APIBackend) StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (vm.StateDB, *types.Header, error)
- func (a *APIBackend) StateAtBlock(ctx context.Context, block *types.Block, reexec uint64, base *state.StateDB, ...) (statedb *state.StateDB, release tracers.StateReleaseFunc, err error)
- func (a *APIBackend) StateAtTransaction(ctx context.Context, block *types.Block, txIndex int, reexec uint64) (*core.Message, vm.BlockContext, *state.StateDB, tracers.StateReleaseFunc, ...)
- func (a *APIBackend) Stats() (pending int, queued int)
- func (a *APIBackend) SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription
- func (a *APIBackend) SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription
- func (a *APIBackend) SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription
- func (a *APIBackend) SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription
- func (a *APIBackend) SubscribeNewTxsEvent(ch chan<- core.NewTxsEvent) event.Subscription
- func (a *APIBackend) SubscribePendingLogsEvent(ch chan<- []*types.Log) event.Subscription
- func (a *APIBackend) SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription
- func (a *APIBackend) SuggestGasTipCap(ctx context.Context) (*big.Int, error)
- func (a *APIBackend) SyncProgress() ethereum.SyncProgress
- func (a *APIBackend) SyncProgressMap() map[string]interface{}
- func (a *APIBackend) TxPoolContent() (map[common.Address][]*types.Transaction, ...)
- func (a *APIBackend) TxPoolContentFrom(addr common.Address) ([]*types.Transaction, []*types.Transaction)
- func (a *APIBackend) UnprotectedAllowed() bool
- type ArbDebugConfig
- type ArbInterface
- type ArbTransactionAPI
- type Backend
- func (b *Backend) APIBackend() *APIBackend
- func (b *Backend) APIs() []rpc.API
- func (b *Backend) AccountManager() *accounts.Manager
- func (b *Backend) ArbInterface() ArbInterface
- func (b *Backend) BlockChain() *core.BlockChain
- func (b *Backend) BloomIndexer() *core.ChainIndexer
- func (b *Backend) ChainDb() ethdb.Database
- func (b *Backend) Engine() consensus.Engine
- func (b *Backend) EnqueueL2Message(ctx context.Context, tx *types.Transaction, ...) error
- func (b *Backend) ResetWithGenesisBlock(gb *types.Block)
- func (b *Backend) Stack() *node.Node
- func (b *Backend) Start() error
- func (b *Backend) Stop() error
- func (b *Backend) SubscribeNewTxsEvent(ch chan<- core.NewTxsEvent) event.Subscription
- type Config
- type PublicNetAPI
- type PublicTxPoolAPI
- type RecordingChainContext
- type RecordingDatabase
- func (r *RecordingDatabase) Dereference(header *types.Header)
- func (r *RecordingDatabase) GetOrRecreateState(ctx context.Context, header *types.Header, logFunc StateBuildingLogFunction) (*state.StateDB, error)
- func (r *RecordingDatabase) PreimagesFromRecording(chainContextIf core.ChainContext, recordingDb *RecordingKV) (map[common.Hash][]byte, error)
- func (r *RecordingDatabase) PrepareRecording(ctx context.Context, lastBlockHeader *types.Header, ...) (*state.StateDB, core.ChainContext, *RecordingKV, error)
- func (r *RecordingDatabase) ReferenceCount() int64
- func (r *RecordingDatabase) StateFor(header *types.Header) (*state.StateDB, error)
- func (r *RecordingDatabase) WriteStateToDatabase(header *types.Header) error
- type RecordingDatabaseConfig
- type RecordingKV
- func (db *RecordingKV) Close() error
- func (db *RecordingKV) Compact(start []byte, limit []byte) error
- func (db *RecordingKV) Delete(key []byte) error
- func (db *RecordingKV) EnableBypass()
- func (db *RecordingKV) Get(key []byte) ([]byte, error)
- func (db *RecordingKV) GetRecordedEntries() map[common.Hash][]byte
- func (db *RecordingKV) Has(key []byte) (bool, error)
- func (db *RecordingKV) NewBatch() ethdb.Batch
- func (db *RecordingKV) NewBatchWithSize(size int) ethdb.Batch
- func (db *RecordingKV) NewIterator(prefix []byte, start []byte) ethdb.Iterator
- func (db *RecordingKV) NewSnapshot() (ethdb.Snapshot, error)
- func (db *RecordingKV) Put(key []byte, value []byte) error
- func (db *RecordingKV) Release()
- func (db *RecordingKV) Stat(property string) (string, error)
- type StateBuildingLogFunction
- type StateForHeaderFunction
- type StateReleaseFunc
- type SyncProgressBackend
- type TransactionArgs
Constants ¶
const ( DefaultArchiveNodeMaxRecreateStateDepth = 30 * 1000 * 1000 DefaultNonArchiveNodeMaxRecreateStateDepth = 0 // don't recreate state UninitializedMaxRecreateStateDepth = -2 InfiniteMaxRecreateStateDepth = -1 )
Variables ¶
var DefaultConfig = Config{ RPCGasCap: ethconfig.Defaults.RPCGasCap, RPCTxFeeCap: ethconfig.Defaults.RPCTxFeeCap, TxAllowUnprotected: true, RPCEVMTimeout: ethconfig.Defaults.RPCEVMTimeout, BloomBitsBlocks: params.BloomBitsBlocks * 4, BloomConfirms: params.BloomConfirms, FilterLogCacheSize: 32, FilterTimeout: 5 * time.Minute, FeeHistoryMaxBlockCount: 1024, ClassicRedirect: "", MaxRecreateStateDepth: UninitializedMaxRecreateStateDepth, AllowMethod: []string{}, ArbDebug: ArbDebugConfig{ BlockRangeBound: 256, TimeoutQueueBound: 512, }, }
var DefaultRecordingDatabaseConfig = RecordingDatabaseConfig{
TrieDirtyCache: 1024,
TrieCleanCache: 16,
}
var (
ErrDepthLimitExceeded = errors.New("state recreation l2 gas depth limit exceeded")
)
Functions ¶
func AdvanceStateByBlock ¶
func AdvanceStateUpToBlock ¶
func ConfigAddOptions ¶
func CreateFallbackClient ¶
func EstimateGas ¶
func EstimateGas(ctx context.Context, b ethapi.Backend, args TransactionArgs, blockNrOrHash rpc.BlockNumberOrHash, overrides *ethapi.StateOverride, gasCap uint64) (hexutil.Uint64, error)
func NewRevertReason ¶
func NewRevertReason(result *core.ExecutionResult) error
func SendConditionalTransactionRPC ¶
func SendConditionalTransactionRPC(ctx context.Context, rpc *rpc.Client, tx *types.Transaction, options *arbitrum_types.ConditionalOptions) error
func SubmitConditionalTransaction ¶
func SubmitConditionalTransaction(ctx context.Context, b *APIBackend, tx *types.Transaction, options *arbitrum_types.ConditionalOptions) (common.Hash, error)
Types ¶
type APIBackend ¶
type APIBackend struct {
// contains filtered or unexported fields
}
func (*APIBackend) AccountManager ¶
func (a *APIBackend) AccountManager() *accounts.Manager
func (*APIBackend) BlockByHash ¶
func (*APIBackend) BlockByNumber ¶
func (a *APIBackend) BlockByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Block, error)
func (*APIBackend) BlockByNumberOrHash ¶
func (a *APIBackend) BlockByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Block, error)
func (*APIBackend) BlockChain ¶
func (a *APIBackend) BlockChain() *core.BlockChain
func (*APIBackend) ChainConfig ¶
func (a *APIBackend) ChainConfig() *params.ChainConfig
func (*APIBackend) ChainDb ¶
func (a *APIBackend) ChainDb() ethdb.Database
func (*APIBackend) CurrentBlock ¶
func (a *APIBackend) CurrentBlock() *types.Header
func (*APIBackend) CurrentHeader ¶
func (a *APIBackend) CurrentHeader() *types.Header
func (*APIBackend) Engine ¶
func (a *APIBackend) Engine() consensus.Engine
func (*APIBackend) ExtRPCEnabled ¶
func (a *APIBackend) ExtRPCEnabled() bool
func (*APIBackend) FallbackClient ¶
func (b *APIBackend) FallbackClient() types.FallbackClient
func (*APIBackend) FeeHistory ¶
func (*APIBackend) GetAPIs ¶
func (a *APIBackend) GetAPIs(filterSystem *filters.FilterSystem) []rpc.API
func (*APIBackend) GetArbitrumNode ¶
func (a *APIBackend) GetArbitrumNode() interface{}
func (*APIBackend) GetBody ¶
func (a *APIBackend) GetBody(ctx context.Context, hash common.Hash, number rpc.BlockNumber) (*types.Body, error)
func (*APIBackend) GetPoolNonce ¶
func (*APIBackend) GetPoolTransaction ¶
func (a *APIBackend) GetPoolTransaction(txHash common.Hash) *types.Transaction
func (*APIBackend) GetPoolTransactions ¶
func (a *APIBackend) GetPoolTransactions() (types.Transactions, error)
func (*APIBackend) GetReceipts ¶
func (*APIBackend) GetTransaction ¶
func (*APIBackend) HeaderByHash ¶
func (*APIBackend) HeaderByNumber ¶
func (a *APIBackend) HeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*types.Header, error)
func (*APIBackend) HeaderByNumberOrHash ¶
func (a *APIBackend) HeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (*types.Header, error)
func (*APIBackend) PendingBlockAndReceipts ¶
func (b *APIBackend) PendingBlockAndReceipts() (*types.Block, types.Receipts)
func (*APIBackend) RPCEVMTimeout ¶
func (a *APIBackend) RPCEVMTimeout() time.Duration
func (*APIBackend) RPCGasCap ¶
func (a *APIBackend) RPCGasCap() uint64
func (*APIBackend) RPCTxFeeCap ¶
func (a *APIBackend) RPCTxFeeCap() float64
func (*APIBackend) SendConditionalTx ¶
func (a *APIBackend) SendConditionalTx(ctx context.Context, signedTx *types.Transaction, options *arbitrum_types.ConditionalOptions) error
func (*APIBackend) SendTx ¶
func (a *APIBackend) SendTx(ctx context.Context, signedTx *types.Transaction) error
Transaction pool API
func (*APIBackend) ServiceFilter ¶
func (a *APIBackend) ServiceFilter(ctx context.Context, session *bloombits.MatcherSession)
func (*APIBackend) SetSyncBackend ¶
func (a *APIBackend) SetSyncBackend(sync SyncProgressBackend) error
func (*APIBackend) StateAndHeaderByNumber ¶
func (a *APIBackend) StateAndHeaderByNumber(ctx context.Context, number rpc.BlockNumber) (*state.StateDB, *types.Header, error)
func (*APIBackend) StateAndHeaderByNumberOrHash ¶
func (a *APIBackend) StateAndHeaderByNumberOrHash(ctx context.Context, blockNrOrHash rpc.BlockNumberOrHash) (vm.StateDB, *types.Header, error)
func (*APIBackend) StateAtBlock ¶
func (*APIBackend) StateAtTransaction ¶
func (*APIBackend) Stats ¶
func (a *APIBackend) Stats() (pending int, queued int)
func (*APIBackend) SubscribeChainEvent ¶
func (a *APIBackend) SubscribeChainEvent(ch chan<- core.ChainEvent) event.Subscription
func (*APIBackend) SubscribeChainHeadEvent ¶
func (a *APIBackend) SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription
func (*APIBackend) SubscribeChainSideEvent ¶
func (a *APIBackend) SubscribeChainSideEvent(ch chan<- core.ChainSideEvent) event.Subscription
func (*APIBackend) SubscribeLogsEvent ¶
func (a *APIBackend) SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription
func (*APIBackend) SubscribeNewTxsEvent ¶
func (a *APIBackend) SubscribeNewTxsEvent(ch chan<- core.NewTxsEvent) event.Subscription
func (*APIBackend) SubscribePendingLogsEvent ¶
func (a *APIBackend) SubscribePendingLogsEvent(ch chan<- []*types.Log) event.Subscription
func (*APIBackend) SubscribeRemovedLogsEvent ¶
func (a *APIBackend) SubscribeRemovedLogsEvent(ch chan<- core.RemovedLogsEvent) event.Subscription
func (*APIBackend) SuggestGasTipCap ¶
func (*APIBackend) SyncProgress ¶
func (a *APIBackend) SyncProgress() ethereum.SyncProgress
func (*APIBackend) SyncProgressMap ¶
func (a *APIBackend) SyncProgressMap() map[string]interface{}
General Ethereum API
func (*APIBackend) TxPoolContent ¶
func (a *APIBackend) TxPoolContent() (map[common.Address][]*types.Transaction, map[common.Address][]*types.Transaction)
func (*APIBackend) TxPoolContentFrom ¶
func (a *APIBackend) TxPoolContentFrom(addr common.Address) ([]*types.Transaction, []*types.Transaction)
func (*APIBackend) UnprotectedAllowed ¶
func (a *APIBackend) UnprotectedAllowed() bool
type ArbDebugConfig ¶
type ArbInterface ¶
type ArbInterface interface { PublishTransaction(ctx context.Context, tx *types.Transaction, options *arbitrum_types.ConditionalOptions) error BlockChain() *core.BlockChain ArbNode() interface{} }
type ArbTransactionAPI ¶
type ArbTransactionAPI struct {
// contains filtered or unexported fields
}
func NewArbTransactionAPI ¶
func NewArbTransactionAPI(b *APIBackend) *ArbTransactionAPI
func (*ArbTransactionAPI) SendRawTransactionConditional ¶
func (s *ArbTransactionAPI) SendRawTransactionConditional(ctx context.Context, input hexutil.Bytes, options *arbitrum_types.ConditionalOptions) (common.Hash, error)
type Backend ¶
type Backend struct {
// contains filtered or unexported fields
}
func NewBackend ¶
func (*Backend) APIBackend ¶
func (b *Backend) APIBackend() *APIBackend
func (*Backend) AccountManager ¶
func (*Backend) ArbInterface ¶
func (b *Backend) ArbInterface() ArbInterface
func (*Backend) BlockChain ¶
func (b *Backend) BlockChain() *core.BlockChain
func (*Backend) BloomIndexer ¶
func (b *Backend) BloomIndexer() *core.ChainIndexer
func (*Backend) EnqueueL2Message ¶
func (b *Backend) EnqueueL2Message(ctx context.Context, tx *types.Transaction, options *arbitrum_types.ConditionalOptions) error
func (*Backend) ResetWithGenesisBlock ¶
func (*Backend) SubscribeNewTxsEvent ¶
func (b *Backend) SubscribeNewTxsEvent(ch chan<- core.NewTxsEvent) event.Subscription
type Config ¶
type Config struct { // RPCGasCap is the global gas cap for eth-call variants. RPCGasCap uint64 `koanf:"gas-cap"` // RPCTxFeeCap is the global transaction fee(price * gaslimit) cap for // send-transction variants. The unit is ether. RPCTxFeeCap float64 `koanf:"tx-fee-cap"` TxAllowUnprotected bool `koanf:"tx-allow-unprotected"` // RPCEVMTimeout is the global timeout for eth-call. RPCEVMTimeout time.Duration `koanf:"evm-timeout"` // Parameters for the bloom indexer BloomBitsBlocks uint64 `koanf:"bloom-bits-blocks"` BloomConfirms uint64 `koanf:"bloom-confirms"` // Parameters for the filter system FilterLogCacheSize int `koanf:"filter-log-cache-size"` FilterTimeout time.Duration `koanf:"filter-timeout"` // FeeHistoryMaxBlockCount limits the number of historical blocks a fee history request may cover FeeHistoryMaxBlockCount uint64 `koanf:"feehistory-max-block-count"` ArbDebug ArbDebugConfig `koanf:"arbdebug"` ClassicRedirect string `koanf:"classic-redirect"` ClassicRedirectTimeout time.Duration `koanf:"classic-redirect-timeout"` MaxRecreateStateDepth int64 `koanf:"max-recreate-state-depth"` AllowMethod []string `koanf:"allow-method"` }
type PublicNetAPI ¶
type PublicNetAPI struct {
// contains filtered or unexported fields
}
PublicNetAPI offers network related RPC methods
func NewPublicNetAPI ¶
func NewPublicNetAPI(networkVersion uint64) *PublicNetAPI
NewPublicNetAPI creates a new net API instance.
func (*PublicNetAPI) Version ¶
func (s *PublicNetAPI) Version() string
Version returns the current ethereum protocol version.
type PublicTxPoolAPI ¶
type PublicTxPoolAPI struct{}
PublicNetAPI offers network related RPC methods
func NewPublicTxPoolAPI ¶
func NewPublicTxPoolAPI() *PublicTxPoolAPI
NewPublicNetAPI creates a new net API instance.
type RecordingChainContext ¶
type RecordingChainContext struct {
// contains filtered or unexported fields
}
func (*RecordingChainContext) Engine ¶
func (r *RecordingChainContext) Engine() consensus.Engine
func (*RecordingChainContext) GetMinBlockNumberAccessed ¶
func (r *RecordingChainContext) GetMinBlockNumberAccessed() uint64
type RecordingDatabase ¶
type RecordingDatabase struct {
// contains filtered or unexported fields
}
func NewRecordingDatabase ¶
func NewRecordingDatabase(config *RecordingDatabaseConfig, ethdb ethdb.Database, blockchain *core.BlockChain) *RecordingDatabase
func (*RecordingDatabase) Dereference ¶
func (r *RecordingDatabase) Dereference(header *types.Header)
func (*RecordingDatabase) GetOrRecreateState ¶
func (r *RecordingDatabase) GetOrRecreateState(ctx context.Context, header *types.Header, logFunc StateBuildingLogFunction) (*state.StateDB, error)
func (*RecordingDatabase) PreimagesFromRecording ¶
func (r *RecordingDatabase) PreimagesFromRecording(chainContextIf core.ChainContext, recordingDb *RecordingKV) (map[common.Hash][]byte, error)
func (*RecordingDatabase) PrepareRecording ¶
func (r *RecordingDatabase) PrepareRecording(ctx context.Context, lastBlockHeader *types.Header, logFunc StateBuildingLogFunction) (*state.StateDB, core.ChainContext, *RecordingKV, error)
func (*RecordingDatabase) ReferenceCount ¶
func (r *RecordingDatabase) ReferenceCount() int64
func (*RecordingDatabase) StateFor ¶
Normal geth state.New + Reference is not atomic vs Dereference. This one is. This function does not recreate a state
func (*RecordingDatabase) WriteStateToDatabase ¶
func (r *RecordingDatabase) WriteStateToDatabase(header *types.Header) error
type RecordingDatabaseConfig ¶
type RecordingKV ¶
type RecordingKV struct {
// contains filtered or unexported fields
}
func (*RecordingKV) Close ¶
func (db *RecordingKV) Close() error
func (*RecordingKV) Delete ¶
func (db *RecordingKV) Delete(key []byte) error
func (*RecordingKV) EnableBypass ¶
func (db *RecordingKV) EnableBypass()
func (*RecordingKV) GetRecordedEntries ¶
func (db *RecordingKV) GetRecordedEntries() map[common.Hash][]byte
func (*RecordingKV) NewBatch ¶
func (db *RecordingKV) NewBatch() ethdb.Batch
func (*RecordingKV) NewBatchWithSize ¶
func (db *RecordingKV) NewBatchWithSize(size int) ethdb.Batch
func (*RecordingKV) NewIterator ¶
func (db *RecordingKV) NewIterator(prefix []byte, start []byte) ethdb.Iterator
func (*RecordingKV) NewSnapshot ¶
func (db *RecordingKV) NewSnapshot() (ethdb.Snapshot, error)
func (*RecordingKV) Release ¶
func (db *RecordingKV) Release()
type StateForHeaderFunction ¶
type StateReleaseFunc ¶
type StateReleaseFunc tracers.StateReleaseFunc
var NoopStateRelease StateReleaseFunc = func() {}
func FindLastAvailableState ¶
func FindLastAvailableState(ctx context.Context, bc *core.BlockChain, stateFor StateForHeaderFunction, targetHeader *types.Header, logFunc StateBuildingLogFunction, maxDepthInL2Gas int64) (*state.StateDB, *types.Header, StateReleaseFunc, error)
finds last available state and header checking it first for targetHeader then looking backwards if maxDepthInL2Gas is positive, it constitutes a limit for cumulative l2 gas used of the traversed blocks else if maxDepthInL2Gas is -1, the traversal depth is not limited otherwise only targetHeader state is checked and no search is performed
type SyncProgressBackend ¶
type TransactionArgs ¶
type TransactionArgs = ethapi.TransactionArgs