2012-12-04 00:48:01 +00: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 21:46:11 +00:00
|
|
|
/*
|
|
|
|
Predicates on exprs and stmts that the pretty-printer and parser use
|
|
|
|
*/
|
2012-05-22 17:54:12 +00:00
|
|
|
|
2012-12-23 22:41:37 +00:00
|
|
|
use ast;
|
2012-04-18 05:02:00 +00:00
|
|
|
|
2013-04-02 23:44:01 +00: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-09-02 01:45:37 +00:00
|
|
|
pub fn expr_requires_semi_to_be_stmt(e: @ast::Expr) -> bool {
|
2012-08-06 19:34:08 +00:00
|
|
|
match e.node {
|
2013-11-28 20:22:53 +00:00
|
|
|
ast::ExprIf(..)
|
|
|
|
| ast::ExprMatch(..)
|
2013-09-02 01:45:37 +00:00
|
|
|
| ast::ExprBlock(_)
|
2013-11-28 20:22:53 +00:00
|
|
|
| ast::ExprWhile(..)
|
|
|
|
| ast::ExprLoop(..)
|
|
|
|
| ast::ExprForLoop(..)
|
2013-09-02 01:45:37 +00:00
|
|
|
| ast::ExprCall(_, _, ast::DoSugar)
|
|
|
|
| ast::ExprCall(_, _, ast::ForSugar)
|
|
|
|
| ast::ExprMethodCall(_, _, _, _, _, ast::DoSugar)
|
|
|
|
| ast::ExprMethodCall(_, _, _, _, _, ast::ForSugar) => false,
|
2012-08-04 02:59:04 +00:00
|
|
|
_ => true
|
2012-04-18 05:02:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-02 01:45:37 +00:00
|
|
|
pub fn expr_is_simple_block(e: @ast::Expr) -> bool {
|
2012-08-07 00:14:32 +00:00
|
|
|
match e.node {
|
2013-11-30 22:00:39 +00:00
|
|
|
ast::ExprBlock(block) => block.rules == ast::DefaultBlock,
|
2012-08-07 00:14:32 +00:00
|
|
|
_ => false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-02 23:44:01 +00: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-09-02 01:45:37 +00:00
|
|
|
pub fn stmt_ends_with_semi(stmt: &ast::Stmt) -> bool {
|
2012-11-13 04:06:55 +00:00
|
|
|
return match stmt.node {
|
2013-09-02 01:45:37 +00:00
|
|
|
ast::StmtDecl(d, _) => {
|
2012-11-13 04:06:55 +00:00
|
|
|
match d.node {
|
2013-09-02 01:45:37 +00:00
|
|
|
ast::DeclLocal(_) => true,
|
|
|
|
ast::DeclItem(_) => false
|
2012-04-18 05:02:00 +00:00
|
|
|
}
|
2012-11-13 04:06:55 +00:00
|
|
|
}
|
2013-09-02 01:45:37 +00:00
|
|
|
ast::StmtExpr(e, _) => { expr_requires_semi_to_be_stmt(e) }
|
2013-11-28 20:22:53 +00:00
|
|
|
ast::StmtSemi(..) => { false }
|
|
|
|
ast::StmtMac(..) => { false }
|
2012-04-18 05:02:00 +00:00
|
|
|
}
|
|
|
|
}
|