Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
c88b4b09
提交
c88b4b09
authored
8月 14, 2016
作者:
Kevin Atkinson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
"block rm": remove the option to ignore pins
License: MIT Signed-off-by:
Kevin Atkinson
<
k@kevina.org
>
上级
efeb7898
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
8 行增加
和
38 行删除
+8
-38
block.go
core/commands/block.go
+7
-28
t0050-block.sh
test/sharness/t0050-block.sh
+1
-10
没有找到文件。
core/commands/block.go
浏览文件 @
c88b4b09
...
...
@@ -200,15 +200,7 @@ It takes a list of base58 encoded multihashs to remove.
Arguments
:
[]
cmds
.
Argument
{
cmds
.
StringArg
(
"hash"
,
true
,
true
,
"Bash58 encoded multihash of block(s) to remove."
),
},
Options
:
[]
cmds
.
Option
{
cmds
.
BoolOption
(
"ignore-pins"
,
"Ignore pins."
)
.
Default
(
false
),
},
Run
:
func
(
req
cmds
.
Request
,
res
cmds
.
Response
)
{
ignorePins
,
_
,
err
:=
req
.
Option
(
"ignore-pins"
)
.
Bool
()
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
n
,
err
:=
req
.
InvocContext
()
.
GetNode
()
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
...
...
@@ -225,9 +217,6 @@ It takes a list of base58 encoded multihashs to remove.
go
func
()
{
defer
close
(
outChan
)
pinning
:=
n
.
Pinning
if
ignorePins
{
pinning
=
nil
}
err
:=
rmBlocks
(
n
.
Blockstore
,
pinning
,
outChan
,
keys
)
if
err
!=
nil
{
outChan
<-
&
RemovedBlock
{
Error
:
err
.
Error
()}
...
...
@@ -271,25 +260,15 @@ type RemovedBlock struct {
Error
string
`json:",omitempty"`
}
// pins may be nil
func
rmBlocks
(
blocks
bs
.
GCBlockstore
,
pins
pin
.
Pinner
,
out
chan
<-
interface
{},
keys
[]
key
.
Key
)
error
{
var
unlocker
bs
.
Unlocker
defer
func
()
{
if
unlocker
!=
nil
{
unlocker
.
Unlock
()
}
}()
stillOkay
:=
keys
if
pins
!=
nil
{
// Need to make sure that some operation that is
// finishing with a pin is ocurr simultaneously.
unlocker
=
blocks
.
GCLock
()
var
err
error
stillOkay
,
err
=
checkIfPinned
(
pins
,
keys
,
out
)
if
err
!=
nil
{
return
fmt
.
Errorf
(
"pin check failed: %s"
,
err
)
}
unlocker
:=
blocks
.
GCLock
()
defer
unlocker
.
Unlock
()
stillOkay
,
err
:=
checkIfPinned
(
pins
,
keys
,
out
)
if
err
!=
nil
{
return
fmt
.
Errorf
(
"pin check failed: %s"
,
err
)
}
for
_
,
k
:=
range
stillOkay
{
err
:=
blocks
.
DeleteBlock
(
k
)
if
err
!=
nil
{
...
...
test/sharness/t0050-block.sh
浏览文件 @
c88b4b09
...
...
@@ -82,16 +82,7 @@ test_expect_success "can't remove indirectly pinned block: output looks good" '
grep -q "$FILE1HASH: pinned via $DIRHASH" block_rm_err
'
test_expect_success
"multi-block 'ipfs block rm --ignore-pins' succeeds"
'
ipfs block rm --ignore-pins $DIRHASH >actual_rm
'
test_expect_success
"multi-block 'ipfs block rm --ignore-pins' output looks good"
'
echo "removed $DIRHASH" > expected_rm &&
test_cmp expected_rm actual_rm
'
test_expect_success
"fix up pins"
'
test_expect_success
"remove pin"
'
ipfs pin rm -r $DIRHASH
'
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论