Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
ac26b705
提交
ac26b705
authored
1月 14, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #547 from jbenet/fix/mux-privatize
fix: privatize Mux fields
上级
abe6cad3
c341df0a
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
41 行增加
和
31 行删除
+41
-31
basic_host.go
p2p/host/basic/basic_host.go
+3
-3
mux.go
p2p/protocol/mux.go
+33
-23
mux_test.go
p2p/protocol/mux_test.go
+5
-5
没有找到文件。
p2p/host/basic/basic_host.go
浏览文件 @
ac26b705
...
...
@@ -16,7 +16,7 @@ var log = eventlog.Logger("p2p/host/basic")
type
BasicHost
struct
{
network
inet
.
Network
mux
protocol
.
Mux
mux
*
protocol
.
Mux
ids
*
identify
.
IDService
relay
*
relay
.
RelayService
}
...
...
@@ -25,7 +25,7 @@ type BasicHost struct {
func
New
(
net
inet
.
Network
)
*
BasicHost
{
h
:=
&
BasicHost
{
network
:
net
,
mux
:
protocol
.
Mux
{
Handlers
:
protocol
.
StreamHandlerMap
{}}
,
mux
:
protocol
.
NewMux
()
,
}
// setup host services
...
...
@@ -65,7 +65,7 @@ func (h *BasicHost) Network() inet.Network {
// Mux returns the Mux multiplexing incoming streams to protocol handlers
func
(
h
*
BasicHost
)
Mux
()
*
protocol
.
Mux
{
return
&
h
.
mux
return
h
.
mux
}
func
(
h
*
BasicHost
)
IDService
()
*
identify
.
IDService
{
...
...
p2p/protocol/mux.go
浏览文件 @
ac26b705
...
...
@@ -14,7 +14,7 @@ import (
var
log
=
eventlog
.
Logger
(
"net/mux"
)
type
S
treamHandlerMap
map
[
ID
]
inet
.
StreamHandler
type
s
treamHandlerMap
map
[
ID
]
inet
.
StreamHandler
// Mux provides simple stream multixplexing.
// It helps you precisely when:
...
...
@@ -23,24 +23,28 @@ type StreamHandlerMap map[ID]inet.StreamHandler
//
// It contains the handlers for each protocol accepted.
// It dispatches handlers for streams opened by remote peers.
//
// WARNING: this datastructure IS NOT threadsafe.
// do not modify it once the network is using it.
type
Mux
struct
{
Default
inet
.
StreamHandler
// handles unknown protocols.
Handlers
StreamHandlerMap
// defaultHandler handles unknown protocols. Callers modify at your own risk.
defaultHandler
inet
.
StreamHandler
lock
sync
.
RWMutex
handlers
streamHandlerMap
}
sync
.
RWMutex
func
NewMux
()
*
Mux
{
return
&
Mux
{
handlers
:
streamHandlerMap
{},
}
}
// Protocols returns the list of protocols this muxer has handlers for
func
(
m
*
Mux
)
Protocols
()
[]
ID
{
m
.
RLock
()
l
:=
make
([]
ID
,
0
,
len
(
m
.
H
andlers
))
for
p
:=
range
m
.
H
andlers
{
m
.
lock
.
RLock
()
l
:=
make
([]
ID
,
0
,
len
(
m
.
h
andlers
))
for
p
:=
range
m
.
h
andlers
{
l
=
append
(
l
,
p
)
}
m
.
RUnlock
()
m
.
lock
.
RUnlock
()
return
l
}
...
...
@@ -54,14 +58,14 @@ func (m *Mux) readHeader(s io.Reader) (ID, inet.StreamHandler, error) {
}
// log.Debug("readHeader got:", p)
m
.
RLock
()
h
,
found
:=
m
.
H
andlers
[
p
]
m
.
RUnlock
()
m
.
lock
.
RLock
()
h
,
found
:=
m
.
h
andlers
[
p
]
m
.
lock
.
RUnlock
()
switch
{
case
!
found
&&
m
.
Default
!=
nil
:
return
p
,
m
.
Default
,
nil
case
!
found
&&
m
.
Default
==
nil
:
case
!
found
&&
m
.
defaultHandler
!=
nil
:
return
p
,
m
.
defaultHandler
,
nil
case
!
found
&&
m
.
defaultHandler
==
nil
:
return
p
,
nil
,
fmt
.
Errorf
(
"%s no handler with name: %s (%d)"
,
m
,
p
,
len
(
p
))
default
:
return
p
,
h
,
nil
...
...
@@ -70,18 +74,24 @@ func (m *Mux) readHeader(s io.Reader) (ID, inet.StreamHandler, error) {
// String returns the muxer's printing representation
func
(
m
*
Mux
)
String
()
string
{
m
.
RLock
()
defer
m
.
RUnlock
()
return
fmt
.
Sprintf
(
"<Muxer %p %d>"
,
m
,
len
(
m
.
Handlers
))
m
.
lock
.
RLock
()
defer
m
.
lock
.
RUnlock
()
return
fmt
.
Sprintf
(
"<Muxer %p %d>"
,
m
,
len
(
m
.
handlers
))
}
func
(
m
*
Mux
)
SetDefaultHandler
(
h
inet
.
StreamHandler
)
{
m
.
lock
.
Lock
()
m
.
defaultHandler
=
h
m
.
lock
.
Unlock
()
}
// SetHandler sets the protocol handler on the Network's Muxer.
// This operation is threadsafe.
func
(
m
*
Mux
)
SetHandler
(
p
ID
,
h
inet
.
StreamHandler
)
{
log
.
Debugf
(
"%s setting handler for protocol: %s (%d)"
,
m
,
p
,
len
(
p
))
m
.
Lock
()
m
.
H
andlers
[
p
]
=
h
m
.
Unlock
()
m
.
lock
.
Lock
()
m
.
h
andlers
[
p
]
=
h
m
.
lock
.
Unlock
()
}
// Handle reads the next name off the Stream, and calls a handler function
...
...
p2p/protocol/mux_test.go
浏览文件 @
ac26b705
...
...
@@ -38,12 +38,12 @@ func TestHandler(t *testing.T) {
}
}
m
:=
Mux
{
Handlers
:
StreamHandlerMap
{}}
m
.
Default
=
h
(
"default"
)
m
.
Handlers
[
"/dht"
]
=
h
(
"bitswap"
)
m
:=
NewMux
()
m
.
SetDefaultHandler
(
h
(
"default"
)
)
m
.
SetHandler
(
"/dht"
,
h
(
"bitswap"
)
)
// m.Handlers["/ipfs"] = h("bitswap") // default!
m
.
Handlers
[
"/bitswap"
]
=
h
(
"bitswap"
)
m
.
Handlers
[
"/ipfs/dksnafkasnfkdajfkdajfdsjadosiaaodj"
]
=
h
(
"bitswap"
)
m
.
SetHandler
(
"/bitswap"
,
h
(
"bitswap"
)
)
m
.
SetHandler
(
"/ipfs/dksnafkasnfkdajfkdajfdsjadosiaaodj"
,
h
(
"bitswap"
)
)
for
k
,
v
:=
range
testCases
{
var
buf
bytes
.
Buffer
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论