aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2011-05-13 14:38:05 -0700
committerPatrick Walton <[email protected]>2011-05-13 14:39:00 -0700
commite888fe6f9b8ed0c47df2ed17e50c2d391c1dc647 (patch)
tree7c517d4618d7f541a1076c7a4a9e7b372bf38707 /src
parentrustc: lowercase the link and link::write modules (diff)
downloadrust-e888fe6f9b8ed0c47df2ed17e50c2d391c1dc647.tar.xz
rust-e888fe6f9b8ed0c47df2ed17e50c2d391c1dc647.zip
rustc: Change ty::triv_ann() to take a node ID instead of a full annotation
Diffstat (limited to 'src')
-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 b3d9977e..5957c1fd 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 3e0ed783..024d2c67 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);