Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
82272ee0
Commit
82272ee0
authored
Jun 30, 2014
by
obscuren
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Iterator fix
parent
9ed0d389
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
6 additions
and
8 deletions
+6
-8
trie.go
ethutil/trie.go
+4
-6
trie_test.go
ethutil/trie_test.go
+2
-2
No files found.
ethutil/trie.go
View file @
82272ee0
...
@@ -538,15 +538,13 @@ func (it *TrieIterator) fetchNode(key []int, node []byte, cb EachCallback) {
...
@@ -538,15 +538,13 @@ func (it *TrieIterator) fetchNode(key []int, node []byte, cb EachCallback) {
}
}
func
(
it
*
TrieIterator
)
iterateNode
(
key
[]
int
,
currentNode
*
Value
,
cb
EachCallback
)
{
func
(
it
*
TrieIterator
)
iterateNode
(
key
[]
int
,
currentNode
*
Value
,
cb
EachCallback
)
{
//fmt.Println("node", currentNode)
if
currentNode
.
Len
()
==
2
{
if
currentNode
.
Len
()
==
2
{
k
:=
CompactDecode
(
currentNode
.
Get
(
0
)
.
Str
())
k
:=
CompactDecode
(
currentNode
.
Get
(
0
)
.
Str
())
if
currentNode
.
Get
(
1
)
.
Str
()
==
""
{
pk
:=
append
(
key
,
k
...
)
it
.
iterateNode
(
key
,
currentNode
.
Get
(
1
),
cb
)
if
currentNode
.
Get
(
1
)
.
Len
()
!=
0
&&
currentNode
.
Get
(
1
)
.
Str
()
==
""
{
it
.
iterateNode
(
pk
,
currentNode
.
Get
(
1
),
cb
)
}
else
{
}
else
{
pk
:=
append
(
key
,
k
...
)
if
k
[
len
(
k
)
-
1
]
==
16
{
if
k
[
len
(
k
)
-
1
]
==
16
{
cb
(
DecodeCompact
(
pk
),
currentNode
.
Get
(
1
))
cb
(
DecodeCompact
(
pk
),
currentNode
.
Get
(
1
))
...
@@ -560,7 +558,7 @@ func (it *TrieIterator) iterateNode(key []int, currentNode *Value, cb EachCallba
...
@@ -560,7 +558,7 @@ func (it *TrieIterator) iterateNode(key []int, currentNode *Value, cb EachCallba
if
i
==
16
&&
currentNode
.
Get
(
i
)
.
Len
()
!=
0
{
if
i
==
16
&&
currentNode
.
Get
(
i
)
.
Len
()
!=
0
{
cb
(
DecodeCompact
(
pk
),
currentNode
.
Get
(
i
))
cb
(
DecodeCompact
(
pk
),
currentNode
.
Get
(
i
))
}
else
{
}
else
{
if
currentNode
.
Get
(
i
)
.
Str
()
==
""
{
if
currentNode
.
Get
(
i
)
.
Len
()
!=
0
&&
currentNode
.
Get
(
i
)
.
Str
()
==
""
{
it
.
iterateNode
(
pk
,
currentNode
.
Get
(
i
),
cb
)
it
.
iterateNode
(
pk
,
currentNode
.
Get
(
i
),
cb
)
}
else
{
}
else
{
val
:=
currentNode
.
Get
(
i
)
.
Str
()
val
:=
currentNode
.
Get
(
i
)
.
Str
()
...
...
ethutil/trie_test.go
View file @
82272ee0
...
@@ -261,13 +261,13 @@ func TestTrieReplay(t *testing.T) {
...
@@ -261,13 +261,13 @@ func TestTrieReplay(t *testing.T) {
_
,
trie2
:=
New
()
_
,
trie2
:=
New
()
trie
.
NewIterator
()
.
Each
(
func
(
key
string
,
v
*
Value
)
{
trie
.
NewIterator
()
.
Each
(
func
(
key
string
,
v
*
Value
)
{
trie2
.
Update
(
key
,
string
(
v
.
Str
()
))
trie2
.
Update
(
key
,
v
.
Str
(
))
})
})
a
:=
NewValue
(
trie
.
Root
)
.
Bytes
()
a
:=
NewValue
(
trie
.
Root
)
.
Bytes
()
b
:=
NewValue
(
trie2
.
Root
)
.
Bytes
()
b
:=
NewValue
(
trie2
.
Root
)
.
Bytes
()
if
bytes
.
Compare
(
a
,
b
)
!=
0
{
if
bytes
.
Compare
(
a
,
b
)
!=
0
{
t
.
Errorf
(
"
root %x %x
\n
"
,
trie
.
Root
,
trie2
.
Root
)
t
.
Errorf
(
"
%s %x %x
\n
"
,
test
.
Name
,
trie
.
Root
,
trie2
.
Root
)
}
}
})
})
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment