aboutsummaryrefslogtreecommitdiff
path: root/src/comp/front/parser.rs
diff options
context:
space:
mode:
authorRafael Ávila de Espíndola <[email protected]>2011-02-25 12:08:21 -0500
committerRafael Ávila de Espíndola <[email protected]>2011-02-25 12:08:21 -0500
commitf8f6f078c505dd0f20526e3ad86c360605fce109 (patch)
treed333e5b301e72337ac23e290ae98717b0ece568e /src/comp/front/parser.rs
parentDisable test that is failing on valgrind. (diff)
downloadrust-f8f6f078c505dd0f20526e3ad86c360605fce109.tar.xz
rust-f8f6f078c505dd0f20526e3ad86c360605fce109.zip
There are no native iterators (or at least they are not going to be supported
soon.).
Diffstat (limited to 'src/comp/front/parser.rs')
-rw-r--r--src/comp/front/parser.rs31
1 files changed, 16 insertions, 15 deletions
diff --git a/src/comp/front/parser.rs b/src/comp/front/parser.rs
index 67b9cc80..7bd34fdf 100644
--- a/src/comp/front/parser.rs
+++ b/src/comp/front/parser.rs
@@ -1617,8 +1617,7 @@ impure fn parse_ty_params(parser p) -> vec[ast.ty_param] {
ret ty_params;
}
-impure fn parse_fn_decl(parser p, ast.proto proto,
- ast.effect eff) -> ast.fn_decl {
+impure fn parse_fn_decl(parser p, ast.effect eff) -> ast.fn_decl {
auto pf = parse_arg;
let util.common.spanned[vec[ast.arg]] inputs =
// FIXME: passing parse_arg as an lval doesn't work at the
@@ -1636,32 +1635,32 @@ impure fn parse_fn_decl(parser p, ast.proto proto,
} else {
output = @spanned(inputs.span, inputs.span, ast.ty_nil);
}
- ret rec(effect=eff, proto=proto,
- inputs=inputs.node, output=output);
+ ret rec(effect=eff, inputs=inputs.node, output=output);
}
impure fn parse_fn(parser p, ast.effect eff, ast.proto proto) -> ast._fn {
- auto decl = parse_fn_decl(p, proto, eff);
+ auto decl = parse_fn_decl(p, eff);
auto body = parse_block(p);
ret rec(decl = decl,
+ proto = proto,
body = body);
}
impure fn parse_fn_header(parser p)
- -> tup(span, ast.proto, ast.ident, vec[ast.ty_param]) {
- auto lo = p.get_span();
- auto proto = parse_proto(p);
+ -> tup(ast.ident, vec[ast.ty_param]) {
auto id = parse_ident(p);
auto ty_params = parse_ty_params(p);
- ret tup(lo, proto, id, ty_params);
+ ret tup(id, ty_params);
}
impure fn parse_item_fn_or_iter(parser p, ast.effect eff) -> @ast.item {
+ auto lo = p.get_span();
+ auto proto = parse_proto(p);
auto t = parse_fn_header(p);
- auto f = parse_fn(p, eff, t._1);
- auto item = ast.item_fn(t._2, f, t._3,
+ auto f = parse_fn(p, eff, proto);
+ auto item = ast.item_fn(t._0, f, t._1,
p.next_def_id(), ast.ann_none);
- ret @spanned(t._0, f.body.span, item);
+ ret @spanned(lo, f.body.span, item);
}
@@ -1760,13 +1759,15 @@ impure fn parse_item_native_type(parser p) -> @ast.native_item {
}
impure fn parse_item_native_fn(parser p, ast.effect eff) -> @ast.native_item {
+ auto lo = p.get_span();
+ expect(p, token.FN);
auto t = parse_fn_header(p);
- auto decl = parse_fn_decl(p, t._1, eff);
+ auto decl = parse_fn_decl(p, eff);
auto hi = p.get_span();
expect(p, token.SEMI);
- auto item = ast.native_item_fn(t._2, decl, t._3, p.next_def_id(),
+ auto item = ast.native_item_fn(t._0, decl, t._1, p.next_def_id(),
ast.ann_none);
- ret @spanned(t._0, hi, item);
+ ret @spanned(lo, hi, item);
}
impure fn parse_native_item(parser p) -> @ast.native_item {