Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
8d3bb7eb
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,发现更多精彩内容 >>
提交
8d3bb7eb
编写于
7月 22, 2013
作者:
B
Brian Anderson
提交者:
Daniel Micay
7月 24, 2013
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rustc: Remove some dead code from method resolution
上级
7fbe8002
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
3 addition
and
17 deletion
+3
-17
src/librustc/middle/typeck/check/method.rs
src/librustc/middle/typeck/check/method.rs
+3
-17
未找到文件。
src/librustc/middle/typeck/check/method.rs
浏览文件 @
8d3bb7eb
...
...
@@ -194,7 +194,6 @@ pub fn do_lookup(&self, self_ty: ty::t) -> Option<method_map_entry> {
self
.push_inherent_candidates
(
self_ty
);
self
.push_extension_candidates
();
let
mut
enum_dids
=
~
[];
let
mut
self_ty
=
self_ty
;
let
mut
autoderefs
=
0
;
loop
{
...
...
@@ -236,7 +235,7 @@ pub fn do_lookup(&self, self_ty: ty::t) -> Option<method_map_entry> {
}
// Otherwise, perform autoderef.
match
self
.deref
(
self_ty
,
&
mut
enum_dids
)
{
match
self
.deref
(
self_ty
)
{
None
=>
{
break
;
}
Some
(
ty
)
=>
{
self_ty
=
ty
;
...
...
@@ -248,20 +247,8 @@ pub fn do_lookup(&self, self_ty: ty::t) -> Option<method_map_entry> {
self
.search_for_autosliced_method
(
self_ty
,
autoderefs
)
}
pub
fn
deref
(
&
self
,
ty
:
ty
::
t
,
enum_dids
:
&
mut
~
[
ast
::
def_id
]
)
pub
fn
deref
(
&
self
,
ty
:
ty
::
t
)
->
Option
<
ty
::
t
>
{
match
ty
::
get
(
ty
)
.sty
{
ty_enum
(
did
,
_
)
=>
{
// Watch out for newtype'd enums like "enum t = @T".
// See discussion in typeck::check::do_autoderef().
if
enum_dids
.iter
()
.any
(|
x
|
x
==
&
did
)
{
return
None
;
}
enum_dids
.push
(
did
);
}
_
=>
{}
}
match
ty
::
deref
(
self
.tcx
(),
ty
,
false
)
{
None
=>
None
,
Some
(
t
)
=>
{
...
...
@@ -285,7 +272,6 @@ pub fn push_inherent_candidates(&self, self_ty: ty::t) {
* we'll want to find the inherent impls for `C`.
*/
let
mut
enum_dids
=
~
[];
let
mut
self_ty
=
self_ty
;
loop
{
match
get
(
self_ty
)
.sty
{
...
...
@@ -314,7 +300,7 @@ pub fn push_inherent_candidates(&self, self_ty: ty::t) {
// n.b.: Generally speaking, we only loop if we hit the
// fallthrough case in the match above. The exception
// would be newtype enums.
self_ty
=
match
self
.deref
(
self_ty
,
&
mut
enum_dids
)
{
self_ty
=
match
self
.deref
(
self_ty
)
{
None
=>
{
return
;
}
Some
(
ty
)
=>
{
ty
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录