aboutsummaryrefslogtreecommitdiff
path: root/src/comp/middle
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2010-11-24 17:15:54 -0800
committerPatrick Walton <[email protected]>2010-11-24 17:17:42 -0800
commit98e8c2ef21f6aab3dd3d4d328a1c8baf1f074ee4 (patch)
treed787591f3025c242b3dade19d8a1b2297bd243f0 /src/comp/middle
parentSketch out type-directed structural drop and copy, including vector types. (diff)
downloadrust-98e8c2ef21f6aab3dd3d4d328a1c8baf1f074ee4.tar.xz
rust-98e8c2ef21f6aab3dd3d4d328a1c8baf1f074ee4.zip
rustc: Parse type-parametric tags
Diffstat (limited to 'src/comp/middle')
-rw-r--r--src/comp/middle/fold.rs11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/comp/middle/fold.rs b/src/comp/middle/fold.rs
index 2afbc8b9..8a8f65eb 100644
--- a/src/comp/middle/fold.rs
+++ b/src/comp/middle/fold.rs
@@ -170,6 +170,7 @@ type ast_fold[ENV] =
(fn(&ENV e, &span sp, ident ident,
vec[ast.variant] variants,
+ vec[ast.ty_param] ty_params,
def_id id) -> @item) fold_item_tag,
// Additional nodes.
@@ -554,7 +555,7 @@ fn fold_item[ENV](&ENV env, ast_fold[ENV] fld, @item i) -> @item {
ret fld.fold_item_ty(env_, i.span, ident, ty_, id, ann);
}
- case (ast.item_tag(?ident, ?variants, ?id)) {
+ case (ast.item_tag(?ident, ?variants, ?ty_params, ?id)) {
let vec[ast.variant] new_variants = vec();
for (ast.variant v in variants) {
let vec[@ast.ty] new_args = vec();
@@ -563,7 +564,8 @@ fn fold_item[ENV](&ENV env, ast_fold[ENV] fld, @item i) -> @item {
}
new_variants += rec(name=v.name, args=new_args);
}
- ret fld.fold_item_tag(env_, i.span, ident, new_variants, id);
+ ret fld.fold_item_tag(env_, i.span, ident, new_variants,
+ ty_params, id);
}
}
@@ -817,8 +819,9 @@ fn identity_fold_item_ty[ENV](&ENV e, &span sp, ident i,
fn identity_fold_item_tag[ENV](&ENV e, &span sp, ident i,
vec[ast.variant] variants,
+ vec[ast.ty_param] ty_params,
def_id id) -> @item {
- ret @respan(sp, ast.item_tag(i, variants, id));
+ ret @respan(sp, ast.item_tag(i, variants, ty_params, id));
}
@@ -939,7 +942,7 @@ fn new_identity_fold[ENV]() -> ast_fold[ENV] {
fold_item_fn = bind identity_fold_item_fn[ENV](_,_,_,_,_,_,_),
fold_item_mod = bind identity_fold_item_mod[ENV](_,_,_,_,_),
fold_item_ty = bind identity_fold_item_ty[ENV](_,_,_,_,_,_),
- fold_item_tag = bind identity_fold_item_tag[ENV](_,_,_,_,_),
+ fold_item_tag = bind identity_fold_item_tag[ENV](_,_,_,_,_,_),
fold_block = bind identity_fold_block[ENV](_,_,_),
fold_fn = bind identity_fold_fn[ENV](_,_,_,_),