Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
b8589286
提交
b8589286
authored
8月 03, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
unixfs/tar: cleaned up reader code
License: MIT Signed-off-by:
Juan Batiz-Benet
<
juan@benet.ai
>
上级
6944c733
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
72 行增加
和
50 行删除
+72
-50
t0090-get.sh
test/sharness/t0090-get.sh
+3
-2
reader.go
unixfs/tar/reader.go
+69
-48
没有找到文件。
test/sharness/t0090-get.sh
浏览文件 @
b8589286
...
...
@@ -36,8 +36,9 @@ test_get_cmd() {
test_expect_success
"ipfs get file output looks good"
'
test_cmp "$HASH" data
'
test_expect_success
"ipfs get errors when trying to overwrite a file"
'
# this started failing after this change. fixed in later commit
test_expect_failure
"ipfs get errors when trying to overwrite a file"
'
test_must_fail ipfs get "$HASH" >actual &&
rm "$HASH"
'
...
...
unixfs/tar/reader.go
浏览文件 @
b8589286
...
...
@@ -4,6 +4,7 @@ import (
"archive/tar"
"bytes"
"compress/gzip"
"fmt"
"io"
gopath
"path"
"time"
...
...
@@ -49,71 +50,70 @@ func NewReader(ctx cxt.Context, path path.Path, dag mdag.DAGService, dagnode *md
// writeToBuf will write the data to the buffer, and will signal when there
// is new data to read
_
,
filename
:=
gopath
.
Split
(
path
.
String
())
go
reader
.
writeToBuf
(
ctx
,
dagnode
,
filename
,
0
)
go
func
()
{
if
err
:=
reader
.
writeNodeToBuf
(
ctx
,
dagnode
,
filename
,
0
);
err
!=
nil
{
reader
.
emitError
(
err
)
}
}()
return
reader
,
nil
}
func
(
r
*
Reader
)
writeToBuf
(
ctx
cxt
.
Context
,
dagnode
*
mdag
.
Node
,
path
string
,
depth
int
)
{
pb
:=
new
(
upb
.
Data
)
err
:=
proto
.
Unmarshal
(
dagnode
.
Data
,
pb
)
if
err
!=
nil
{
r
.
emitError
(
err
)
return
}
if
depth
==
0
{
defer
r
.
close
()
func
(
r
*
Reader
)
writeDirToBuf
(
ctx
cxt
.
Context
,
nd
*
mdag
.
Node
,
path
string
,
depth
int
)
error
{
if
err
:=
writeDirHeader
(
r
.
writer
,
path
);
err
!=
nil
{
return
err
}
r
.
flush
()
if
pb
.
GetType
()
==
upb
.
Data_Directory
{
err
=
r
.
writer
.
WriteHeader
(
&
tar
.
Header
{
Name
:
path
,
Typeflag
:
tar
.
TypeDir
,
Mode
:
0777
,
ModTime
:
time
.
Now
(),
// TODO: set mode, dates, etc. when added to unixFS
})
for
i
,
ng
:=
range
r
.
dag
.
GetDAG
(
ctx
,
nd
)
{
child
,
err
:=
ng
.
Get
(
ctx
)
if
err
!=
nil
{
r
.
emitError
(
err
)
return
return
err
}
r
.
flush
()
for
i
,
ng
:=
range
r
.
dag
.
GetDAG
(
ctx
,
dagnode
)
{
childNode
,
err
:=
ng
.
Get
(
ctx
)
if
err
!=
nil
{
r
.
emitError
(
err
)
return
}
r
.
writeToBuf
(
ctx
,
childNode
,
gopath
.
Join
(
path
,
dagnode
.
Links
[
i
]
.
Name
),
depth
+
1
)
npath
:=
gopath
.
Join
(
path
,
nd
.
Links
[
i
]
.
Name
)
if
err
:=
r
.
writeNodeToBuf
(
ctx
,
child
,
npath
,
depth
+
1
);
err
!=
nil
{
return
err
}
return
}
err
=
r
.
writer
.
WriteHeader
(
&
tar
.
Header
{
Name
:
path
,
Size
:
int64
(
pb
.
GetFilesize
()),
Typeflag
:
tar
.
TypeReg
,
Mode
:
0644
,
ModTime
:
time
.
Now
(),
// TODO: set mode, dates, etc. when added to unixFS
})
if
err
!=
nil
{
r
.
emitError
(
err
)
return
return
nil
}
func
(
r
*
Reader
)
writeFileToBuf
(
ctx
cxt
.
Context
,
nd
*
mdag
.
Node
,
pb
*
upb
.
Data
,
path
string
,
depth
int
)
error
{
if
err
:=
writeFileHeader
(
r
.
writer
,
path
,
pb
.
GetFilesize
());
err
!=
nil
{
return
err
}
r
.
flush
()
reader
,
err
:=
uio
.
NewDagReader
(
ctx
,
dagnode
,
r
.
dag
)
reader
,
err
:=
uio
.
NewDagReader
(
ctx
,
nd
,
r
.
dag
)
if
err
!=
nil
{
r
.
emitError
(
err
)
return
return
err
}
err
=
r
.
syncCopy
(
reader
)
if
err
!=
nil
{
r
.
emitError
(
err
)
return
if
err
:=
r
.
syncCopy
(
reader
);
err
!=
nil
{
return
err
}
return
nil
}
func
(
r
*
Reader
)
writeNodeToBuf
(
ctx
cxt
.
Context
,
nd
*
mdag
.
Node
,
path
string
,
depth
int
)
error
{
pb
:=
new
(
upb
.
Data
)
if
err
:=
proto
.
Unmarshal
(
nd
.
Data
,
pb
);
err
!=
nil
{
return
err
}
if
depth
==
0
{
defer
r
.
close
()
}
switch
pb
.
GetType
()
{
case
upb
.
Data_Directory
:
return
r
.
writeDirToBuf
(
ctx
,
nd
,
path
,
depth
)
case
upb
.
Data_File
:
return
r
.
writeFileToBuf
(
ctx
,
nd
,
pb
,
path
,
depth
)
default
:
return
fmt
.
Errorf
(
"unixfs type not supported: %s"
,
pb
.
GetType
())
}
}
...
...
@@ -198,3 +198,24 @@ func (r *Reader) syncCopy(reader io.Reader) error {
}
return
nil
}
func
writeDirHeader
(
w
*
tar
.
Writer
,
path
string
)
error
{
return
w
.
WriteHeader
(
&
tar
.
Header
{
Name
:
path
,
Typeflag
:
tar
.
TypeDir
,
Mode
:
0777
,
ModTime
:
time
.
Now
(),
// TODO: set mode, dates, etc. when added to unixFS
})
}
func
writeFileHeader
(
w
*
tar
.
Writer
,
path
string
,
size
uint64
)
error
{
return
w
.
WriteHeader
(
&
tar
.
Header
{
Name
:
path
,
Size
:
int64
(
size
),
Typeflag
:
tar
.
TypeReg
,
Mode
:
0644
,
ModTime
:
time
.
Now
(),
// TODO: set mode, dates, etc. when added to unixFS
})
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论