From d7e881841438cfe0797b71ff35ea96c8f2477a76 Mon Sep 17 00:00:00 2001 From: Tim Chevalier Date: Tue, 12 Apr 2011 12:16:21 -0700 Subject: Further work on typestate. Handles expr_rec and expr_assign now. Also changed the ts_ann field on statements to be an ann instead, which explains most of the changes. As well, got rid of the "warning: no type for expression" error by filling in annotations for local decls in typeck (not sure whether this was my fault or not). Finally, in bitv, added a clone() function to copy a bit vector, and fixed is_true, is_false, and to_str to not be nonsense. --- src/comp/front/parser.rs | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) (limited to 'src/comp/front/parser.rs') diff --git a/src/comp/front/parser.rs b/src/comp/front/parser.rs index 617f1813..94104655 100644 --- a/src/comp/front/parser.rs +++ b/src/comp/front/parser.rs @@ -11,7 +11,7 @@ import util.common; import util.common.filename; import util.common.span; import util.common.new_str_hash; -import util.typestate_ann.ts_ann; +import util.common.plain_ann; tag restriction { UNRESTRICTED; @@ -1562,14 +1562,15 @@ impure fn parse_source_stmt(parser p) -> @ast.stmt { case (token.LET) { auto decl = parse_let(p); - ret @spanned(lo, decl.span.hi, - ast.stmt_decl(decl, none[@ts_ann])); + auto hi = p.get_span(); + ret @spanned + (lo, decl.span.hi, ast.stmt_decl(decl, plain_ann())); } case (token.AUTO) { auto decl = parse_auto(p); - ret @spanned(lo, decl.span.hi, - ast.stmt_decl(decl, none[@ts_ann])); + auto hi = p.get_span(); + ret @spanned(lo, decl.span.hi, ast.stmt_decl(decl, plain_ann())); } case (_) { @@ -1578,12 +1579,13 @@ impure fn parse_source_stmt(parser p) -> @ast.stmt { auto i = parse_item(p); auto hi = i.span.hi; auto decl = @spanned(lo, hi, ast.decl_item(i)); - ret @spanned(lo, hi, ast.stmt_decl(decl, none[@ts_ann])); + ret @spanned(lo, hi, ast.stmt_decl(decl, plain_ann())); } else { // Remainder are line-expr stmts. auto e = parse_expr(p); - ret @spanned(lo, e.span.hi, ast.stmt_expr(e, none[@ts_ann])); + auto hi = p.get_span(); + ret @spanned(lo, e.span.hi, ast.stmt_expr(e, plain_ann())); } } } -- cgit v1.2.3