Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
ab460ed8
提交
ab460ed8
authored
9月 14, 2014
作者:
Brian Tiger Chow
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(bs, core) rename bitswap objects
上级
0075a47d
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
19 行增加
和
15 行删除
+19
-15
bitswap.go
bitswap/bitswap.go
+8
-3
service_wrapper.go
bitswap/transmission/service_wrapper.go
+6
-6
core.go
core/core.go
+5
-6
没有找到文件。
bitswap/bitswap.go
浏览文件 @
ab460ed8
...
...
@@ -60,10 +60,15 @@ type BitSwap struct {
haltChan
chan
struct
{}
}
// NewBitSwap creates a new BitSwap instance. It does not check its parameters.
func
NewBitSwap
(
p
*
peer
.
Peer
,
d
ds
.
Datastore
,
r
routing
.
IpfsRouting
)
*
BitSwap
{
// NewSession initializes a bitswap session.
func
NewSession
(
parent
context
.
Context
,
p
*
peer
.
Peer
,
d
ds
.
Datastore
,
r
routing
.
IpfsRouting
)
*
BitSwap
{
// TODO(brian): define a contract for management of async operations that
// fall under bitswap's purview
ctx
,
_
:=
context
.
WithCancel
(
parent
)
receiver
:=
tx
.
Forwarder
{}
sender
:=
tx
.
New
BSNetService
(
context
.
Background
()
,
&
receiver
)
sender
:=
tx
.
New
ServiceWrapper
(
ctx
,
&
receiver
)
bs
:=
&
BitSwap
{
peer
:
p
,
datastore
:
d
,
...
...
bitswap/transmission/service_wrapper.go
浏览文件 @
ab460ed8
...
...
@@ -9,10 +9,10 @@ import (
peer
"github.com/jbenet/go-ipfs/peer"
)
func
New
BSNetService
(
ctx
context
.
Context
,
r
Receiver
)
Sender
{
func
New
ServiceWrapper
(
ctx
context
.
Context
,
r
Receiver
)
Sender
{
h
:=
&
handlerWrapper
{
r
}
s
:=
netservice
.
NewService
(
ctx
,
h
)
return
&
se
rviceWrapper
{
*
s
}
return
&
se
nderWrapper
{
s
}
}
// handlerWrapper is responsible for marshaling/unmarshaling NetMessages. It
...
...
@@ -47,11 +47,11 @@ func (wrapper *handlerWrapper) HandleMessage(
return
outgoing
,
nil
}
type
se
rvice
Wrapper
struct
{
serviceDelegate
netservice
.
Se
rvice
type
se
nder
Wrapper
struct
{
serviceDelegate
netservice
.
Se
nder
}
func
(
wrapper
*
se
rvice
Wrapper
)
SendMessage
(
func
(
wrapper
*
se
nder
Wrapper
)
SendMessage
(
ctx
context
.
Context
,
p
*
peer
.
Peer
,
outgoing
bsmsg
.
Exportable
)
error
{
nmsg
,
err
:=
outgoing
.
ToNet
(
p
)
if
err
!=
nil
{
...
...
@@ -61,7 +61,7 @@ func (wrapper *serviceWrapper) SendMessage(
return
wrapper
.
serviceDelegate
.
SendMessage
(
ctx
,
nmsg
,
req
.
ID
)
}
func
(
wrapper
*
se
rvice
Wrapper
)
SendRequest
(
ctx
context
.
Context
,
func
(
wrapper
*
se
nder
Wrapper
)
SendRequest
(
ctx
context
.
Context
,
p
*
peer
.
Peer
,
outgoing
bsmsg
.
Exportable
)
(
bsmsg
.
BitSwapMessage
,
error
)
{
outgoingMsg
,
err
:=
outgoing
.
ToNet
(
p
)
...
...
core/core.go
浏览文件 @
ab460ed8
...
...
@@ -46,7 +46,7 @@ type IpfsNode struct {
Routing
routing
.
IpfsRouting
// the block exchange + strategy (bitswap)
BitSwap
*
bitswap
.
BitSwap
BitSwap
bitswap
.
BitSwap
// the block service, get/add blocks.
Blocks
*
bserv
.
BlockService
...
...
@@ -81,7 +81,6 @@ func NewIpfsNode(cfg *config.Config, online bool) (*IpfsNode, error) {
net
*
inet
.
Network
// TODO: refactor so we can use IpfsRouting interface instead of being DHT-specific
route
*
dht
.
IpfsDHT
swap
*
bitswap
.
BitSwap
)
if
online
{
...
...
@@ -99,14 +98,14 @@ func NewIpfsNode(cfg *config.Config, online bool) (*IpfsNode, error) {
route
.
Start
()
// TODO(brian): pass a context to bs for its async operations
swap
=
bitswap
.
NewBitSwap
(
local
,
d
,
route
)
swap
.
SetStrategy
(
bitswap
.
YesManStrategy
)
bitswapSession
:=
bitswap
.
NewSession
(
context
.
TODO
(),
local
,
d
,
route
)
bitswapSession
.
SetStrategy
(
bitswap
.
YesManStrategy
)
// TODO(brian): pass a context to initConnections
go
initConnections
(
cfg
,
route
)
}
bs
,
err
:=
bserv
.
NewBlockService
(
d
,
swap
)
bs
,
err
:=
bserv
.
NewBlockService
(
d
,
bitswapSession
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -120,7 +119,7 @@ func NewIpfsNode(cfg *config.Config, online bool) (*IpfsNode, error) {
Blocks
:
bs
,
DAG
:
dag
,
Resolver
:
&
path
.
Resolver
{
DAG
:
dag
},
BitSwap
:
swap
,
BitSwap
:
bitswapSession
,
Identity
:
local
,
Routing
:
route
,
},
nil
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论