Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
c08b8958
提交
c08b8958
authored
9月 16, 2014
作者:
Juan Batiz-Benet
提交者:
Brian Tiger Chow
9月 22, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Peerstore - threadsafe peer collection
will have persistence later on as a datastore passed in.
上级
4cc1f60d
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
86 行增加
和
0 行删除
+86
-0
peerstore.go
peer/peerstore.go
+86
-0
没有找到文件。
peer/peerstore.go
0 → 100644
浏览文件 @
c08b8958
package
peer
import
(
"errors"
"sync"
u
"github.com/jbenet/go-ipfs/util"
ds
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/datastore.go"
)
// Peerstore provides a threadsafe collection for peers.
type
Peerstore
interface
{
Get
(
ID
)
(
*
Peer
,
error
)
Add
(
*
Peer
)
error
Remove
(
ID
)
error
All
()
(
*
map
[
u
.
Key
]
*
Peer
,
error
)
}
type
peerstore
struct
{
sync
.
RWMutex
peers
ds
.
Datastore
}
// NewPeerstore creates a threadsafe collection of peers.
func
NewPeerstore
()
Peerstore
{
return
&
peerstore
{
peers
:
ds
.
NewMapDatastore
(),
}
}
func
(
p
*
peerstore
)
Get
(
i
ID
)
(
*
Peer
,
error
)
{
p
.
RLock
()
defer
p
.
RUnlock
()
val
,
err
:=
p
.
peers
.
Get
(
ds
.
NewKey
(
string
(
i
)))
if
err
!=
nil
{
return
nil
,
err
}
peer
,
ok
:=
val
.
(
*
Peer
)
if
!
ok
{
return
nil
,
errors
.
New
(
"stored value was not a Peer"
)
}
return
peer
,
nil
}
func
(
p
*
peerstore
)
Add
(
peer
*
Peer
)
error
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
ds
.
NewKey
(
string
(
peer
.
ID
))
return
p
.
peers
.
Put
(
k
,
peer
)
}
func
(
p
*
peerstore
)
Remove
(
i
ID
)
error
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
ds
.
NewKey
(
string
(
i
))
return
p
.
peers
.
Delete
(
k
)
}
func
(
p
*
peerstore
)
All
()
(
*
map
[
u
.
Key
]
*
Peer
,
error
)
{
p
.
RLock
()
defer
p
.
RUnlock
()
l
,
err
:=
p
.
peers
.
KeyList
()
if
err
!=
nil
{
return
nil
,
err
}
ps
:=
&
map
[
u
.
Key
]
*
Peer
{}
for
_
,
k
:=
range
l
{
val
,
err
:=
p
.
peers
.
Get
(
k
)
if
err
!=
nil
{
continue
}
pval
,
ok
:=
val
.
(
*
Peer
)
if
ok
{
(
*
ps
)[
u
.
Key
(
k
.
String
())]
=
pval
}
}
return
ps
,
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论