aboutsummaryrefslogtreecommitdiff
path: root/src/comp/front
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2010-11-24 15:45:59 -0800
committerPatrick Walton <[email protected]>2010-11-24 15:45:59 -0800
commitf075b10af2c2a1088d72fff0bff1918a8e74fbf0 (patch)
tree6e65a8ce0c606bcd132aa9e6f7a7efd20dc94bd2 /src/comp/front
parentrustc: Parse simple patterns (diff)
downloadrust-f075b10af2c2a1088d72fff0bff1918a8e74fbf0.tar.xz
rust-f075b10af2c2a1088d72fff0bff1918a8e74fbf0.zip
rustc: Add patterns to fold
Diffstat (limited to 'src/comp/front')
-rw-r--r--src/comp/front/ast.rs10
-rw-r--r--src/comp/front/parser.rs14
2 files changed, 15 insertions, 9 deletions
diff --git a/src/comp/front/ast.rs b/src/comp/front/ast.rs
index 954440dd..cc0f2961 100644
--- a/src/comp/front/ast.rs
+++ b/src/comp/front/ast.rs
@@ -41,13 +41,11 @@ type block_ = rec(vec[@stmt] stmts,
type pat = spanned[pat_];
tag pat_ {
- pat_wild;
- pat_bind(ident);
- pat_tag(ident, vec[@pat]);
+ pat_wild(ann);
+ pat_bind(ident, ann);
+ pat_tag(ident, vec[@pat], ann);
}
-type arm = rec(@pat pat, block block);
-
tag binop {
add;
sub;
@@ -100,6 +98,8 @@ tag decl_ {
decl_item(@item);
}
+type arm = rec(@pat pat, block block);
+
type expr = spanned[expr_];
tag expr_ {
expr_vec(vec[@expr], ann);
diff --git a/src/comp/front/parser.rs b/src/comp/front/parser.rs
index 16c6ed11..a3cc00a0 100644
--- a/src/comp/front/parser.rs
+++ b/src/comp/front/parser.rs
@@ -815,13 +815,19 @@ impure fn parse_initializer(parser p) -> option.t[@ast.expr] {
impure fn parse_pat(parser p) -> @ast.pat {
auto lo = p.get_span();
- auto pat = ast.pat_wild; // FIXME: typestate bug
+ auto pat = ast.pat_wild(ast.ann_none); // FIXME: typestate bug
alt (p.peek()) {
- case (token.UNDERSCORE) { p.bump(); pat = ast.pat_wild; }
+ case (token.UNDERSCORE) {
+ p.bump();
+ pat = ast.pat_wild(ast.ann_none);
+ }
case (token.QUES) {
p.bump();
alt (p.peek()) {
- case (token.IDENT(?id)) { p.bump(); pat = ast.pat_bind(id); }
+ case (token.IDENT(?id)) {
+ p.bump();
+ pat = ast.pat_bind(id, ast.ann_none);
+ }
case (?tok) {
p.err("expected identifier after '?' in pattern but " +
"found " + token.to_str(tok));
@@ -842,7 +848,7 @@ impure fn parse_pat(parser p) -> @ast.pat {
case (_) { args = vec(); }
}
- pat = ast.pat_tag(id, args);
+ pat = ast.pat_tag(id, args, ast.ann_none);
}
case (?tok) {
p.err("expected pattern but found " + token.to_str(tok));