2012-12-03 16:48:01 -08: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.
|
|
|
|
|
|
2014-04-27 22:05:41 -04:00
|
|
|
//! Routines the parser uses to classify AST nodes
|
|
|
|
|
|
|
|
|
|
// Predicates on exprs and stmts that the pretty-printer and parser use
|
2012-05-22 10:54:12 -07:00
|
|
|
|
2016-02-08 12:44:45 +01:00
|
|
|
use ast::{self, BlockCheckMode};
|
2012-04-17 22:02:00 -07:00
|
|
|
|
2014-06-09 13:12:30 -07: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
|
2014-09-13 19:06:01 +03:00
|
|
|
pub fn expr_requires_semi_to_be_stmt(e: &ast::Expr) -> bool {
|
2012-08-06 12:34:08 -07:00
|
|
|
match e.node {
|
2016-02-08 16:05:05 +01:00
|
|
|
ast::ExprKind::If(..) |
|
|
|
|
|
ast::ExprKind::IfLet(..) |
|
|
|
|
|
ast::ExprKind::Match(..) |
|
|
|
|
|
ast::ExprKind::Block(_) |
|
|
|
|
|
ast::ExprKind::While(..) |
|
|
|
|
|
ast::ExprKind::WhileLet(..) |
|
|
|
|
|
ast::ExprKind::Loop(..) |
|
|
|
|
|
ast::ExprKind::ForLoop(..) => false,
|
2016-01-27 21:42:26 +02:00
|
|
|
_ => true,
|
2012-04-17 22:02:00 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-09-13 19:06:01 +03:00
|
|
|
pub fn expr_is_simple_block(e: &ast::Expr) -> bool {
|
2012-08-06 17:14:32 -07:00
|
|
|
match e.node {
|
2016-02-08 16:05:05 +01:00
|
|
|
ast::ExprKind::Block(ref block) => block.rules == BlockCheckMode::Default,
|
2016-01-27 21:42:26 +02:00
|
|
|
_ => false,
|
2012-08-06 17:14:32 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-09 13:12:30 -07: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.
|
2014-09-13 19:06:01 +03:00
|
|
|
pub fn stmt_ends_with_semi(stmt: &ast::Stmt_) -> bool {
|
|
|
|
|
match *stmt {
|
|
|
|
|
ast::StmtDecl(ref d, _) => {
|
2012-11-12 23:06:55 -05:00
|
|
|
match d.node {
|
2016-02-08 15:34:47 +01:00
|
|
|
ast::DeclKind::Local(_) => true,
|
|
|
|
|
ast::DeclKind::Item(_) => false,
|
2012-04-17 22:02:00 -07:00
|
|
|
}
|
2012-11-12 23:06:55 -05:00
|
|
|
}
|
2016-01-27 21:42:26 +02:00
|
|
|
ast::StmtExpr(ref e, _) => expr_requires_semi_to_be_stmt(e),
|
|
|
|
|
ast::StmtSemi(..) => false,
|
|
|
|
|
ast::StmtMac(..) => false,
|
2012-04-17 22:02:00 -07:00
|
|
|
}
|
|
|
|
|
}
|