erigon-pulse/trie/resolver_stateless.go
Igor Mandrigin 4f4b395aa4
Introduce code node & get rid of code map (#398)
* introduce code node

* replace codeMap with code touches

* fix a comment

* fixups to tests

* fix compile error

* fix getnodedata tests

* add tests and test stubs

* add more test stubs

* add test method bodies

* add and fix more tests on trie for new codenode

* add test change code between blocks

* fix crash in stateless

* remove unneded files

* remove comment

* fix deleted account code

* fix resolve set builder for code nodes
2020-03-23 22:10:36 +00:00

64 lines
1.5 KiB
Go

package trie
import (
"bytes"
"io"
)
type ResolverStateless struct {
requests []*ResolveRequest
hookFunction hookFunction
}
func NewResolverStateless(requests []*ResolveRequest, hookFunction hookFunction) *ResolverStateless {
return &ResolverStateless{
requests: requests,
hookFunction: hookFunction,
}
}
func (r *ResolverStateless) RebuildTrie(db WitnessStorage, blockNr uint64, trieLimit uint32, startPos int64) (int64, error) {
serializedWitness, err := db.GetWitnessesForBlock(blockNr, trieLimit)
if err != nil {
return 0, err
}
witnessReader := bytes.NewReader(serializedWitness)
if _, err := witnessReader.Seek(startPos, io.SeekStart); err != nil {
return 0, err
}
var prevReq *ResolveRequest
requestIndex := 0
for witnessReader.Len() > 0 && requestIndex < len(r.requests) {
req := r.requests[requestIndex]
if prevReq == nil ||
!bytes.Equal(req.contract, prevReq.contract) ||
!bytes.Equal(req.resolveHex[:req.resolvePos], prevReq.resolveHex[:prevReq.resolvePos]) {
witness, err := NewWitnessFromReader(witnessReader, false /*trace*/)
if err != nil {
return 0, err
}
trie, err := BuildTrieFromWitness(witness, false /*is-binary*/, false /*trace*/)
if err != nil {
return 0, err
}
rootNode := trie.root
rootHash := trie.Hash()
err = r.hookFunction(req, rootNode, rootHash)
if err != nil {
return 0, err
}
prevReq = req
}
requestIndex++
}
bytesRead := int64(len(serializedWitness) - witnessReader.Len())
return bytesRead, nil
}