Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
332d4aea
提交
332d4aea
authored
2月 25, 2019
作者:
Łukasz Magiera
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
coreapi unixfs: change Wrap logic to make more sense
License: MIT Signed-off-by:
Łukasz Magiera
<
magik6k@gmail.com
>
上级
a410f7e2
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
99 行增加
和
81 行删除
+99
-81
unixfs.go
core/coreapi/unixfs.go
+1
-0
add.go
core/coreunix/add.go
+98
-81
没有找到文件。
core/coreapi/unixfs.go
浏览文件 @
332d4aea
...
...
@@ -95,6 +95,7 @@ func (api *UnixfsAPI) Add(ctx context.Context, files files.Node, opts ...options
fileAdder
.
NoCopy
=
settings
.
NoCopy
fileAdder
.
Name
=
settings
.
StdinName
fileAdder
.
CidBuilder
=
prefix
fileAdder
.
TopHidden
=
settings
.
TopHidden
switch
settings
.
Layout
{
case
options
.
BalancedLayout
:
...
...
core/coreunix/add.go
浏览文件 @
332d4aea
...
...
@@ -68,6 +68,7 @@ type Adder struct {
Out
chan
<-
interface
{}
Progress
bool
Hidden
bool
TopHidden
bool
Pin
bool
Trickle
bool
RawLeaves
bool
...
...
@@ -192,53 +193,6 @@ func (adder *Adder) PinRoot() error {
return
adder
.
pinning
.
Flush
()
}
// Finalize flushes the mfs root directory and returns the mfs root node.
func
(
adder
*
Adder
)
Finalize
()
(
ipld
.
Node
,
error
)
{
mr
,
err
:=
adder
.
mfsRoot
()
if
err
!=
nil
{
return
nil
,
err
}
var
root
mfs
.
FSNode
rootdir
:=
mr
.
GetDirectory
()
root
=
rootdir
err
=
root
.
Flush
()
if
err
!=
nil
{
return
nil
,
err
}
var
name
string
if
!
adder
.
Wrap
{
children
,
err
:=
rootdir
.
ListNames
(
adder
.
ctx
)
if
err
!=
nil
{
return
nil
,
err
}
if
len
(
children
)
==
0
{
return
nil
,
fmt
.
Errorf
(
"expected at least one child dir, got none"
)
}
// Replace root with the first child
name
=
children
[
0
]
root
,
err
=
rootdir
.
Child
(
name
)
if
err
!=
nil
{
return
nil
,
err
}
}
err
=
adder
.
outputDirs
(
name
,
root
)
if
err
!=
nil
{
return
nil
,
err
}
err
=
mr
.
Close
()
if
err
!=
nil
{
return
nil
,
err
}
return
root
.
GetNode
()
}
func
(
adder
*
Adder
)
outputDirs
(
path
string
,
fsn
mfs
.
FSNode
)
error
{
switch
fsn
:=
fsn
.
(
type
)
{
case
*
mfs
.
File
:
...
...
@@ -321,30 +275,88 @@ func (adder *Adder) AddAllAndPin(file files.Node) (ipld.Node, error) {
}
}()
switch
tf
:=
file
.
(
type
)
{
case
files
.
Directory
:
// Iterate over each top-level file and add individually. Otherwise the
// single files.File f is treated as a directory, affecting hidden file
// semantics.
it
:=
tf
.
Entries
()
for
it
.
Next
()
{
if
err
:=
adder
.
addFileNode
(
it
.
Name
(),
it
.
Node
());
err
!=
nil
{
return
nil
,
err
}
d
,
dir
:=
file
.
(
files
.
Directory
)
if
!
dir
||
!
adder
.
TopHidden
{
d
=
files
.
NewSliceDirectory
([]
files
.
DirEntry
{
files
.
FileEntry
(
""
,
file
),
})
}
// Iterate over each top-level file and add individually. Otherwise the
// single files.File f is treated as a directory, affecting hidden file
// semantics.
it
:=
d
.
Entries
()
for
it
.
Next
()
{
if
err
:=
adder
.
addFileNode
(
it
.
Name
(),
it
.
Node
(),
true
);
err
!=
nil
{
return
nil
,
err
}
}
if
it
.
Err
()
!=
nil
{
return
nil
,
it
.
Err
()
}
mr
,
err
:=
adder
.
mfsRoot
()
if
err
!=
nil
{
return
nil
,
err
}
var
root
mfs
.
FSNode
rootdir
:=
mr
.
GetDirectory
()
root
=
rootdir
err
=
root
.
Flush
()
if
err
!=
nil
{
return
nil
,
err
}
var
name
string
if
!
adder
.
Wrap
&&
!
dir
{
children
,
err
:=
rootdir
.
ListNames
(
adder
.
ctx
)
if
err
!=
nil
{
return
nil
,
err
}
if
it
.
Err
()
!=
nil
{
return
nil
,
it
.
Err
()
if
len
(
children
)
==
0
{
return
nil
,
fmt
.
Errorf
(
"expected at least one child dir, got none"
)
}
break
default
:
if
err
:=
adder
.
addFileNode
(
""
,
file
);
err
!=
nil
{
// Replace root with the first child
name
=
children
[
0
]
root
,
err
=
rootdir
.
Child
(
name
)
if
err
!=
nil
{
return
nil
,
err
}
}
err
=
mr
.
Close
()
if
err
!=
nil
{
return
nil
,
err
}
nd
,
err
:=
root
.
GetNode
()
if
err
!=
nil
{
return
nil
,
err
}
if
adder
.
Wrap
&&
dir
{
name
=
nd
.
Cid
()
.
String
()
end
:=
unixfs
.
EmptyDirNode
()
if
err
:=
end
.
AddNodeLink
(
nd
.
Cid
()
.
String
(),
nd
);
err
!=
nil
{
return
nil
,
err
}
nd
=
end
if
err
:=
adder
.
dagService
.
Add
(
adder
.
ctx
,
end
);
err
!=
nil
{
return
nil
,
err
}
if
err
:=
outputDagnode
(
adder
.
Out
,
""
,
nd
);
err
!=
nil
{
return
nil
,
err
}
break
}
// copy intermediary nodes from editor to our actual dagservice
nd
,
err
:=
adder
.
Finalize
()
err
=
adder
.
outputDirs
(
name
,
root
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -355,8 +367,11 @@ func (adder *Adder) AddAllAndPin(file files.Node) (ipld.Node, error) {
return
nd
,
adder
.
PinRoot
()
}
func
(
adder
*
Adder
)
addFileNode
(
path
string
,
file
files
.
Node
)
error
{
defer
file
.
Close
()
func
(
adder
*
Adder
)
addFileNode
(
path
string
,
file
files
.
Node
,
toplevel
bool
)
error
{
if
!
toplevel
{
defer
file
.
Close
()
}
err
:=
adder
.
maybePauseForGC
()
if
err
!=
nil
{
return
err
...
...
@@ -378,7 +393,7 @@ func (adder *Adder) addFileNode(path string, file files.Node) error {
switch
f
:=
file
.
(
type
)
{
case
files
.
Directory
:
return
adder
.
addDir
(
path
,
f
)
return
adder
.
addDir
(
path
,
f
,
toplevel
)
case
*
files
.
Symlink
:
return
adder
.
addSymlink
(
path
,
f
)
case
files
.
File
:
...
...
@@ -433,20 +448,22 @@ func (adder *Adder) addFile(path string, file files.File) error {
return
adder
.
addNode
(
dagnode
,
path
)
}
func
(
adder
*
Adder
)
addDir
(
path
string
,
dir
files
.
Directory
)
error
{
func
(
adder
*
Adder
)
addDir
(
path
string
,
dir
files
.
Directory
,
toplevel
bool
)
error
{
log
.
Infof
(
"adding directory: %s"
,
path
)
mr
,
err
:=
adder
.
mfsRoot
()
if
err
!=
nil
{
return
err
}
err
=
mfs
.
Mkdir
(
mr
,
path
,
mfs
.
MkdirOpts
{
Mkparents
:
true
,
Flush
:
false
,
CidBuilder
:
adder
.
CidBuilder
,
})
if
err
!=
nil
{
return
err
if
!
(
toplevel
&&
path
==
""
)
{
mr
,
err
:=
adder
.
mfsRoot
()
if
err
!=
nil
{
return
err
}
err
=
mfs
.
Mkdir
(
mr
,
path
,
mfs
.
MkdirOpts
{
Mkparents
:
true
,
Flush
:
false
,
CidBuilder
:
adder
.
CidBuilder
,
})
if
err
!=
nil
{
return
err
}
}
it
:=
dir
.
Entries
()
...
...
@@ -458,7 +475,7 @@ func (adder *Adder) addDir(path string, dir files.Directory) error {
log
.
Infof
(
"%s is hidden, skipping"
,
fpath
)
continue
}
err
=
adder
.
addFileNode
(
fpath
,
it
.
Node
()
)
err
:=
adder
.
addFileNode
(
fpath
,
it
.
Node
(),
false
)
if
err
!=
nil
{
return
err
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论