Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
faeb0404
R
Rust
项目概览
int
/
Rust
大约 1 年 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rust
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
faeb0404
编写于
4月 18, 2020
作者:
E
Esteban Küber
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Remove unnecessary allocation
上级
2000f91f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
26 deletion
+25
-26
src/librustc_trait_selection/traits/wf.rs
src/librustc_trait_selection/traits/wf.rs
+25
-26
未找到文件。
src/librustc_trait_selection/traits/wf.rs
浏览文件 @
faeb0404
...
...
@@ -140,7 +140,7 @@ fn extend_cause_with_original_assoc_item_obligation<'tcx>(
item
:
Option
<&
hir
::
Item
<
'tcx
>>
,
cause
:
&
mut
traits
::
ObligationCause
<
'tcx
>
,
pred
:
&
ty
::
Predicate
<
'_
>
,
mut
trait_assoc_items
:
impl
Iterator
<
Item
=
ty
::
AssocItem
>
,
mut
trait_assoc_items
:
impl
Iterator
<
Item
=
&
'tcx
ty
::
AssocItem
>
,
)
{
debug!
(
"extended_cause_with_original_assoc_item_obligation {:?} {:?} {:?} {:?}"
,
...
...
@@ -232,35 +232,34 @@ fn compute_trait_ref(&mut self, trait_ref: &ty::TraitRef<'tcx>, elaborate: Elabo
let
item
=
self
.item
;
let
extend
=
|
obligation
:
traits
::
PredicateObligation
<
'tcx
>
|
{
let
mut
cause
=
cause
.clone
();
if
let
Some
(
parent_trait_ref
)
=
obligation
.predicate
.to_opt_poly_trait_ref
()
{
let
derived_cause
=
traits
::
DerivedObligationCause
{
parent_trait_ref
,
parent_code
:
Rc
::
new
(
obligation
.cause.code
.clone
()),
};
cause
.code
=
traits
::
ObligationCauseCode
::
DerivedObligation
(
derived_cause
);
}
extend_cause_with_original_assoc_item_obligation
(
tcx
,
trait_ref
,
item
,
&
mut
cause
,
&
obligation
.predicate
,
tcx
.associated_items
(
trait_ref
.def_id
)
.in_definition_order
(),
);
traits
::
Obligation
::
new
(
cause
,
param_env
,
obligation
.predicate
)
};
if
let
Elaborate
::
All
=
elaborate
{
let
implied_obligations
=
traits
::
util
::
elaborate_obligations
(
tcx
,
obligations
.clone
());
let
implied_obligations
=
implied_obligations
.map
(|
obligation
|
{
debug!
(
"compute_trait_ref implied_obligation {:?}"
,
obligation
);
debug!
(
"compute_trait_ref implied_obligation cause {:?}"
,
obligation
.cause
);
let
mut
cause
=
cause
.clone
();
if
let
Some
(
parent_trait_ref
)
=
obligation
.predicate
.to_opt_poly_trait_ref
()
{
let
derived_cause
=
traits
::
DerivedObligationCause
{
parent_trait_ref
,
parent_code
:
Rc
::
new
(
obligation
.cause.code
.clone
()),
};
cause
.code
=
traits
::
ObligationCauseCode
::
DerivedObligation
(
derived_cause
);
}
extend_cause_with_original_assoc_item_obligation
(
tcx
,
trait_ref
,
item
,
&
mut
cause
,
&
obligation
.predicate
,
tcx
.associated_items
(
trait_ref
.def_id
)
.in_definition_order
()
.copied
(),
);
debug!
(
"compute_trait_ref new cause {:?}"
,
cause
);
traits
::
Obligation
::
new
(
cause
,
param_env
,
obligation
.predicate
)
});
let
implied_obligations
=
traits
::
util
::
elaborate_obligations
(
tcx
,
obligations
);
let
implied_obligations
=
implied_obligations
.map
(
extend
);
self
.out
.extend
(
implied_obligations
);
}
else
{
self
.out
.extend
(
obligations
);
}
self
.out
.extend
(
obligations
);
self
.out
.extend
(
trait_ref
.substs
.types
()
.filter
(|
ty
|
!
ty
.has_escaping_bound_vars
())
.map
(
|
ty
|
traits
::
Obligation
::
new
(
cause
.clone
(),
param_env
,
ty
::
Predicate
::
WellFormed
(
ty
)),
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录