Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
b1f77e9e
提交
b1f77e9e
authored
3月 02, 2016
作者:
Mildred Ki'Lya
提交者:
Shanti Bouchez-Mongardé
3月 04, 2016
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Improve error reporting and fix pin/set_test.go
License: MIT Signed-off-by:
Mildred Ki'Lya
<
mildred-pub.git@mildred.fr
>
上级
8f8020e8
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
30 行增加
和
5 行删除
+30
-5
coding.go
merkledag/coding.go
+1
-1
merkledag.go
merkledag/merkledag.go
+6
-2
set.go
pin/set.go
+2
-2
set_test.go
pin/set_test.go
+21
-0
没有找到文件。
merkledag/coding.go
浏览文件 @
b1f77e9e
...
...
@@ -27,7 +27,7 @@ func (n *Node) unmarshal(encoded []byte) error {
n
.
Links
[
i
]
=
&
Link
{
Name
:
l
.
GetName
(),
Size
:
l
.
GetTsize
()}
h
,
err
:=
mh
.
Cast
(
l
.
GetHash
())
if
err
!=
nil
{
return
fmt
.
Errorf
(
"Link hash
is not valid multihash. %v"
,
err
)
return
fmt
.
Errorf
(
"Link hash
#%d is not valid multihash. %v"
,
i
,
err
)
}
n
.
Links
[
i
]
.
Hash
=
h
}
...
...
merkledag/merkledag.go
浏览文件 @
b1f77e9e
...
...
@@ -79,10 +79,14 @@ func (n *dagService) Get(ctx context.Context, k key.Key) (*Node, error) {
if
err
==
bserv
.
ErrNotFound
{
return
nil
,
ErrNotFound
}
return
nil
,
err
return
nil
,
fmt
.
Errorf
(
"Failed to get block for %s: %v"
,
k
.
B58String
(),
err
)
}
return
DecodeProtobuf
(
b
.
Data
)
res
,
err
:=
DecodeProtobuf
(
b
.
Data
)
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"Failed to decode Protocol Buffers: %v"
,
err
)
}
return
res
,
nil
}
func
(
n
*
dagService
)
Remove
(
nd
*
Node
)
error
{
...
...
pin/set.go
浏览文件 @
b1f77e9e
...
...
@@ -271,12 +271,12 @@ func loadSet(ctx context.Context, dag merkledag.DAGService, root *merkledag.Node
func
loadMultiset
(
ctx
context
.
Context
,
dag
merkledag
.
DAGService
,
root
*
merkledag
.
Node
,
name
string
,
internalKeys
keyObserver
)
(
map
[
key
.
Key
]
uint64
,
error
)
{
l
,
err
:=
root
.
GetNodeLink
(
name
)
if
err
!=
nil
{
return
nil
,
err
return
nil
,
fmt
.
Errorf
(
"Failed to get link %s: %v"
,
name
,
err
)
}
internalKeys
(
key
.
Key
(
l
.
Hash
))
n
,
err
:=
l
.
GetNode
(
ctx
,
dag
)
if
err
!=
nil
{
return
nil
,
err
return
nil
,
fmt
.
Errorf
(
"Failed to get node from link %s: %v"
,
name
,
err
)
}
refcounts
:=
make
(
map
[
key
.
Key
]
uint64
)
...
...
pin/set_test.go
浏览文件 @
b1f77e9e
...
...
@@ -11,6 +11,8 @@ import (
"github.com/ipfs/go-ipfs/blockservice"
"github.com/ipfs/go-ipfs/exchange/offline"
"github.com/ipfs/go-ipfs/merkledag"
mh
"gx/ipfs/QmYf7ng2hG5XBtJA3tN34DQ2GUN5HNksEw1rLDkmr6vGku/go-multihash"
u
"gx/ipfs/QmZNVWh8LLjAavuQ2JXuFmuYH3C11xo988vSgp7UQrTRj1/go-ipfs-util"
"gx/ipfs/QmZy2y8t9zQH2a1b8q2ZSLKp17ATuJoCNxxyMFG5qFExpt/go-net/context"
)
...
...
@@ -31,6 +33,14 @@ func TestMultisetRoundtrip(t *testing.T) {
dag
:=
merkledag
.
NewDAGService
(
bserv
)
fn
:=
func
(
m
map
[
key
.
Key
]
uint16
)
bool
{
// Convert invalid multihash from input to valid ones
for
k
,
v
:=
range
m
{
if
_
,
err
:=
mh
.
Cast
([]
byte
(
k
));
err
!=
nil
{
delete
(
m
,
k
)
m
[
key
.
Key
(
u
.
Hash
([]
byte
(
k
)))]
=
v
}
}
// Generate a smaller range for refcounts than full uint64, as
// otherwise this just becomes overly cpu heavy, splitting it
// out into too many items. That means we need to convert to
...
...
@@ -43,6 +53,17 @@ func TestMultisetRoundtrip(t *testing.T) {
if
err
!=
nil
{
t
.
Fatalf
(
"storing multiset: %v"
,
err
)
}
// Check that the node n is in the DAG
k
,
err
:=
n
.
Key
()
if
err
!=
nil
{
t
.
Fatalf
(
"Could not get key: %v"
,
err
)
}
_
,
err
=
dag
.
Get
(
ctx
,
k
)
if
err
!=
nil
{
t
.
Fatalf
(
"Could not get node: %v"
,
err
)
}
root
:=
&
merkledag
.
Node
{}
const
linkName
=
"dummylink"
if
err
:=
root
.
AddNodeLink
(
linkName
,
n
);
err
!=
nil
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论