mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-18 16:44:12 +00:00
5ea590c18e
* State cache init * More code * Fix lint * More tests * More tests * More tests * Fix test * Transformations * remove writeQueue, before fixing the tests * Fix tests * Add more tests, incarnation to the code items * Fix lint * Fix lint * Remove shards prototype, add incarnation to the state reader code * Clean up and replace cache in call_traces stage * fix flaky test * Save changes * Readers to use addrHash, writes - addresses * Fix lint * Fix lint * More accurate tracking of size * Optimise for smaller write batches * Attempt to integrate state cache into Execution stage * cacheSize to default flags * Print correct cache sizes and batch sizes * cacheSize in the integration * Fix tests * Fix lint * Remove print * Fix exec stage * Fix test * Refresh sequence on write * No double increment * heap.Remove * Try to fix alignment * Refactoring, adding hashItems * More changes * Fix compile errors * Fix lint * Wrapping cached reader * Wrap writer into cached writer * Turn state cache off by default * Fix plain state writer * Fix for code/storage mixup * Fix tests * Fix clique test * Better fix for the tests * Add test and fix some more * Fix compile error| * More functions * Fixes * Fix for the tests * sepatate DeletedFlag and AbsentFlag * Minor fixes * Test refactoring * More changes * Fix some tests * More test fixes * More test fixes * Fix lint * Move blockchain_test to be able to use stagedsync * More fixes * Fixes and cleanup * Fix tests in turbo/stages * Fix lint * Fix lint * Intemediate * Fix tests * Intemediate * More fixes * Compilation fixes * More fixes * Fix compile errors * More test fixes * More fixes * More test fixes * Fix compile error * Fixes * Fix * Fix * More fixes * Fixes * More fixes and cleanup * Further fix * Check gas used and bloom with header Co-authored-by: Alexey Sharp <alexeysharp@Alexeys-iMac.local>
73 lines
2.2 KiB
Go
73 lines
2.2 KiB
Go
package state
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/holiman/uint256"
|
|
"github.com/ledgerwatch/turbo-geth/common"
|
|
"github.com/ledgerwatch/turbo-geth/core/types/accounts"
|
|
"github.com/ledgerwatch/turbo-geth/turbo/shards"
|
|
)
|
|
|
|
// CachedWriter is a wrapper for an instance of type StateWriter
|
|
type CachedWriter struct {
|
|
w WriterWithChangeSets
|
|
cache *shards.StateCache
|
|
}
|
|
|
|
// NewCachedWriter wraps a given state writer into a cached writer
|
|
func NewCachedWriter(w WriterWithChangeSets, cache *shards.StateCache) *CachedWriter {
|
|
return &CachedWriter{w: w, cache: cache}
|
|
}
|
|
|
|
func (cw *CachedWriter) UpdateAccountData(ctx context.Context, address common.Address, original, account *accounts.Account) error {
|
|
if err := cw.w.UpdateAccountData(ctx, address, original, account); err != nil {
|
|
return err
|
|
}
|
|
cw.cache.SetAccountWrite(address.Bytes(), account)
|
|
return nil
|
|
}
|
|
|
|
func (cw *CachedWriter) UpdateAccountCode(address common.Address, incarnation uint64, codeHash common.Hash, code []byte) error {
|
|
if err := cw.w.UpdateAccountCode(address, incarnation, codeHash, code); err != nil {
|
|
return err
|
|
}
|
|
cw.cache.SetCodeWrite(address.Bytes(), incarnation, code)
|
|
return nil
|
|
}
|
|
|
|
func (cw *CachedWriter) DeleteAccount(ctx context.Context, address common.Address, original *accounts.Account) error {
|
|
if err := cw.w.DeleteAccount(ctx, address, original); err != nil {
|
|
return err
|
|
}
|
|
cw.cache.SetAccountDelete(address.Bytes())
|
|
return nil
|
|
}
|
|
|
|
func (cw *CachedWriter) WriteAccountStorage(ctx context.Context, address common.Address, incarnation uint64, key *common.Hash, original, value *uint256.Int) error {
|
|
if err := cw.w.WriteAccountStorage(ctx, address, incarnation, key, original, value); err != nil {
|
|
return err
|
|
}
|
|
if *original == *value {
|
|
return nil
|
|
}
|
|
if value.IsZero() {
|
|
cw.cache.SetStorageDelete(address.Bytes(), incarnation, key.Bytes())
|
|
} else {
|
|
cw.cache.SetStorageWrite(address.Bytes(), incarnation, key.Bytes(), value.Bytes())
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (cw *CachedWriter) CreateContract(address common.Address) error {
|
|
return cw.w.CreateContract(address)
|
|
}
|
|
|
|
func (cw *CachedWriter) WriteChangeSets() error {
|
|
return cw.w.WriteChangeSets()
|
|
}
|
|
|
|
func (cw *CachedWriter) WriteHistory() error {
|
|
return cw.w.WriteHistory()
|
|
}
|