Skip to content

Commit cb1752d

Browse files
committed
---
yaml --- r: 954 b: refs/heads/master c: 98e8c2e h: refs/heads/master v: v3
1 parent 956413c commit cb1752d

File tree

4 files changed

+22
-14
lines changed

4 files changed

+22
-14
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,2 @@
11
---
2-
refs/heads/master: f809375b163bb108d9193f456f44ca663874380b
2+
refs/heads/master: 98e8c2ef21f6aab3dd3d4d328a1c8baf1f074ee4

trunk/src/comp/front/ast.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -171,7 +171,7 @@ tag item_ {
171171
item_fn(ident, _fn, vec[ty_param], def_id, ann);
172172
item_mod(ident, _mod, def_id);
173173
item_ty(ident, @ty, def_id, ann);
174-
item_tag(ident, vec[variant], def_id);
174+
item_tag(ident, vec[variant], vec[ty_param], def_id);
175175
}
176176

177177

trunk/src/comp/front/parser.rs

Lines changed: 13 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1039,17 +1039,21 @@ impure fn parse_block(parser p) -> ast.block {
10391039
ret spanned(stmts.span, stmts.span, b);
10401040
}
10411041

1042-
impure fn parse_item_fn(parser p) -> tup(ast.ident, @ast.item) {
1043-
auto lo = p.get_span();
1044-
expect(p, token.FN);
1045-
auto id = parse_ident(p);
1046-
1042+
impure fn parse_ty_params(parser p) -> vec[ast.ty_param] {
10471043
let vec[ast.ty_param] ty_params = vec();
10481044
if (p.peek() == token.LBRACKET) {
1049-
auto pg = parse_ident; // FIXME: pass as lval directly
1045+
auto f = parse_ident; // FIXME: pass as lval directly
10501046
ty_params = parse_seq[ast.ty_param](token.LBRACKET, token.RBRACKET,
1051-
some(token.COMMA), pg, p).node;
1047+
some(token.COMMA), f, p).node;
10521048
}
1049+
ret ty_params;
1050+
}
1051+
1052+
impure fn parse_item_fn(parser p) -> tup(ast.ident, @ast.item) {
1053+
auto lo = p.get_span();
1054+
expect(p, token.FN);
1055+
auto id = parse_ident(p);
1056+
auto ty_params = parse_ty_params(p);
10531057

10541058
auto pf = parse_arg;
10551059
let util.common.spanned[vec[ast.arg]] inputs =
@@ -1120,6 +1124,7 @@ impure fn parse_item_tag(parser p) -> tup(ast.ident, @ast.item) {
11201124
auto lo = p.get_span();
11211125
expect(p, token.TAG);
11221126
auto id = parse_ident(p);
1127+
auto ty_params = parse_ty_params(p);
11231128

11241129
let vec[ast.variant] variants = vec();
11251130
expect(p, token.LBRACE);
@@ -1158,7 +1163,7 @@ impure fn parse_item_tag(parser p) -> tup(ast.ident, @ast.item) {
11581163
p.bump();
11591164

11601165
auto hi = p.get_span();
1161-
auto item = ast.item_tag(id, variants, p.next_def_id());
1166+
auto item = ast.item_tag(id, variants, ty_params, p.next_def_id());
11621167
ret tup(id, @spanned(lo, hi, item));
11631168
}
11641169

trunk/src/comp/middle/fold.rs

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -170,6 +170,7 @@ type ast_fold[ENV] =
170170

171171
(fn(&ENV e, &span sp, ident ident,
172172
vec[ast.variant] variants,
173+
vec[ast.ty_param] ty_params,
173174
def_id id) -> @item) fold_item_tag,
174175

175176
// Additional nodes.
@@ -554,7 +555,7 @@ fn fold_item[ENV](&ENV env, ast_fold[ENV] fld, @item i) -> @item {
554555
ret fld.fold_item_ty(env_, i.span, ident, ty_, id, ann);
555556
}
556557

557-
case (ast.item_tag(?ident, ?variants, ?id)) {
558+
case (ast.item_tag(?ident, ?variants, ?ty_params, ?id)) {
558559
let vec[ast.variant] new_variants = vec();
559560
for (ast.variant v in variants) {
560561
let vec[@ast.ty] new_args = vec();
@@ -563,7 +564,8 @@ fn fold_item[ENV](&ENV env, ast_fold[ENV] fld, @item i) -> @item {
563564
}
564565
new_variants += rec(name=v.name, args=new_args);
565566
}
566-
ret fld.fold_item_tag(env_, i.span, ident, new_variants, id);
567+
ret fld.fold_item_tag(env_, i.span, ident, new_variants,
568+
ty_params, id);
567569
}
568570
}
569571

@@ -817,8 +819,9 @@ fn identity_fold_item_ty[ENV](&ENV e, &span sp, ident i,
817819

818820
fn identity_fold_item_tag[ENV](&ENV e, &span sp, ident i,
819821
vec[ast.variant] variants,
822+
vec[ast.ty_param] ty_params,
820823
def_id id) -> @item {
821-
ret @respan(sp, ast.item_tag(i, variants, id));
824+
ret @respan(sp, ast.item_tag(i, variants, ty_params, id));
822825
}
823826

824827

@@ -939,7 +942,7 @@ fn new_identity_fold[ENV]() -> ast_fold[ENV] {
939942
fold_item_fn = bind identity_fold_item_fn[ENV](_,_,_,_,_,_,_),
940943
fold_item_mod = bind identity_fold_item_mod[ENV](_,_,_,_,_),
941944
fold_item_ty = bind identity_fold_item_ty[ENV](_,_,_,_,_,_),
942-
fold_item_tag = bind identity_fold_item_tag[ENV](_,_,_,_,_),
945+
fold_item_tag = bind identity_fold_item_tag[ENV](_,_,_,_,_,_),
943946

944947
fold_block = bind identity_fold_block[ENV](_,_,_),
945948
fold_fn = bind identity_fold_fn[ENV](_,_,_,_),

0 commit comments

Comments
 (0)