about summary refs log tree commit diff
path: root/src/comp
diff options
context:
space:
mode:
authorPatrick Walton <pcwalton@mimiga.net>2011-05-13 14:38:05 -0700
committerPatrick Walton <pcwalton@mimiga.net>2011-05-13 14:39:00 -0700
commite888fe6f9b8ed0c47df2ed17e50c2d391c1dc647 (patch)
tree7c517d4618d7f541a1076c7a4a9e7b372bf38707 /src/comp
parent2f440b1452f79a670d2927abd42f95b79272c5d9 (diff)
downloadrust-e888fe6f9b8ed0c47df2ed17e50c2d391c1dc647.tar.gz
rust-e888fe6f9b8ed0c47df2ed17e50c2d391c1dc647.zip
rustc: Change ty::triv_ann() to take a node ID instead of a full annotation
Diffstat (limited to 'src/comp')
-rw-r--r--src/comp/middle/ty.rs4
-rw-r--r--src/comp/middle/typeck.rs199
2 files changed, 118 insertions, 85 deletions
diff --git a/src/comp/middle/ty.rs b/src/comp/middle/ty.rs
index b3d9977e103..5957c1fdf36 100644
--- a/src/comp/middle/ty.rs
+++ b/src/comp/middle/ty.rs
@@ -1504,8 +1504,8 @@ fn ann_to_monotype(ctxt cx,  &node_type_table ntt, ast::ann a) -> t {
 }
 
 // Turns a type into an ann_type, using defaults for other fields.
-fn triv_ann(&ast::ann old, t typ) -> ast::ann {
-    ret ast::ann_type(ast::ann_tag(old), typ, none[vec[t]], none[@ts_ann]);
+fn triv_ann(uint node_id, t typ) -> ast::ann {
+    ret ast::ann_type(node_id, typ, none[vec[t]], none[@ts_ann]);
 }
 
 // Returns the number of distinct type parameters in the given type.
diff --git a/src/comp/middle/typeck.rs b/src/comp/middle/typeck.rs
index 3e0ed783ba4..024d2c67cb4 100644
--- a/src/comp/middle/typeck.rs
+++ b/src/comp/middle/typeck.rs
@@ -635,8 +635,9 @@ mod Collect {
 
             auto tpt = tup(ty_param_count, result_ty);
             cx.type_cache.insert(variant.node.id, tpt);
-            auto variant_t = rec(ann=triv_ann(variant.node.ann, result_ty)
-                                 with variant.node
+            auto variant_t = rec(
+                ann=triv_ann(ast::ann_tag(variant.node.ann), result_ty)
+                with variant.node
             );
             result += vec(fold::respan(variant.span, variant_t));
         }
@@ -705,7 +706,8 @@ mod Collect {
                        &ast::def_id id, &ast::ann a) -> @ast::item {
         // assert (e.cx.type_cache.contains_key(id));
         auto typ = e.cx.type_cache.get(id)._1;
-        auto item = ast::item_const(i, t, ex, id, triv_ann(a, typ));
+        auto item = ast::item_const(i, t, ex, id,
+                                    triv_ann(ast::ann_tag(a), typ));
         ret @fold::respan[ast::item_](sp, item);
     }
 
@@ -714,7 +716,8 @@ mod Collect {
                     &ast::def_id id, &ast::ann a) -> @ast::item {
         // assert (e.cx.type_cache.contains_key(id));
         auto typ = e.cx.type_cache.get(id)._1;
-        auto item = ast::item_fn(i, f, ty_params, id, triv_ann(a, typ));
+        auto item = ast::item_fn(i, f, ty_params, id,
+                                 triv_ann(ast::ann_tag(a), typ));
         ret @fold::respan[ast::item_](sp, item);
     }
 
@@ -725,7 +728,7 @@ mod Collect {
         // assert (e.cx.type_cache.contains_key(id));
         auto typ = e.cx.type_cache.get(id)._1;
         auto item = ast::native_item_fn(i, ln, d, ty_params, id,
-                                       triv_ann(a, typ));
+                                       triv_ann(ast::ann_tag(a), typ));
         ret @fold::respan[ast::native_item_](sp, item);
     }
 
@@ -770,7 +773,7 @@ mod Collect {
                                      meth_ty.proto,
                                      meth_ty.inputs,
                                      meth_ty.output);
-            m_ = rec(ann=triv_ann(meth.node.ann, meth_tfn)
+            m_ = rec(ann=triv_ann(ast::ann_tag(meth.node.ann), meth_tfn)
                      with meth.node
             );
             m = @rec(node=m_ with *meth);
@@ -779,9 +782,8 @@ mod Collect {
         auto g = bind getter(e.cx, _);
         for (ast::obj_field fld in ob.fields) {
             let ty::t fty = ast_ty_to_ty(e.cx.tcx, g, fld.ty);
-            let ast::obj_field f = rec(ann=triv_ann(fld.ann, fty)
-                                      with fld
-            );
+            let ast::obj_field f =
+                rec(ann=triv_ann(ast::ann_tag(fld.ann), fty) with fld);
             _vec::push[ast::obj_field](fields, f);
         }
 
@@ -792,7 +794,10 @@ mod Collect {
                 let ty::t output = ty::mk_nil(e.cx.tcx);
                 auto dtor_tfn = ty::mk_fn(e.cx.tcx, ast::proto_fn, inputs,
                                          output);
-                auto d_ = rec(ann=triv_ann(d.node.ann, dtor_tfn) with d.node);
+                auto d_ = rec(
+                    ann=triv_ann(ast::ann_tag(d.node.ann), dtor_tfn)
+                    with d.node
+                );
                 dtor = some[@ast::method](@rec(node=d_ with *d));
             }
             case (none[@ast::method]) { }
@@ -802,7 +807,8 @@ mod Collect {
                        fields = fields,
                        dtor = dtor
                        with ob);
-        auto item = ast::item_obj(i, ob_, ty_params, odid, triv_ann(a, t));
+        auto item = ast::item_obj(i, ob_, ty_params, odid,
+                                  triv_ann(ast::ann_tag(a), t));
         ret @fold::respan[ast::item_](sp, item);
     }
 
@@ -811,7 +817,8 @@ mod Collect {
                     &ast::def_id id, &ast::ann a) -> @ast::item {
         // assert (e.cx.type_cache.contains_key(id));
         auto typ = e.cx.type_cache.get(id)._1;
-        auto item = ast::item_ty(i, t, ty_params, id, triv_ann(a, typ));
+        auto item = ast::item_ty(i, t, ty_params, id,
+                                 triv_ann(ast::ann_tag(a), typ));
         ret @fold::respan[ast::item_](sp, item);
     }
 
@@ -1240,7 +1247,8 @@ mod Pushdown {
                         fail;
                     }
                 }
-                e_1 = ast::expr_vec(es_1, mut, triv_ann(ann, t));
+                e_1 = ast::expr_vec(es_1, mut,
+                                    triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_tup(?es_0, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
@@ -1261,7 +1269,7 @@ mod Pushdown {
                         fail;
                     }
                 }
-                e_1 = ast::expr_tup(elts_1, triv_ann(ann, t));
+                e_1 = ast::expr_tup(elts_1, triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_rec(?fields_0, ?base_0, ?ann)) {
 
@@ -1318,12 +1326,14 @@ mod Pushdown {
                         fail;
                     }
                 }
-                e_1 = ast::expr_rec(fields_1, base_1, triv_ann(ann, t));
+                e_1 = ast::expr_rec(fields_1, base_1,
+                                    triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_bind(?sube, ?es, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                         ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_bind(sube, es, triv_ann(ann, t));
+                e_1 = ast::expr_bind(sube, es,
+                                     triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_call(?sube, ?es, ?ann)) {
                 // NB: we call 'Demand::autoderef' and pass in adk only in
@@ -1332,34 +1342,39 @@ mod Pushdown {
                 // so there's no need.
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
-                e_1 = ast::expr_call(sube, es, triv_ann(ann, t));
+                e_1 = ast::expr_call(sube, es,
+                                     triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_self_method(?id, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_self_method(id, triv_ann(ann, t));
+                e_1 = ast::expr_self_method(id,
+                                            triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_binary(?bop, ?lhs, ?rhs, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_binary(bop, lhs, rhs, triv_ann(ann, t));
+                e_1 = ast::expr_binary(bop, lhs, rhs,
+                                       triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_unary(?uop, ?sube, ?ann)) {
                 // See note in expr_unary for why we're calling
                 // Demand::autoderef.
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
-                e_1 = ast::expr_unary(uop, sube, triv_ann(ann, t));
+                e_1 = ast::expr_unary(uop, sube,
+                                      triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_lit(?lit, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                         ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_lit(lit, triv_ann(ann, t));
+                e_1 = ast::expr_lit(lit, triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_cast(?sube, ?ast_ty, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                         ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_cast(sube, ast_ty, triv_ann(ann, t));
+                e_1 = ast::expr_cast(sube, ast_ty,
+                                     triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_if(?cond, ?then_0, ?else_0, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
@@ -1374,56 +1389,65 @@ mod Pushdown {
                         else_1 = some[@ast::expr](e_1);
                     }
                 }
-                e_1 = ast::expr_if(cond, then_1, else_1, triv_ann(ann, t));
+                e_1 = ast::expr_if(cond, then_1, else_1,
+                                   triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_for(?decl, ?seq, ?bloc, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_for(decl, seq, bloc, triv_ann(ann, t));
+                e_1 = ast::expr_for(decl, seq, bloc,
+                                    triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_for_each(?decl, ?seq, ?bloc, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_for_each(decl, seq, bloc, triv_ann(ann, t));
+                e_1 = ast::expr_for_each(decl, seq, bloc,
+                                         triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_while(?cond, ?bloc, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_while(cond, bloc, triv_ann(ann, t));
+                e_1 = ast::expr_while(cond, bloc,
+                                      triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_do_while(?bloc, ?cond, ?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                        ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_do_while(bloc, cond, triv_ann(ann, t));
+                e_1 = ast::expr_do_while(bloc, cond,
+                                         triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_block(?bloc, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
-                e_1 = ast::expr_block(bloc, triv_ann(ann, t));
+                e_1 = ast::expr_block(bloc, triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_assign(?lhs_0, ?rhs_0, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
                 auto lhs_1 = pushdown_expr(fcx, expected, lhs_0);
                 auto rhs_1 = pushdown_expr(fcx, expected, rhs_0);
-                e_1 = ast::expr_assign(lhs_1, rhs_1, triv_ann(ann, t));
+                e_1 = ast::expr_assign(lhs_1, rhs_1,
+                                       triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_assign_op(?op, ?lhs_0, ?rhs_0, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
                 auto lhs_1 = pushdown_expr(fcx, expected, lhs_0);
                 auto rhs_1 = pushdown_expr(fcx, expected, rhs_0);
-                e_1 = ast::expr_assign_op(op, lhs_1, rhs_1, triv_ann(ann, t));
+                e_1 = ast::expr_assign_op(op, lhs_1, rhs_1,
+                                          triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_field(?lhs, ?rhs, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
-                e_1 = ast::expr_field(lhs, rhs, triv_ann(ann, t));
+                e_1 = ast::expr_field(lhs, rhs,
+                                      triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_index(?base, ?index, ?ann)) {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
-                e_1 = ast::expr_index(base, index, triv_ann(ann, t));
+                e_1 = ast::expr_index(base, index,
+                                      triv_ann(ast::ann_tag(ann), t));
             }
             case (ast::expr_path(?pth, ?ann)) {
                 auto tp_substs_0 = ty::ann_to_type_params(fcx.ccx.node_types,
@@ -1456,9 +1480,9 @@ mod Pushdown {
                 }
 
                 e_1 = ast::expr_path(pth,
-                                    ast::ann_type(ast::ann_tag(ann), t,
-                                                  ty_params_opt,
-                                                  none[@ts_ann]));
+                                     ast::ann_type(ast::ann_tag(ann), t,
+                                                   ty_params_opt,
+                                                   none[@ts_ann]));
                 write_type(fcx.ccx.node_types, ast::ann_tag(ann),
                            tup(ty_params_opt, t));
             }
@@ -1466,7 +1490,7 @@ mod Pushdown {
                 auto t = Demand::autoderef(fcx, e.span, expected,
                     ann_to_type(fcx.ccx.node_types, ann), adk);
                 e_1 = ast::expr_ext(p, args, body, expanded,
-                                    triv_ann(ann, t));
+                                    triv_ann(ast::ann_tag(ann), t));
             }
             /* FIXME: should this check the type annotations? */
             case (ast::expr_fail(_))  { e_1 = e.node; } 
@@ -1482,7 +1506,7 @@ mod Pushdown {
             case (ast::expr_port(?ann)) {
                 auto t = Demand::simple(fcx, e.span, expected,
                                         ann_to_type(fcx.ccx.node_types, ann));
-                e_1 = ast::expr_port(triv_ann(ann, t));
+                e_1 = ast::expr_port(triv_ann(ast::ann_tag(ann), t));
             }
 
             case (ast::expr_chan(?es, ?ann)) {
@@ -1499,7 +1523,7 @@ mod Pushdown {
                         fail;
                     }
                 }
-                e_1 = ast::expr_chan(es_1, triv_ann(ann, t));
+                e_1 = ast::expr_chan(es_1, triv_ann(ast::ann_tag(ann), t));
             }
 
             case (ast::expr_alt(?discrim, ?arms_0, ?ann)) {
@@ -1512,7 +1536,8 @@ mod Pushdown {
                     auto arm_1 = rec(pat=arm_0.pat, block=block_1);
                     arms_1 += vec(arm_1);
                 }
-                e_1 = ast::expr_alt(discrim, arms_1, triv_ann(ann, t));
+                e_1 = ast::expr_alt(discrim, arms_1,
+                                    triv_ann(ast::ann_tag(ann), t));
             }
 
             case (ast::expr_recv(?lval_0, ?expr_0, ?ann)) {
@@ -1587,7 +1612,7 @@ fn writeback_local(&option::t[@fn_ctxt] env, &span sp, &@ast::local local)
         }
     }
 
-    auto local_wb = @rec(ann=triv_ann(local.ann, local_ty)
+    auto local_wb = @rec(ann=triv_ann(ast::ann_tag(local.ann), local_ty)
                          with *local
     );
     ret @fold::respan[ast::decl_](sp, ast::decl_local(local_wb));
@@ -1664,13 +1689,15 @@ fn check_pat(&@fn_ctxt fcx, &@ast::pat pat) -> @ast::pat {
     auto new_pat;
     alt (pat.node) {
         case (ast::pat_wild(?ann)) {
-            new_pat = ast::pat_wild(triv_ann(ann, next_ty_var(fcx.ccx)));
+            new_pat = ast::pat_wild(triv_ann(ast::ann_tag(ann),
+                                             next_ty_var(fcx.ccx)));
         }
         case (ast::pat_lit(?lt, ?ann)) {
-            new_pat = ast::pat_lit(lt, triv_ann(ann, check_lit(fcx.ccx, lt)));
+            new_pat = ast::pat_lit(lt, triv_ann(ast::ann_tag(ann),
+                                                check_lit(fcx.ccx, lt)));
         }
         case (ast::pat_bind(?id, ?def_id, ?a)) {
-            auto ann = triv_ann(a, next_ty_var(fcx.ccx));
+            auto ann = triv_ann(ast::ann_tag(a), next_ty_var(fcx.ccx));
             new_pat = ast::pat_bind(id, def_id, ann);
         }
         case (ast::pat_tag(?p, ?subpats, ?old_ann)) {
@@ -1879,8 +1906,8 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
         auto rhs_1 = Pushdown::pushdown_expr(fcx,
             expr_ty(fcx.ccx.tcx, fcx.ccx.node_types, lhs_1), rhs_0);
 
-        auto ann = triv_ann(a, expr_ty(fcx.ccx.tcx, fcx.ccx.node_types,
-                                       rhs_1));
+        auto ann = triv_ann(ast::ann_tag(a),
+                            expr_ty(fcx.ccx.tcx, fcx.ccx.node_types, rhs_1));
         ret tup(lhs_1, rhs_1, ann);
     }
 
@@ -1908,7 +1935,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
     alt (expr.node) {
         case (ast::expr_lit(?lit, ?a)) {
             auto typ = check_lit(fcx.ccx, lit);
-            auto ann = triv_ann(a, typ);
+            auto ann = triv_ann(ast::ann_tag(a), typ);
             ret @fold::respan[ast::expr_](expr.span, ast::expr_lit(lit, ann));
         }
 
@@ -1938,7 +1965,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 case (_) { /* fall through */ }
             }
 
-            auto ann = triv_ann(a, t);
+            auto ann = triv_ann(ast::ann_tag(a), t);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_binary(binop, lhs_1, rhs_1,
                                                         ann));
@@ -1969,7 +1996,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 case (_) { oper_t = strip_boxes(fcx.ccx.tcx, oper_t); }
             }
 
-            auto ann = triv_ann(a, oper_t);
+            auto ann = triv_ann(ast::ann_tag(a), oper_t);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_unary(unop, oper_1, ann));
         }
@@ -1998,14 +2025,15 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 fail;
             }
 
-            auto e = ast::expr_path(pth, triv_ann(old_ann, tpt._1));
+            auto e = ast::expr_path(pth, triv_ann(ast::ann_tag(old_ann),
+                                    tpt._1));
             ret @fold::respan[ast::expr_](expr.span, e);
         }
 
         case (ast::expr_ext(?p, ?args, ?body, ?expanded, ?a)) {
             auto exp_ = check_expr(fcx, expanded);
             auto t = expr_ty(fcx.ccx.tcx, fcx.ccx.node_types, exp_);
-            auto ann = triv_ann(a, t);
+            auto ann = triv_ann(ast::ann_tag(a), t);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_ext(p, args, body, exp_,
                                                      ann));
@@ -2188,7 +2216,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             }
             auto rhs_1 = Pushdown::pushdown_expr(fcx, item_t, rhs_0);
 
-            auto ann = triv_ann(a, chan_t);
+            auto ann = triv_ann(ast::ann_tag(a), chan_t);
             auto newexpr = ast::expr_send(lhs_1, rhs_1, ann);
             ret @fold::respan[ast::expr_](expr.span, newexpr);
         }
@@ -2214,7 +2242,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             }
             auto lhs_1 = Pushdown::pushdown_expr(fcx, item_t, lhs_0);
 
-            auto ann = triv_ann(a, item_t);
+            auto ann = triv_ann(ast::ann_tag(a), item_t);
             auto newexpr = ast::expr_recv(lhs_1, rhs_1, ann);
             ret @fold::respan[ast::expr_](expr.span, newexpr);
         }
@@ -2246,7 +2274,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
 
             auto thn_1 = Pushdown::pushdown_block(fcx, elsopt_t, thn_0);
 
-            auto ann = triv_ann(a, elsopt_t);
+            auto ann = triv_ann(ast::ann_tag(a), elsopt_t);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_if(cond_1, thn_1,
                                                     elsopt_1, ann));
@@ -2260,7 +2288,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             // FIXME: enforce that the type of the decl is the element type
             // of the seq.
 
-            auto ann = triv_ann(a, ty::mk_nil(fcx.ccx.tcx));
+            auto ann = triv_ann(ast::ann_tag(a), ty::mk_nil(fcx.ccx.tcx));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_for(decl_1, seq_1,
                                                      body_1, ann));
@@ -2271,7 +2299,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             auto seq_1 = check_expr(fcx, seq);
             auto body_1 = check_block(fcx, body);
 
-            auto ann = triv_ann(a, ty::mk_nil(fcx.ccx.tcx));
+            auto ann = triv_ann(ast::ann_tag(a), ty::mk_nil(fcx.ccx.tcx));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_for_each(decl_1, seq_1,
                                                           body_1, ann));
@@ -2284,7 +2312,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                                                   cond_0);
             auto body_1 = check_block(fcx, body);
 
-            auto ann = triv_ann(a, ty::mk_nil(fcx.ccx.tcx));
+            auto ann = triv_ann(ast::ann_tag(a), ty::mk_nil(fcx.ccx.tcx));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_while(cond_1, body_1, ann));
         }
@@ -2296,8 +2324,9 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                                                   cond_0);
             auto body_1 = check_block(fcx, body);
 
-            auto ann = triv_ann(a, block_ty(fcx.ccx.tcx, fcx.ccx.node_types,
-                                            body_1));
+            auto ann = triv_ann(ast::ann_tag(a),
+                                block_ty(fcx.ccx.tcx, fcx.ccx.node_types,
+                                         body_1));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_do_while(body_1, cond_1,
                                                           ann));
@@ -2349,7 +2378,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
 
             auto expr_1 = Pushdown::pushdown_expr(fcx, pattern_ty, expr_0);
 
-            auto ann = triv_ann(a, result_ty);
+            auto ann = triv_ann(ast::ann_tag(a), result_ty);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_alt(expr_1, arms_1, ann));
         }
@@ -2359,11 +2388,12 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             auto ann;
             alt (b_0.node.expr) {
                 case (some[@ast::expr](?expr)) {
-                    ann = triv_ann(a, expr_ty(fcx.ccx.tcx, fcx.ccx.node_types,
-                                              expr));
+                    ann = triv_ann(ast::ann_tag(a),
+                                   expr_ty(fcx.ccx.tcx, fcx.ccx.node_types,
+                                           expr));
                 }
                 case (none[@ast::expr]) {
-                    ann = triv_ann(a, ty::mk_nil(fcx.ccx.tcx));
+                    ann = triv_ann(ast::ann_tag(a), ty::mk_nil(fcx.ccx.tcx));
                 }
             }
             ret @fold::respan(expr.span, ast::expr_block(b_0, ann));
@@ -2403,7 +2433,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             }
 
             auto t_1 = ty::mk_fn(fcx.ccx.tcx, proto_1, arg_tys_1, rt_1);
-            auto ann = triv_ann(a, t_1);
+            auto ann = triv_ann(ast::ann_tag(a), t_1);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_bind(result._0, result._1,
                                                       ann));
@@ -2432,7 +2462,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 }
             }
 
-            auto ann = triv_ann(a, rt_1);
+            auto ann = triv_ann(ast::ann_tag(a), rt_1);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_call(f_1, args_1, ann));
         }
@@ -2467,7 +2497,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 case (_) { fail; }
             }
 
-            auto ann = triv_ann(a, t);
+            auto ann = triv_ann(ast::ann_tag(a), t);
 
             require_impure(fcx.ccx.sess, fcx.purity, expr.span);
 
@@ -2500,7 +2530,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
 
             // FIXME: Other typechecks needed
 
-            auto ann = triv_ann(a, ty::mk_task(fcx.ccx.tcx));
+            auto ann = triv_ann(ast::ann_tag(a), ty::mk_task(fcx.ccx.tcx));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_spawn(dom, name,
                                                        f_1, args_1, ann));
@@ -2520,7 +2550,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                     " as " + ty_to_str(fcx.ccx.tcx, t_1));
             }
 
-            auto ann = triv_ann(a, t_1);
+            auto ann = triv_ann(ast::ann_tag(a), t_1);
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_cast(e_1, t, ann));
         }
@@ -2544,8 +2574,8 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 _vec::push[@ast::expr](args_1,expr_1);
             }
 
