Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
c8af993a
提交
c8af993a
authored
11月 15, 2016
作者:
Jeromy
提交者:
Jeromy
3月 21, 2017
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
iterator technique for unixfs dir listing
License: MIT Signed-off-by:
Jeromy
<
why@ipfs.io
>
上级
06fb495d
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
54 行增加
和
51 行删除
+54
-51
dir.go
mfs/dir.go
+31
-43
hamt.go
unixfs/hamt/hamt.go
+10
-8
dirbuilder.go
unixfs/io/dirbuilder.go
+13
-0
没有找到文件。
mfs/dir.go
浏览文件 @
c8af993a
...
@@ -221,71 +221,59 @@ func (d *Directory) ListNames() ([]string, error) {
...
@@ -221,71 +221,59 @@ func (d *Directory) ListNames() ([]string, error) {
d
.
lock
.
Lock
()
d
.
lock
.
Lock
()
defer
d
.
lock
.
Unlock
()
defer
d
.
lock
.
Unlock
()
names
:=
make
(
map
[
string
]
struct
{})
var
out
[]
string
for
n
,
_
:=
range
d
.
childDirs
{
err
:=
d
.
dirbuilder
.
ForEachLink
(
func
(
l
*
node
.
Link
)
error
{
names
[
n
]
=
struct
{}{}
out
=
append
(
out
,
l
.
Name
)
}
return
nil
for
n
,
_
:=
range
d
.
files
{
})
names
[
n
]
=
struct
{}{}
}
links
,
err
:=
d
.
dirbuilder
.
Links
()
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
for
_
,
l
:=
range
links
{
names
[
l
.
Name
]
=
struct
{}{}
}
var
out
[]
string
for
n
,
_
:=
range
names
{
out
=
append
(
out
,
n
)
}
sort
.
Strings
(
out
)
sort
.
Strings
(
out
)
return
out
,
nil
return
out
,
nil
}
}
func
(
d
*
Directory
)
List
()
([]
NodeListing
,
error
)
{
func
(
d
*
Directory
)
List
()
([]
NodeListing
,
error
)
{
d
.
lock
.
Lock
()
defer
d
.
lock
.
Unlock
()
var
out
[]
NodeListing
var
out
[]
NodeListing
err
:=
d
.
ForEachEntry
(
context
.
TODO
(),
func
(
nl
NodeListing
)
error
{
out
=
append
(
out
,
nl
)
return
nil
})
return
out
,
err
}
links
,
err
:=
d
.
dirbuilder
.
Links
()
func
(
d
*
Directory
)
ForEachEntry
(
ctx
context
.
Context
,
f
func
(
NodeListing
)
error
)
error
{
if
err
!=
nil
{
d
.
lock
.
Lock
()
return
nil
,
err
defer
d
.
lock
.
Unlock
()
}
return
d
.
dirbuilder
.
ForEachLink
(
func
(
l
*
node
.
Link
)
error
{
for
_
,
l
:=
range
links
{
child
:=
NodeListing
{}
child
.
Name
=
l
.
Name
c
,
err
:=
d
.
childUnsync
(
l
.
Name
)
c
,
err
:=
d
.
childUnsync
(
l
.
Name
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
err
}
nd
,
err
:=
c
.
GetNode
()
if
err
!=
nil
{
return
err
}
child
:=
NodeListing
{
Name
:
l
.
Name
,
Type
:
int
(
c
.
Type
()),
Hash
:
nd
.
Cid
()
.
String
(),
}
}
child
.
Type
=
int
(
c
.
Type
())
if
c
,
ok
:=
c
.
(
*
File
);
ok
{
if
c
,
ok
:=
c
.
(
*
File
);
ok
{
size
,
err
:=
c
.
Size
()
size
,
err
:=
c
.
Size
()
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
err
}
}
child
.
Size
=
size
child
.
Size
=
size
}
}
nd
,
err
:=
c
.
GetNode
()
if
err
!=
nil
{
return
nil
,
err
}
child
.
Hash
=
nd
.
Cid
()
.
String
()
return
f
(
child
)
})
out
=
append
(
out
,
child
)
}
return
out
,
nil
}
}
func
(
d
*
Directory
)
Mkdir
(
name
string
)
(
*
Directory
,
error
)
{
func
(
d
*
Directory
)
Mkdir
(
name
string
)
(
*
Directory
,
error
)
{
...
@@ -433,5 +421,5 @@ func (d *Directory) GetNode() (node.Node, error) {
...
@@ -433,5 +421,5 @@ func (d *Directory) GetNode() (node.Node, error) {
return
nil
,
err
return
nil
,
err
}
}
return
nd
,
err
return
nd
.
Copy
()
,
err
}
}
unixfs/hamt/hamt.go
浏览文件 @
c8af993a
...
@@ -321,7 +321,15 @@ func (ds *HamtShard) getValue(ctx context.Context, hv *hashBits, key string, cb
...
@@ -321,7 +321,15 @@ func (ds *HamtShard) getValue(ctx context.Context, hv *hashBits, key string, cb
func
(
ds
*
HamtShard
)
EnumLinks
()
([]
*
node
.
Link
,
error
)
{
func
(
ds
*
HamtShard
)
EnumLinks
()
([]
*
node
.
Link
,
error
)
{
var
links
[]
*
node
.
Link
var
links
[]
*
node
.
Link
err
:=
ds
.
walkTrie
(
func
(
sv
*
shardValue
)
error
{
err
:=
ds
.
ForEachLink
(
func
(
l
*
node
.
Link
)
error
{
links
=
append
(
links
,
l
)
return
nil
})
return
links
,
err
}
func
(
ds
*
HamtShard
)
ForEachLink
(
f
func
(
*
node
.
Link
)
error
)
error
{
return
ds
.
walkTrie
(
func
(
sv
*
shardValue
)
error
{
lnk
,
err
:=
node
.
MakeLink
(
sv
.
val
)
lnk
,
err
:=
node
.
MakeLink
(
sv
.
val
)
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
...
@@ -329,14 +337,8 @@ func (ds *HamtShard) EnumLinks() ([]*node.Link, error) {
...
@@ -329,14 +337,8 @@ func (ds *HamtShard) EnumLinks() ([]*node.Link, error) {
lnk
.
Name
=
sv
.
key
lnk
.
Name
=
sv
.
key
links
=
append
(
links
,
lnk
)
return
f
(
lnk
)
return
nil
})
})
if
err
!=
nil
{
return
nil
,
err
}
return
links
,
nil
}
}
func
(
ds
*
HamtShard
)
walkTrie
(
cb
func
(
*
shardValue
)
error
)
error
{
func
(
ds
*
HamtShard
)
walkTrie
(
cb
func
(
*
shardValue
)
error
)
error
{
...
...
unixfs/io/dirbuilder.go
浏览文件 @
c8af993a
...
@@ -102,6 +102,19 @@ func (d *Directory) switchToSharding(ctx context.Context) error {
...
@@ -102,6 +102,19 @@ func (d *Directory) switchToSharding(ctx context.Context) error {
return
nil
return
nil
}
}
func
(
d
*
Directory
)
ForEachLink
(
f
func
(
*
node
.
Link
)
error
)
error
{
if
d
.
shard
==
nil
{
for
_
,
l
:=
range
d
.
dirnode
.
Links
()
{
if
err
:=
f
(
l
);
err
!=
nil
{
return
err
}
}
return
nil
}
return
d
.
shard
.
ForEachLink
(
f
)
}
func
(
d
*
Directory
)
Links
()
([]
*
node
.
Link
,
error
)
{
func
(
d
*
Directory
)
Links
()
([]
*
node
.
Link
,
error
)
{
if
d
.
shard
==
nil
{
if
d
.
shard
==
nil
{
return
d
.
dirnode
.
Links
(),
nil
return
d
.
dirnode
.
Links
(),
nil
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论