Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
153bb681
提交
153bb681
authored
1月 05, 2018
作者:
Steven Allen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
implement an ipfs cat --length flag
fixes #4085 License: MIT Signed-off-by:
Steven Allen
<
steven@stebalien.com
>
上级
2ab6d3d6
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
30 行增加
和
3 行删除
+30
-3
cat.go
core/commands/cat.go
+30
-3
没有找到文件。
core/commands/cat.go
浏览文件 @
153bb681
...
@@ -26,6 +26,7 @@ var CatCmd = &cmds.Command{
...
@@ -26,6 +26,7 @@ var CatCmd = &cmds.Command{
},
},
Options
:
[]
cmdkit
.
Option
{
Options
:
[]
cmdkit
.
Option
{
cmdkit
.
IntOption
(
"offset"
,
"o"
,
"Byte offset to begin reading from."
),
cmdkit
.
IntOption
(
"offset"
,
"o"
,
"Byte offset to begin reading from."
),
cmdkit
.
IntOption
(
"length"
,
"l"
,
"Maximum number of bytes to read."
),
},
},
Run
:
func
(
req
cmds
.
Request
,
res
cmds
.
ResponseEmitter
)
{
Run
:
func
(
req
cmds
.
Request
,
res
cmds
.
ResponseEmitter
)
{
node
,
err
:=
req
.
InvocContext
()
.
GetNode
()
node
,
err
:=
req
.
InvocContext
()
.
GetNode
()
...
@@ -50,7 +51,20 @@ var CatCmd = &cmds.Command{
...
@@ -50,7 +51,20 @@ var CatCmd = &cmds.Command{
return
return
}
}
readers
,
length
,
err
:=
cat
(
req
.
Context
(),
node
,
req
.
Arguments
(),
int64
(
offset
))
max
,
found
,
err
:=
req
.
Option
(
"length"
)
.
Int
()
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
}
if
max
<
0
{
res
.
SetError
(
fmt
.
Errorf
(
"Cannot specify negative length."
),
cmdkit
.
ErrNormal
)
return
}
if
!
found
{
max
=
-
1
}
readers
,
length
,
err
:=
cat
(
req
.
Context
(),
node
,
req
.
Arguments
(),
int64
(
offset
),
int64
(
max
))
if
err
!=
nil
{
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
...
@@ -116,9 +130,12 @@ var CatCmd = &cmds.Command{
...
@@ -116,9 +130,12 @@ var CatCmd = &cmds.Command{
},
},
}
}
func
cat
(
ctx
context
.
Context
,
node
*
core
.
IpfsNode
,
paths
[]
string
,
offset
int64
)
([]
io
.
Reader
,
uint64
,
error
)
{
func
cat
(
ctx
context
.
Context
,
node
*
core
.
IpfsNode
,
paths
[]
string
,
offset
int64
,
max
int64
)
([]
io
.
Reader
,
uint64
,
error
)
{
readers
:=
make
([]
io
.
Reader
,
0
,
len
(
paths
))
readers
:=
make
([]
io
.
Reader
,
0
,
len
(
paths
))
length
:=
uint64
(
0
)
length
:=
uint64
(
0
)
if
max
==
0
{
return
nil
,
0
,
nil
}
for
_
,
fpath
:=
range
paths
{
for
_
,
fpath
:=
range
paths
{
read
,
err
:=
coreunix
.
Cat
(
ctx
,
node
,
fpath
)
read
,
err
:=
coreunix
.
Cat
(
ctx
,
node
,
fpath
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -134,8 +151,18 @@ func cat(ctx context.Context, node *core.IpfsNode, paths []string, offset int64)
...
@@ -134,8 +151,18 @@ func cat(ctx context.Context, node *core.IpfsNode, paths []string, offset int64)
}
}
offset
=
0
offset
=
0
size
:=
uint64
(
read
.
Size
()
-
uint64
(
count
))
length
+=
size
if
max
>
0
&&
length
>=
uint64
(
max
)
{
var
r
io
.
Reader
=
read
if
overshoot
:=
int64
(
length
-
uint64
(
max
));
overshoot
!=
0
{
r
=
io
.
LimitReader
(
read
,
int64
(
size
)
-
overshoot
)
length
=
uint64
(
max
)
}
readers
=
append
(
readers
,
r
)
break
}
readers
=
append
(
readers
,
read
)
readers
=
append
(
readers
,
read
)
length
+=
uint64
(
read
.
Size
()
-
uint64
(
count
))
}
}
return
readers
,
length
,
nil
return
readers
,
length
,
nil
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论