-            auto ann = triv_ann(a, ty::mk_vec(fcx.ccx.tcx,
-                                             rec(ty=t, mut=mut)));
+            auto ann = triv_ann(ast::ann_tag(a),
+                                ty::mk_vec(fcx.ccx.tcx, rec(ty=t, mut=mut)));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_vec(args_1, mut, ann));
         }
@@ -2562,7 +2592,8 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                 elts_mt += vec(rec(ty=expr_t, mut=e.mut));
             }
 
-            auto ann = triv_ann(a, ty::mk_tup(fcx.ccx.tcx, elts_mt));
+            auto ann = triv_ann(ast::ann_tag(a),
+                                ty::mk_tup(fcx.ccx.tcx, elts_mt));
             ret @fold::respan[ast::expr_](expr.span,
                                         ast::expr_tup(elts_1, ann));
         }
@@ -2594,7 +2625,8 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
 
             alt (base) {
                 case (none[@ast::expr]) {
-                    ann = triv_ann(a, ty::mk_rec(fcx.ccx.tcx, fields_t));
+                    ann = triv_ann(ast::ann_tag(a),
+                                   ty::mk_rec(fcx.ccx.tcx, fields_t));
                 }
 
                 case (some[@ast::expr](?bexpr)) {
@@ -2615,7 +2647,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                         }
                     }
 
