erigon-pulse/trie/trie_transform.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

61 lines
1.6 KiB
Go

package trie
import (
"github.com/ledgerwatch/turbo-geth/core/types/accounts"
)
type keyTransformFunc func([]byte) []byte
func transformSubTrie(nd node, hex []byte, newTrie *Trie, transformFunc keyTransformFunc) {
switch n := nd.(type) {
case nil:
return
case valueNode:
nCopy := make(valueNode, len(n))
copy(nCopy, n)
_, newTrie.root = newTrie.insert(newTrie.root, transformFunc(hex), 0, nCopy)
return
case *accountNode:
accountCopy := accounts.NewAccount()
accountCopy.Copy(&n.Account)
var code []byte = nil
if n.code != nil {
code = make([]byte, len(n.code))
copy(code, n.code)
}
_, newTrie.root = newTrie.insert(newTrie.root, transformFunc(hex), 0, &accountNode{accountCopy, nil, true, codeNode(code)})
aHex := hex
if aHex[len(aHex)-1] == 16 {
aHex = aHex[:len(aHex)-1]
}
transformSubTrie(n.storage, aHex, newTrie, transformFunc)
case hashNode:
nCopy := make(hashNode, len(n))
copy(nCopy, n)
_, newTrie.root = newTrie.insert(newTrie.root, transformFunc(hex), 0, nCopy)
return
case *shortNode:
var hexVal []byte
hexVal = concat(hex, n.Key...)
transformSubTrie(n.Val, hexVal, newTrie, transformFunc)
case *duoNode:
i1, i2 := n.childrenIdx()
hex1 := make([]byte, len(hex)+1)
copy(hex1, hex)
hex1[len(hex)] = i1
hex2 := make([]byte, len(hex)+1)
copy(hex2, hex)
hex2[len(hex)] = i2
transformSubTrie(n.child1, hex1, newTrie, transformFunc)
transformSubTrie(n.child2, hex2, newTrie, transformFunc)
case *fullNode:
for i, child := range n.Children {
if child != nil {
transformSubTrie(child, concat(hex, byte(i)), newTrie, transformFunc)
}
}
default:
panic("")
}
}