mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-20 09:21:11 +00:00
4f4b395aa4
* 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
64 lines
1.5 KiB
Go
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
|
|
}
|