diff options
author | Jeffrey Wilcke <geffobscura@gmail.com> | 2015-07-01 21:38:32 +0800 |
---|---|---|
committer | Jeffrey Wilcke <geffobscura@gmail.com> | 2015-07-04 08:51:36 +0800 |
commit | 0a1ff68c11706f60355b392cb16a681630260ac3 (patch) | |
tree | fa7e46110a346cc1a10e3a3135815942c4560859 /trie/valuenode.go | |
parent | ab16ce70fc68d9ab1b7d8cda57c180b4785cab6a (diff) | |
download | go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar.gz go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar.bz2 go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar.lz go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar.xz go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.tar.zst go-tangerine-0a1ff68c11706f60355b392cb16a681630260ac3.zip |
trie: dirty tracking
Diffstat (limited to 'trie/valuenode.go')
-rw-r--r-- | trie/valuenode.go | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/trie/valuenode.go b/trie/valuenode.go index 7bf8ff06e..6adb59652 100644 --- a/trie/valuenode.go +++ b/trie/valuenode.go @@ -3,13 +3,24 @@ package trie import "github.com/ethereum/go-ethereum/common" type ValueNode struct { - trie *Trie - data []byte + trie *Trie + data []byte + dirty bool } -func (self *ValueNode) Value() Node { return self } // Best not to call :-) -func (self *ValueNode) Val() []byte { return self.data } -func (self *ValueNode) Dirty() bool { return true } -func (self *ValueNode) Copy(t *Trie) Node { return &ValueNode{t, common.CopyBytes(self.data)} } +func NewValueNode(trie *Trie, data []byte) *ValueNode { + return &ValueNode{trie, data, false} +} + +func (self *ValueNode) Value() Node { return self } // Best not to call :-) +func (self *ValueNode) Val() []byte { return self.data } +func (self *ValueNode) Dirty() bool { return self.dirty } +func (self *ValueNode) Copy(t *Trie) Node { + return &ValueNode{t, common.CopyBytes(self.data), self.dirty} +} func (self *ValueNode) RlpData() interface{} { return self.data } func (self *ValueNode) Hash() interface{} { return self.data } + +func (self *ValueNode) setDirty(dirty bool) { + self.dirty = dirty +} |