2012-12-03 18:48:01 -06:00
|
|
|
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2012-04-19 16:46:11 -05:00
|
|
|
/*
|
|
|
|
Predicates on exprs and stmts that the pretty-printer and parser use
|
|
|
|
*/
|
2012-05-22 12:54:12 -05:00
|
|
|
|
2012-12-23 16:41:37 -06:00
|
|
|
use ast;
|
2013-01-30 11:56:33 -06:00
|
|
|
use codemap;
|
2012-04-18 00:02:00 -05:00
|
|
|
|
2013-04-02 18:44:01 -05:00
|
|
|
// does this expression require a semicolon to be treated
|
|
|
|
// as a statement? The negation of this: 'can this expression
|
|
|
|
// be used as a statement without a semicolon' -- is used
|
|
|
|
// as an early-bail-out in the parser so that, for instance,
|
|
|
|
// 'if true {...} else {...}
|
|
|
|
// |x| 5 '
|
|
|
|
// isn't parsed as (if true {...} else {...} | x) | 5
|
2013-01-29 15:54:06 -06:00
|
|
|
pub fn expr_requires_semi_to_be_stmt(e: @ast::expr) -> bool {
|
2012-08-06 14:34:08 -05:00
|
|
|
match e.node {
|
2012-11-30 13:18:25 -06:00
|
|
|
ast::expr_if(*)
|
|
|
|
| ast::expr_match(*)
|
|
|
|
| ast::expr_block(_)
|
|
|
|
| ast::expr_while(*)
|
|
|
|
| ast::expr_loop(*)
|
2013-01-31 19:12:29 -06:00
|
|
|
| ast::expr_call(_, _, ast::DoSugar)
|
|
|
|
| ast::expr_call(_, _, ast::ForSugar)
|
|
|
|
| ast::expr_method_call(_, _, _, _, ast::DoSugar)
|
|
|
|
| ast::expr_method_call(_, _, _, _, ast::ForSugar) => false,
|
2012-08-03 21:59:04 -05:00
|
|
|
_ => true
|
2012-04-18 00:02:00 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-29 15:54:06 -06:00
|
|
|
pub fn expr_is_simple_block(e: @ast::expr) -> bool {
|
2012-08-06 19:14:32 -05:00
|
|
|
match e.node {
|
2013-01-14 21:35:08 -06:00
|
|
|
ast::expr_block(
|
2013-01-30 11:56:33 -06:00
|
|
|
codemap::spanned {
|
|
|
|
node: ast::blk_ { rules: ast::default_blk, _ }, _ }
|
2013-01-14 21:35:08 -06:00
|
|
|
) => true,
|
2012-08-06 19:14:32 -05:00
|
|
|
_ => false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-02 18:44:01 -05:00
|
|
|
// this statement requires a semicolon after it.
|
|
|
|
// note that in one case (stmt_semi), we've already
|
|
|
|
// seen the semicolon, and thus don't need another.
|
2013-04-17 11:15:08 -05:00
|
|
|
pub fn stmt_ends_with_semi(stmt: &ast::stmt) -> bool {
|
2012-11-12 22:06:55 -06:00
|
|
|
return match stmt.node {
|
|
|
|
ast::stmt_decl(d, _) => {
|
|
|
|
match d.node {
|
|
|
|
ast::decl_local(_) => true,
|
|
|
|
ast::decl_item(_) => false
|
2012-04-18 00:02:00 -05:00
|
|
|
}
|
2012-11-12 22:06:55 -06:00
|
|
|
}
|
|
|
|
ast::stmt_expr(e, _) => { expr_requires_semi_to_be_stmt(e) }
|
|
|
|
ast::stmt_semi(*) => { false }
|
|
|
|
ast::stmt_mac(*) => { false }
|
2012-04-18 00:02:00 -05:00
|
|
|
}
|
|
|
|
}
|