sync.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // Copyright 2015 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package state
  17. import (
  18. "bytes"
  19. "github.com/ethereum/go-ethereum/common"
  20. "github.com/ethereum/go-ethereum/core/types"
  21. "github.com/ethereum/go-ethereum/ethdb"
  22. "github.com/ethereum/go-ethereum/rlp"
  23. "github.com/ethereum/go-ethereum/trie"
  24. )
  25. // NewStateSync create a new state trie download scheduler.
  26. func NewStateSync(root common.Hash, database ethdb.KeyValueReader, onLeaf func(keys [][]byte, leaf []byte) error) *trie.Sync {
  27. // Register the storage slot callback if the external callback is specified.
  28. var onSlot func(keys [][]byte, path []byte, leaf []byte, parent common.Hash, parentPath []byte) error
  29. if onLeaf != nil {
  30. onSlot = func(keys [][]byte, path []byte, leaf []byte, parent common.Hash, parentPath []byte) error {
  31. return onLeaf(keys, leaf)
  32. }
  33. }
  34. // Register the account callback to connect the state trie and the storage
  35. // trie belongs to the contract.
  36. var syncer *trie.Sync
  37. onAccount := func(keys [][]byte, path []byte, leaf []byte, parent common.Hash, parentPath []byte) error {
  38. if onLeaf != nil {
  39. if err := onLeaf(keys, leaf); err != nil {
  40. return err
  41. }
  42. }
  43. var obj types.StateAccount
  44. if err := rlp.Decode(bytes.NewReader(leaf), &obj); err != nil {
  45. return err
  46. }
  47. syncer.AddSubTrie(obj.Root, path, parent, parentPath, onSlot)
  48. syncer.AddCodeEntry(common.BytesToHash(obj.CodeHash), path, parent, parentPath)
  49. return nil
  50. }
  51. syncer = trie.NewSync(root, database, onAccount)
  52. return syncer
  53. }