Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-dms3
Commits
a2f27e1a
Commit
a2f27e1a
authored
Feb 14, 2017
by
Jeromy Johnson
Committed by
GitHub
Feb 14, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3598 from Voker57/feat/frugal-enumerate
Pass cids instead of nodes around in EnumerateChildrenAsync
parents
2e116b40
66189325
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
41 deletions
+36
-41
merkledag/merkledag.go
merkledag/merkledag.go
+36
-41
No files found.
merkledag/merkledag.go
View file @
a2f27e1a
...
...
@@ -140,7 +140,7 @@ func (n *dagService) Remove(nd node.Node) error {
// FetchGraph fetches all nodes that are children of the given node
func
FetchGraph
(
ctx
context
.
Context
,
c
*
cid
.
Cid
,
serv
DAGService
)
error
{
return
EnumerateChildren
(
ctx
,
serv
,
c
,
cid
.
NewSet
()
.
Visit
,
false
)
return
EnumerateChildren
Async
(
ctx
,
serv
,
c
,
cid
.
NewSet
()
.
Visit
)
}
// FindLinks searches this nodes links for the given key,
...
...
@@ -394,45 +394,40 @@ func EnumerateChildren(ctx context.Context, ds LinkService, root *cid.Cid, visit
var
FetchGraphConcurrency
=
8
func
EnumerateChildrenAsync
(
ctx
context
.
Context
,
ds
DAGService
,
c
*
cid
.
Cid
,
visit
func
(
*
cid
.
Cid
)
bool
)
error
{
if
!
visit
(
c
)
{
return
nil
}
root
,
err
:=
ds
.
Get
(
ctx
,
c
)
if
err
!=
nil
{
return
err
}
feed
:=
make
(
chan
node
.
Node
)
out
:=
make
(
chan
*
NodeOption
)
feed
:=
make
(
chan
*
cid
.
Cid
)
out
:=
make
(
chan
node
.
Node
)
done
:=
make
(
chan
struct
{})
var
setlk
sync
.
Mutex
errChan
:=
make
(
chan
error
)
fetchersCtx
,
cancel
:=
context
.
WithCancel
(
ctx
)
defer
cancel
()
for
i
:=
0
;
i
<
FetchGraphConcurrency
;
i
++
{
go
func
()
{
for
n
:=
range
feed
{
links
:=
n
.
Links
()
cids
:=
make
([]
*
cid
.
Cid
,
0
,
len
(
links
))
for
_
,
l
:=
range
links
{
setlk
.
Lock
()
unseen
:=
visit
(
l
.
Cid
)
setlk
.
Unlock
()
if
unseen
{
cids
=
append
(
cids
,
l
.
Cid
)
}
for
ic
:=
range
feed
{
n
,
err
:=
ds
.
Get
(
ctx
,
ic
)
if
err
!=
nil
{
errChan
<-
err
return
}
for
nopt
:=
range
ds
.
GetMany
(
ctx
,
cids
)
{
setlk
.
Lock
()
unseen
:=
visit
(
ic
)
setlk
.
Unlock
()
if
unseen
{
select
{
case
out
<-
n
opt
:
case
<-
c
tx
.
Done
()
:
case
out
<-
n
:
case
<-
fetchersC
tx
.
Done
()
:
return
}
}
select
{
case
done
<-
struct
{}{}
:
case
<-
c
tx
.
Done
()
:
case
<-
fetchersC
tx
.
Done
()
:
}
}
}()
...
...
@@ -440,10 +435,10 @@ func EnumerateChildrenAsync(ctx context.Context, ds DAGService, c *cid.Cid, visi
defer
close
(
feed
)
send
:=
feed
var
todobuffer
[]
node
.
Node
var
todobuffer
[]
*
cid
.
Cid
var
inProgress
int
next
:=
root
next
:=
c
for
{
select
{
case
send
<-
next
:
...
...
@@ -460,18 +455,18 @@ func EnumerateChildrenAsync(ctx context.Context, ds DAGService, c *cid.Cid, visi
if
inProgress
==
0
&&
next
==
nil
{
return
nil
}
case
nc
:=
<-
out
:
if
nc
.
Err
!=
nil
{
return
nc
.
Err
}
if
next
==
nil
{
next
=
nc
.
Node
send
=
feed
}
else
{
todobuffer
=
append
(
todobuffer
,
nc
.
Node
)
case
nd
:=
<-
out
:
for
_
,
lnk
:=
range
nd
.
Links
()
{
if
next
==
nil
{
next
=
lnk
.
Cid
send
=
feed
}
else
{
todobuffer
=
append
(
todobuffer
,
lnk
.
Cid
)
}
}
case
err
:=
<-
errChan
:
return
err
case
<-
ctx
.
Done
()
:
return
ctx
.
Err
()
}
...
...
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