Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
7fcf56e8
提交
7fcf56e8
authored
10月 16, 2018
作者:
Łukasz Magiera
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
namesys: select on output
License: MIT Signed-off-by:
Łukasz Magiera
<
magik6k@gmail.com
>
上级
734615ac
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
32 行增加
和
54 行删除
+32
-54
base.go
namesys/base.go
+17
-20
dns.go
namesys/dns.go
+2
-8
namesys.go
namesys/namesys.go
+9
-10
routing.go
namesys/routing.go
+4
-16
没有找到文件。
namesys/base.go
浏览文件 @
7fcf56e8
...
@@ -49,6 +49,11 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
...
@@ -49,6 +49,11 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
defer
close
(
outCh
)
defer
close
(
outCh
)
var
subCh
<-
chan
Result
var
subCh
<-
chan
Result
var
cancelSub
context
.
CancelFunc
var
cancelSub
context
.
CancelFunc
defer
func
()
{
if
cancelSub
!=
nil
{
cancelSub
()
}
}()
for
{
for
{
select
{
select
{
...
@@ -59,20 +64,17 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
...
@@ -59,20 +64,17 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
}
}
if
res
.
err
!=
nil
{
if
res
.
err
!=
nil
{
outCh
<-
Result
{
Err
:
res
.
err
}
emitResult
(
ctx
,
outCh
,
Result
{
Err
:
res
.
err
})
if
cancelSub
!=
nil
{
cancelSub
()
}
return
return
}
}
log
.
Debugf
(
"resolved %s to %s"
,
name
,
res
.
value
.
String
())
log
.
Debugf
(
"resolved %s to %s"
,
name
,
res
.
value
.
String
())
if
!
strings
.
HasPrefix
(
res
.
value
.
String
(),
ipnsPrefix
)
{
if
!
strings
.
HasPrefix
(
res
.
value
.
String
(),
ipnsPrefix
)
{
outCh
<-
Result
{
Path
:
res
.
value
}
emitResult
(
ctx
,
outCh
,
Result
{
Path
:
res
.
value
})
break
break
}
}
if
depth
==
1
{
if
depth
==
1
{
outCh
<-
Result
{
Path
:
res
.
value
,
Err
:
ErrResolveRecursion
}
emitResult
(
ctx
,
outCh
,
Result
{
Path
:
res
.
value
,
Err
:
ErrResolveRecursion
})
break
break
}
}
...
@@ -87,6 +89,7 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
...
@@ -87,6 +89,7 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
cancelSub
()
cancelSub
()
}
}
subCtx
,
cancelSub
=
context
.
WithCancel
(
ctx
)
subCtx
,
cancelSub
=
context
.
WithCancel
(
ctx
)
_
=
cancelSub
p
:=
strings
.
TrimPrefix
(
res
.
value
.
String
(),
ipnsPrefix
)
p
:=
strings
.
TrimPrefix
(
res
.
value
.
String
(),
ipnsPrefix
)
subCh
=
resolveAsync
(
subCtx
,
r
,
p
,
subopts
)
subCh
=
resolveAsync
(
subCtx
,
r
,
p
,
subopts
)
...
@@ -96,27 +99,21 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
...
@@ -96,27 +99,21 @@ func resolveAsync(ctx context.Context, r resolver, name string, options opts.Res
break
break
}
}
select
{
emitResult
(
ctx
,
outCh
,
res
)
case
outCh
<-
res
:
case
<-
ctx
.
Done
()
:
if
cancelSub
!=
nil
{
cancelSub
()
}
return
}
case
<-
ctx
.
Done
()
:
case
<-
ctx
.
Done
()
:
if
cancelSub
!=
nil
{
cancelSub
()
}
return
return
}
}
if
resCh
==
nil
&&
subCh
==
nil
{
if
resCh
==
nil
&&
subCh
==
nil
{
if
cancelSub
!=
nil
{
cancelSub
()
}
return
return
}
}
}
}
}()
}()
return
outCh
return
outCh
}
}
func
emitResult
(
ctx
context
.
Context
,
outCh
chan
<-
Result
,
r
Result
)
{
select
{
case
outCh
<-
r
:
case
<-
ctx
.
Done
()
:
}
}
namesys/dns.go
浏览文件 @
7fcf56e8
...
@@ -80,10 +80,7 @@ func (r *DNSResolver) resolveOnceAsync(ctx context.Context, name string, options
...
@@ -80,10 +80,7 @@ func (r *DNSResolver) resolveOnceAsync(ctx context.Context, name string, options
}
}
if
subRes
.
error
==
nil
{
if
subRes
.
error
==
nil
{
p
,
err
:=
appendPath
(
subRes
.
path
)
p
,
err
:=
appendPath
(
subRes
.
path
)
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
value
:
p
,
err
:
err
})
case
out
<-
onceResult
{
value
:
p
,
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
return
return
}
}
case
rootRes
,
ok
:=
<-
rootChan
:
case
rootRes
,
ok
:=
<-
rootChan
:
...
@@ -93,10 +90,7 @@ func (r *DNSResolver) resolveOnceAsync(ctx context.Context, name string, options
...
@@ -93,10 +90,7 @@ func (r *DNSResolver) resolveOnceAsync(ctx context.Context, name string, options
}
}
if
rootRes
.
error
==
nil
{
if
rootRes
.
error
==
nil
{
p
,
err
:=
appendPath
(
rootRes
.
path
)
p
,
err
:=
appendPath
(
rootRes
.
path
)
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
value
:
p
,
err
:
err
})
case
out
<-
onceResult
{
value
:
p
,
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
}
}
case
<-
ctx
.
Done
()
:
case
<-
ctx
.
Done
()
:
return
return
...
...
namesys/namesys.go
浏览文件 @
7fcf56e8
...
@@ -141,19 +141,11 @@ func (ns *mpns) resolveOnceAsync(ctx context.Context, name string, options opts.
...
@@ -141,19 +141,11 @@ func (ns *mpns) resolveOnceAsync(ctx context.Context, name string, options opts.
if
len
(
segments
)
>
3
{
if
len
(
segments
)
>
3
{
p
,
err
:=
path
.
FromSegments
(
""
,
strings
.
TrimRight
(
p
.
String
(),
"/"
),
segments
[
3
])
p
,
err
:=
path
.
FromSegments
(
""
,
strings
.
TrimRight
(
p
.
String
(),
"/"
),
segments
[
3
])
if
err
!=
nil
{
if
err
!=
nil
{
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
value
:
p
,
ttl
:
res
.
ttl
,
err
:
err
})
case
out
<-
onceResult
{
value
:
p
,
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
return
}
}
}
}
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
value
:
p
,
ttl
:
res
.
ttl
,
err
:
res
.
err
})
case
out
<-
onceResult
{
value
:
p
,
ttl
:
res
.
ttl
,
err
:
res
.
err
}
:
case
<-
ctx
.
Done
()
:
return
}
case
<-
ctx
.
Done
()
:
case
<-
ctx
.
Done
()
:
return
return
}
}
...
@@ -163,6 +155,13 @@ func (ns *mpns) resolveOnceAsync(ctx context.Context, name string, options opts.
...
@@ -163,6 +155,13 @@ func (ns *mpns) resolveOnceAsync(ctx context.Context, name string, options opts.
return
out
return
out
}
}
func
emitOnceResult
(
ctx
context
.
Context
,
outCh
chan
<-
onceResult
,
r
onceResult
)
{
select
{
case
outCh
<-
r
:
case
<-
ctx
.
Done
()
:
}
}
// Publish implements Publisher
// Publish implements Publisher
func
(
ns
*
mpns
)
Publish
(
ctx
context
.
Context
,
name
ci
.
PrivKey
,
value
path
.
Path
)
error
{
func
(
ns
*
mpns
)
Publish
(
ctx
context
.
Context
,
name
ci
.
PrivKey
,
value
path
.
Path
)
error
{
return
ns
.
PublishWithEOL
(
ctx
,
name
,
value
,
time
.
Now
()
.
Add
(
DefaultRecordTTL
))
return
ns
.
PublishWithEOL
(
ctx
,
name
,
value
,
time
.
Now
()
.
Add
(
DefaultRecordTTL
))
...
...
namesys/routing.go
浏览文件 @
7fcf56e8
...
@@ -112,10 +112,7 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
...
@@ -112,10 +112,7 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
err
=
proto
.
Unmarshal
(
val
,
entry
)
err
=
proto
.
Unmarshal
(
val
,
entry
)
if
err
!=
nil
{
if
err
!=
nil
{
log
.
Debugf
(
"RoutingResolver: could not unmarshal value for name %s: %s"
,
name
,
err
)
log
.
Debugf
(
"RoutingResolver: could not unmarshal value for name %s: %s"
,
name
,
err
)
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
err
:
err
})
case
out
<-
onceResult
{
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
return
return
}
}
...
@@ -129,10 +126,7 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
...
@@ -129,10 +126,7 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
// Not a multihash, probably a new style record
// Not a multihash, probably a new style record
p
,
err
=
path
.
ParsePath
(
string
(
entry
.
GetValue
()))
p
,
err
=
path
.
ParsePath
(
string
(
entry
.
GetValue
()))
if
err
!=
nil
{
if
err
!=
nil
{
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
err
:
err
})
case
out
<-
onceResult
{
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
return
return
}
}
}
}
...
@@ -154,17 +148,11 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
...
@@ -154,17 +148,11 @@ func (r *IpnsResolver) resolveOnceAsync(ctx context.Context, name string, option
}
}
default
:
default
:
log
.
Errorf
(
"encountered error when parsing EOL: %s"
,
err
)
log
.
Errorf
(
"encountered error when parsing EOL: %s"
,
err
)
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
err
:
err
})
case
out
<-
onceResult
{
err
:
err
}
:
case
<-
ctx
.
Done
()
:
}
return
return
}
}
select
{
emitOnceResult
(
ctx
,
out
,
onceResult
{
value
:
p
,
ttl
:
ttl
})
case
out
<-
onceResult
{
value
:
p
,
ttl
:
ttl
}
:
case
<-
ctx
.
Done
()
:
}
case
<-
ctx
.
Done
()
:
case
<-
ctx
.
Done
()
:
return
return
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论