-                    ann = triv_ann(a, bexpr_t);
+                    ann = triv_ann(ast::ann_tag(a), bexpr_t);
 
                     for (ty::field f in fields_t) {
                         auto found = false;
@@ -2652,7 +2684,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                         fcx.ccx.sess.span_err(expr.span,
                                               "bad index on tuple");
                     }
-                    auto ann = triv_ann(a, args.(ix).ty);
+                    auto ann = triv_ann(ast::ann_tag(a), args.(ix).ty);
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_field(base_1,
                                                                field,
@@ -2666,7 +2698,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                         fcx.ccx.sess.span_err(expr.span,
                                               "bad index on record");
                     }
-                    auto ann = triv_ann(a, fields.(ix).mt.ty);
+                    auto ann = triv_ann(ast::ann_tag(a), fields.(ix).mt.ty);
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_field(base_1,
                                                                field,
@@ -2683,7 +2715,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                     auto meth = methods.(ix);
                     auto t = ty::mk_fn(fcx.ccx.tcx, meth.proto,
                                       meth.inputs, meth.output);
-                    auto ann = triv_ann(a, t);
+                    auto ann = triv_ann(ast::ann_tag(a), t);
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_field(base_1,
                                                                field,
@@ -2713,7 +2745,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                              "non-integral type of vec index: "
                              + ty_to_str(fcx.ccx.tcx, idx_t));
                     }
