Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
1e007791
提交
1e007791
authored
12月 08, 2014
作者:
Brian Tiger Chow
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(peer) impl peerstore with map
License: MIT Signed-off-by:
Brian Tiger Chow
<
brian@perfmode.com
>
上级
3f63e50c
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
29 行增加
和
78 行删除
+29
-78
peerstore.go
peer/peerstore.go
+29
-78
没有找到文件。
peer/peerstore.go
浏览文件 @
1e007791
package
peer
import
(
"errors"
"sync"
u
"github.com/jbenet/go-ipfs/util"
ds
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore"
)
// Peerstore provides a threadsafe collection for peers.
...
...
@@ -19,34 +16,26 @@ type Peerstore interface {
type
peerstore
struct
{
sync
.
RWMutex
peers
ds
.
Datastore
data
map
[
string
]
Peer
// key is string(ID)
}
// NewPeerstore creates a threadsafe collection of peers.
func
NewPeerstore
()
Peerstore
{
return
&
peerstore
{
peers
:
ds
.
NewMapDatastore
(
),
data
:
make
(
map
[
string
]
Peer
),
}
}
func
(
p
*
peerstore
)
Get
(
i
ID
)
(
Peer
,
error
)
{
p
.
Lock
()
defer
p
.
Unlock
()
func
(
p
s
*
peerstore
)
Get
(
i
ID
)
(
Peer
,
error
)
{
p
s
.
Lock
()
defer
p
s
.
Unlock
()
if
i
==
nil
{
panic
(
"wat"
)
}
k
:=
u
.
Key
(
i
)
.
DsKey
()
val
,
err
:=
p
.
peers
.
Get
(
k
)
switch
err
{
// some other datastore error
default
:
return
nil
,
err
// not found, construct it ourselves, add it to datastore, and return.
case
ds
.
ErrNotFound
:
p
,
ok
:=
ps
.
data
[
i
.
String
()]
if
!
ok
{
// not found, construct it ourselves, add it to datastore, and return.
// TODO(brian) kinda dangerous, no? If ID is invalid and doesn't
// correspond to an actual valid peer ID, this peerstore will return an
...
...
@@ -57,84 +46,46 @@ func (p *peerstore) Get(i ID) (Peer, error) {
//
// Potential bad case: Suppose values arrive from untrusted providers
// in the DHT.
peer
:=
&
peer
{
id
:
i
}
if
err
:=
p
.
peers
.
Put
(
k
,
peer
);
err
!=
nil
{
return
nil
,
err
}
return
peer
,
nil
p
=
&
peer
{
id
:
i
}
ps
.
data
[
i
.
String
()]
=
p
}
// no error, got it back fine
case
nil
:
peer
,
ok
:=
val
.
(
*
peer
)
if
!
ok
{
return
nil
,
errors
.
New
(
"stored value was not a Peer"
)
}
return
peer
,
nil
}
return
p
,
nil
}
func
(
p
*
peerstore
)
Add
(
peer
Peer
)
(
Peer
,
error
)
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
peer
.
Key
()
.
DsKey
()
val
,
err
:=
p
.
peers
.
Get
(
k
)
switch
err
{
// some other datastore error
default
:
return
nil
,
err
// not found? just add and return.
case
ds
.
ErrNotFound
:
err
:=
p
.
peers
.
Put
(
k
,
peer
)
return
peer
,
err
// no error, already here.
case
nil
:
peer2
,
ok
:=
val
.
(
Peer
)
if
!
ok
{
return
nil
,
errors
.
New
(
"stored value was not a Peer"
)
}
if
peer
==
peer2
{
return
peer
,
nil
}
// must do some merging.
peer2
.
Update
(
peer
)
return
peer2
,
nil
existing
,
ok
:=
p
.
data
[
peer
.
Key
()
.
String
()]
if
!
ok
{
// not found? just add and return.
p
.
data
[
peer
.
Key
()
.
String
()]
=
peer
return
peer
,
nil
}
// already here.
if
peer
==
existing
{
return
peer
,
nil
}
existing
.
Update
(
peer
)
// must do some merging.
return
existing
,
nil
}
func
(
p
*
peerstore
)
Delete
(
i
ID
)
error
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
u
.
Key
(
i
)
.
DsKey
(
)
return
p
.
peers
.
Delete
(
k
)
delete
(
p
.
data
,
i
.
String
()
)
return
nil
}
func
(
p
*
peerstore
)
All
()
(
*
Map
,
error
)
{
p
.
RLock
()
defer
p
.
RUnlock
()
l
,
err
:=
p
.
peers
.
KeyList
()
if
err
!=
nil
{
return
nil
,
err
}
p
.
Lock
()
defer
p
.
Unlock
()
ps
:=
&
Map
{}
for
_
,
k
:=
range
l
{
val
,
err
:=
p
.
peers
.
Get
(
k
)
if
err
!=
nil
{
continue
}
pval
,
ok
:=
val
.
(
*
peer
)
if
ok
{
(
*
ps
)[
pval
.
Key
()]
=
pval
}
ps
:=
Map
{}
for
k
,
v
:=
range
p
.
data
{
ps
[
u
.
Key
(
k
)]
=
v
}
return
ps
,
nil
return
&
ps
,
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论