Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Rust
提交
5254ccc7
R
Rust
项目概览
int
/
Rust
12 个月 前同步成功
通知
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,发现更多精彩内容 >>
提交
5254ccc7
编写于
9月 29, 2014
作者:
J
Jakub Wieczorek
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update after the fall out from the syntax::ptr changes
上级
e53f4a6b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
38 addition
and
32 deletion
+38
-32
src/librustc/middle/check_match.rs
src/librustc/middle/check_match.rs
+2
-2
src/libsyntax/ext/expand.rs
src/libsyntax/ext/expand.rs
+36
-30
未找到文件。
src/librustc/middle/check_match.rs
浏览文件 @
5254ccc7
...
...
@@ -267,8 +267,8 @@ fn check_arms(cx: &MatchCheckCtxt, arms: &[(Vec<P<Pat>>, Option<&Expr>)], source
// We don't want two, that's just confusing.
}
else
{
// find the first arm pattern so we can use its span
let
&
(
ref
first_arm_pats
,
_
)
=
&
arms
[
0
];
// we know there's at least 1 arm
let
first_pat
=
first_arm_pats
.get
(
0
);
// and it's safe to assume 1 pat
let
&
(
ref
first_arm_pats
,
_
)
=
&
arms
[
0
];
let
first_pat
=
first_arm_pats
.get
(
0
);
let
span
=
first_pat
.span
;
span_err!
(
cx
.tcx.sess
,
span
,
E0162
,
"irrefutable if-let pattern"
);
printed_if_let_err
=
true
;
...
...
src/libsyntax/ext/expand.rs
浏览文件 @
5254ccc7
...
...
@@ -70,8 +70,6 @@ pub fn expand_expr(e: P<ast::Expr>, fld: &mut MacroExpander) -> P<ast::Expr> {
// Desugar ExprIfLet
// From: `if let <pat> = <expr> <body> [<elseopt>]`
ast
::
ExprIfLet
(
pat
,
expr
,
body
,
mut
elseopt
)
=>
{
let
span
=
e
.span
;
// to:
//
// match <expr> {
...
...
@@ -90,23 +88,33 @@ pub fn expand_expr(e: P<ast::Expr>, fld: &mut MacroExpander) -> P<ast::Expr> {
let
else_if_arms
=
{
let
mut
arms
=
vec!
[];
loop
{
// NOTE: replace with 'if let' after snapshot
match
elseopt
{
Some
(
els
)
=>
match
els
.node
{
// else if
ast
::
ExprIf
(
cond
,
then
,
elseopt_
)
=>
{
let
pat_under
=
fld
.cx
.pat_wild
(
span
);
elseopt
=
elseopt_
;
arms
.push
(
ast
::
Arm
{
attrs
:
vec!
[],
pats
:
vec!
[
pat_under
],
guard
:
Some
(
cond
),
body
:
fld
.cx
.expr_block
(
then
)
});
}
_
=>
break
},
None
=>
break
let
elseopt_continue
=
elseopt
.and_then
(|
els
|
els
.and_then
(|
els
|
match
els
.node
{
// else if
ast
::
ExprIf
(
cond
,
then
,
elseopt
)
=>
{
let
pat_under
=
fld
.cx
.pat_wild
(
span
);
arms
.push
(
ast
::
Arm
{
attrs
:
vec!
[],
pats
:
vec!
[
pat_under
],
guard
:
Some
(
cond
),
body
:
fld
.cx
.expr_block
(
then
)
});
elseopt
.map
(|
elseopt
|
(
elseopt
,
true
))
}
_
=>
Some
((
P
(
els
),
false
))
}));
match
elseopt_continue
{
Some
((
e
,
true
))
=>
{
elseopt
=
Some
(
e
);
}
Some
((
e
,
false
))
=>
{
elseopt
=
Some
(
e
);
break
;
}
None
=>
{
elseopt
=
None
;
break
;
}
}
}
arms
...
...
@@ -115,10 +123,7 @@ pub fn expand_expr(e: P<ast::Expr>, fld: &mut MacroExpander) -> P<ast::Expr> {
// `_ => [<elseopt> | ()]`
let
else_arm
=
{
let
pat_under
=
fld
.cx
.pat_wild
(
span
);
let
else_expr
=
match
elseopt
{
Some
(
els
)
=>
els
,
None
=>
fld
.cx
.expr_lit
(
span
,
ast
::
LitNil
)
};
let
else_expr
=
elseopt
.unwrap_or_else
(||
fld
.cx
.expr_lit
(
span
,
ast
::
LitNil
));
fld
.cx
.arm
(
span
,
vec!
[
pat_under
],
else_expr
)
};
...
...
@@ -133,23 +138,24 @@ pub fn expand_expr(e: P<ast::Expr>, fld: &mut MacroExpander) -> P<ast::Expr> {
// Desugar support for ExprIfLet in the ExprIf else position
ast
::
ExprIf
(
cond
,
blk
,
elseopt
)
=>
{
let
elseopt
=
elseopt
.map
(|
els
|
match
els
.node
{
let
elseopt
=
elseopt
.map
(|
els
|
els
.and_then
(|
els
|
match
els
.node
{
ast
::
ExprIfLet
(
..
)
=>
{
// wrap the if-let expr in a block
let
span
=
els
.span
;
let
blk
=
P
(
ast
::
Block
{
view_items
:
vec!
[],
stmts
:
vec!
[],
expr
:
Some
(
els
),
expr
:
Some
(
P
(
els
)
),
id
:
ast
::
DUMMY_NODE_ID
,
rules
:
ast
::
DefaultBlock
,
span
:
els
.
span
span
:
span
});
fld
.cx
.expr_block
(
blk
)
}
_
=>
els
});
let
if_expr
=
fld
.cx
.expr
(
e
.
span
,
ast
::
ExprIf
(
cond
,
blk
,
elseopt
));
noop_fold_expr
(
if_expr
,
fld
)
_
=>
P
(
els
)
})
)
;
let
if_expr
=
fld
.cx
.expr
(
span
,
ast
::
ExprIf
(
cond
,
blk
,
elseopt
));
if_expr
.map
(|
e
|
noop_fold_expr
(
e
,
fld
)
)
}
ast
::
ExprLoop
(
loop_block
,
opt_ident
)
=>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录