syntax: Add a source field to Local for tracking if it comes from lets or fors.

This commit is contained in:
Huon Wilson 2014-05-26 22:00:08 +10:00
parent 6fad19e16b
commit 6ddd40d436
5 changed files with 17 additions and 2 deletions

View File

@ -417,6 +417,14 @@ pub enum Stmt_ {
StmtMac(Mac, bool), StmtMac(Mac, bool),
} }
/// Where a local declaration came from: either a true `let ... =
/// ...;`, or one desugared from the pattern of a for loop.
#[deriving(Clone, Eq, TotalEq, Encodable, Decodable, Hash)]
pub enum LocalSource {
LocalLet,
LocalFor,
}
// FIXME (pending discussion of #1697, #2178...): local should really be // FIXME (pending discussion of #1697, #2178...): local should really be
// a refinement on pat. // a refinement on pat.
/// Local represents a `let` statement, e.g., `let <pat>:<ty> = <expr>;` /// Local represents a `let` statement, e.g., `let <pat>:<ty> = <expr>;`
@ -427,6 +435,7 @@ pub struct Local {
pub init: Option<@Expr>, pub init: Option<@Expr>,
pub id: NodeId, pub id: NodeId,
pub span: Span, pub span: Span,
pub source: LocalSource,
} }
pub type Decl = Spanned<Decl_>; pub type Decl = Spanned<Decl_>;

View File

@ -439,6 +439,7 @@ impl<'a> AstBuilder for ExtCtxt<'a> {
init: Some(ex), init: Some(ex),
id: ast::DUMMY_NODE_ID, id: ast::DUMMY_NODE_ID,
span: sp, span: sp,
source: ast::LocalLet,
}; };
let decl = respan(sp, ast::DeclLocal(local)); let decl = respan(sp, ast::DeclLocal(local));
@respan(sp, ast::StmtDecl(@decl, ast::DUMMY_NODE_ID)) @respan(sp, ast::StmtDecl(@decl, ast::DUMMY_NODE_ID))
@ -462,6 +463,7 @@ impl<'a> AstBuilder for ExtCtxt<'a> {
init: Some(ex), init: Some(ex),
id: ast::DUMMY_NODE_ID, id: ast::DUMMY_NODE_ID,
span: sp, span: sp,
source: ast::LocalLet,
}; };
let decl = respan(sp, ast::DeclLocal(local)); let decl = respan(sp, ast::DeclLocal(local));
@respan(sp, ast::StmtDecl(@decl, ast::DUMMY_NODE_ID)) @respan(sp, ast::StmtDecl(@decl, ast::DUMMY_NODE_ID))

View File

@ -669,7 +669,8 @@ fn expand_non_macro_stmt(s: &Stmt, fld: &mut MacroExpander)
pat: pat, pat: pat,
init: init, init: init,
id: id, id: id,
span: span span: span,
source: source,
} = **local; } = **local;
// expand the pat (it might contain exprs... #:(o)> // expand the pat (it might contain exprs... #:(o)>
let expanded_pat = fld.fold_pat(pat); let expanded_pat = fld.fold_pat(pat);
@ -703,6 +704,7 @@ fn expand_non_macro_stmt(s: &Stmt, fld: &mut MacroExpander)
init: new_init_opt, init: new_init_opt,
id: id, id: id,
span: span, span: span,
source: source
}; };
SmallVector::one(@Spanned { SmallVector::one(@Spanned {
node: StmtDecl(@Spanned { node: StmtDecl(@Spanned {

View File

@ -288,6 +288,7 @@ pub trait Folder {
pat: self.fold_pat(l.pat), pat: self.fold_pat(l.pat),
init: l.init.map(|e| self.fold_expr(e)), init: l.init.map(|e| self.fold_expr(e)),
span: self.new_span(l.span), span: self.new_span(l.span),
source: l.source,
} }
} }

View File

@ -34,7 +34,7 @@ use ast::{Ident, NormalFn, Inherited, Item, Item_, ItemStatic};
use ast::{ItemEnum, ItemFn, ItemForeignMod, ItemImpl}; use ast::{ItemEnum, ItemFn, ItemForeignMod, ItemImpl};
use ast::{ItemMac, ItemMod, ItemStruct, ItemTrait, ItemTy, Lit, Lit_}; use ast::{ItemMac, ItemMod, ItemStruct, ItemTrait, ItemTy, Lit, Lit_};
use ast::{LitBool, LitFloat, LitFloatUnsuffixed, LitInt, LitChar}; use ast::{LitBool, LitFloat, LitFloatUnsuffixed, LitInt, LitChar};
use ast::{LitIntUnsuffixed, LitNil, LitStr, LitUint, Local}; use ast::{LitIntUnsuffixed, LitNil, LitStr, LitUint, Local, LocalLet};
use ast::{MutImmutable, MutMutable, Mac_, MacInvocTT, Matcher, MatchNonterminal}; use ast::{MutImmutable, MutMutable, Mac_, MacInvocTT, Matcher, MatchNonterminal};
use ast::{MatchSeq, MatchTok, Method, MutTy, BiMul, Mutability}; use ast::{MatchSeq, MatchTok, Method, MutTy, BiMul, Mutability};
use ast::{NamedField, UnNeg, NoReturn, UnNot, P, Pat, PatEnum}; use ast::{NamedField, UnNeg, NoReturn, UnNot, P, Pat, PatEnum};
@ -3034,6 +3034,7 @@ impl<'a> Parser<'a> {
init: init, init: init,
id: ast::DUMMY_NODE_ID, id: ast::DUMMY_NODE_ID,
span: mk_sp(lo, self.last_span.hi), span: mk_sp(lo, self.last_span.hi),
source: LocalLet,
} }
} }