-                    auto ann = triv_ann(a, mt.ty);
+                    auto ann = triv_ann(ast::ann_tag(a), mt.ty);
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_index(base_1,
                                                                idx_1,
@@ -2726,8 +2758,9 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
                              "non-integral type of str index: "
                              + ty_to_str(fcx.ccx.tcx, idx_t));
                     }
-                    auto ann = triv_ann(a, ty::mk_mach(fcx.ccx.tcx,
-                                                      common::ty_u8));
+                    auto ann = triv_ann(ast::ann_tag(a),
+                                        ty::mk_mach(fcx.ccx.tcx,
+                                                    common::ty_u8));
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_index(base_1,
                                                                idx_1,
@@ -2745,7 +2778,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
         case (ast::expr_port(?a)) {
             auto t = next_ty_var(fcx.ccx);
             auto pt = ty::mk_port(fcx.ccx.tcx, t);
-            auto ann = triv_ann(a, pt);
+            auto ann = triv_ann(ast::ann_tag(a), pt);
             ret @fold::respan[ast::expr_](expr.span, ast::expr_port(ann));
         }
 
@@ -2755,7 +2788,7 @@ fn check_expr(&@fn_ctxt fcx, &@ast::expr expr) -> @ast::expr {
             alt (struct(fcx.ccx.tcx, port_t)) {
                 case (ty::ty_port(?subtype)) {
                     auto ct = ty::mk_chan(fcx.ccx.tcx, subtype);
-                    auto ann = triv_ann(a, ct);
+                    auto ann = triv_ann(ast::ann_tag(a), ct);
                     ret @fold::respan[ast::expr_](expr.span,
                                                 ast::expr_chan(expr_1, ann));
                 }
@@ -2803,7 +2836,7 @@ fn check_decl_local(&@fn_ctxt fcx, &@ast::decl decl) -> @ast::decl {
             auto a_res = local.ann;
             alt (a_res) {
                 case (ann_none(_)) {
-                    a_res = triv_ann(a_res, t);
+                    a_res = triv_ann(ast::ann_tag(a_res), t);
                 }
                 case (_) {}
             }
@@ -2972,8 +3005,8 @@ fn check_item_fn(&@crate_ctxt ccx, &span sp, &ast::ident ident, &ast::_fn f,
     }
 
     auto output_ty = ast_ty_to_ty_crate(ccx, f.decl.output);
-    auto fn_ann = triv_ann(ann, ty::mk_fn(ccx.tcx, f.proto, inputs,
-                                         output_ty));
+    auto fn_ann = triv_ann(ast::ann_tag(ann),
+                           ty::mk_fn(ccx.tcx, f.proto, inputs, output_ty));
 
     auto item = ast::item_fn(ident, f, ty_params, id, fn_ann);
     ret @fold::respan[ast::item_](sp, item);