aboutsummaryrefslogtreecommitdiff
path: root/src/comp/middle
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2011-04-21 11:46:31 -0700
committerPatrick Walton <[email protected]>2011-04-21 11:46:31 -0700
commitf4b89f5d79fd5448fc5d82844ebd890cc2d7843b (patch)
tree1421f693b5e67eaed5b2bc5898c6bf539561bbec /src/comp/middle
parentFix link commands for stage1 and stage2. (diff)
downloadrust-f4b89f5d79fd5448fc5d82844ebd890cc2d7843b.tar.xz
rust-f4b89f5d79fd5448fc5d82844ebd890cc2d7843b.zip
rustc: Move ty.unify to a separate namespace
Diffstat (limited to 'src/comp/middle')
-rw-r--r--src/comp/middle/ty.rs68
-rw-r--r--src/comp/middle/typeck.rs28
2 files changed, 50 insertions, 46 deletions
diff --git a/src/comp/middle/ty.rs b/src/comp/middle/ty.rs
index 9637e038..eed07098 100644
--- a/src/comp/middle/ty.rs
+++ b/src/comp/middle/ty.rs
@@ -77,8 +77,8 @@ tag sty {
type unify_handler = obj {
fn resolve_local(ast.def_id id) -> option.t[@t];
- fn record_local(ast.def_id id, @t ty); // TODO: -> unify_result
- fn record_param(uint index, @t binding) -> unify_result;
+ fn record_local(ast.def_id id, @t ty); // TODO: -> Unify.result
+ fn record_param(uint index, @t binding) -> Unify.result;
};
tag type_err {
@@ -95,11 +95,6 @@ tag type_err {
terr_arg_count;
}
-tag unify_result {
- ures_ok(@ty.t);
- ures_err(type_err, @ty.t, @ty.t);
-}
-
type ty_param_count_and_ty = tup(uint, @t);
type type_cache = hashmap[ast.def_id,ty_param_count_and_ty];
@@ -1551,12 +1546,16 @@ fn is_lval(@ast.expr expr) -> bool {
//
// http://www.cs.man.ac.uk/~hoderk/ubench/unification_full.pdf
-type var_bindings = rec(UFind.ufind sets,
- hashmap[int,uint] var_ids,
- mutable vec[mutable vec[@t]] types);
+mod Unify {
+ tag result {
+ ures_ok(@ty.t);
+ ures_err(type_err, @ty.t, @ty.t);
+ }
+
+ type var_bindings = rec(UFind.ufind sets,
+ hashmap[int,uint] var_ids,
+ mutable vec[mutable vec[@t]] types);
-fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
- -> unify_result {
// Wraps the given type in an appropriate cname.
//
// TODO: This doesn't do anything yet. We should carry the cname up from
@@ -1565,7 +1564,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
// something we'll probably need to develop over time.
// Simple structural type comparison.
- fn struct_cmp(@ty.t expected, @ty.t actual) -> unify_result {
+ fn struct_cmp(@ty.t expected, @ty.t actual) -> result {
if (expected.struct == actual.struct) {
ret ures_ok(expected);
}
@@ -1589,7 +1588,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
}
tag fn_common_res {
- fn_common_res_err(unify_result);
+ fn_common_res_err(result);
fn_common_res_ok(vec[arg], @t);
}
@@ -1666,7 +1665,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
&unify_handler handler,
vec[arg] expected_inputs, @t expected_output,
vec[arg] actual_inputs, @t actual_output)
- -> unify_result {
+ -> result {
if (e_proto != a_proto) {
ret ures_err(terr_mismatch, expected, actual);
@@ -1693,7 +1692,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
&unify_handler handler,
vec[arg] expected_inputs, @t expected_output,
vec[arg] actual_inputs, @t actual_output)
- -> unify_result {
+ -> result {
if (e_abi != a_abi) {
ret ures_err(terr_mismatch, expected, actual);
}
@@ -1717,7 +1716,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
@ty.t actual,
&unify_handler handler,
vec[method] expected_meths,
- vec[method] actual_meths) -> unify_result {
+ vec[method] actual_meths) -> result {
let vec[method] result_meths = vec();
let uint i = 0u;
let uint expected_len = _vec.len[method](expected_meths);
@@ -1772,7 +1771,7 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
}
fn unify_step(&var_bindings bindings, @ty.t expected, @ty.t actual,
- &unify_handler handler) -> unify_result {
+ &unify_handler handler) -> result {
// TODO: rewrite this using tuple pattern matching when available, to
// avoid all this rightward drift and spikiness.
@@ -2261,24 +2260,27 @@ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
ret result;
}
- let vec[@t] throwaway = vec();
- let vec[mutable vec[@t]] types = vec(mutable throwaway);
- _vec.pop[mutable vec[@t]](types); // FIXME: botch
+ fn unify(@ty.t expected, @ty.t actual, &unify_handler handler)
+ -> result {
+ let vec[@t] throwaway = vec();
+ let vec[mutable vec[@t]] types = vec(mutable throwaway);
+ _vec.pop[mutable vec[@t]](types); // FIXME: botch
- auto bindings = rec(sets=UFind.make(),
- var_ids=common.new_int_hash[uint](),
- mutable types=types);
+ auto bindings = rec(sets=UFind.make(),
+ var_ids=common.new_int_hash[uint](),
+ mutable types=types);
- auto ures = unify_step(bindings, expected, actual, handler);
- alt (ures) {
- case (ures_ok(?t)) {
- auto set_types = unify_sets(bindings);
- auto t2 = substitute(bindings, set_types, t);
- ret ures_ok(t2);
- }
- case (_) { ret ures; }
+ auto ures = unify_step(bindings, expected, actual, handler);
+ alt (ures) {
+ case (ures_ok(?t)) {
+ auto set_types = unify_sets(bindings);
+ auto t2 = substitute(bindings, set_types, t);
+ ret ures_ok(t2);
+ }
+ case (_) { ret ures; }
+ }
+ fail; // not reached
}
- fail; // not reached
}
fn type_err_to_str(&ty.type_err err) -> str {
diff --git a/src/comp/middle/typeck.rs b/src/comp/middle/typeck.rs
index 99cc6d6a..b4863954 100644
--- a/src/comp/middle/typeck.rs
+++ b/src/comp/middle/typeck.rs
@@ -25,6 +25,8 @@ import middle.ty.type_is_integral;
import middle.ty.type_is_scalar;
import middle.ty.ty_param_count_and_ty;
import middle.ty.ty_nil;
+import middle.ty.Unify.ures_ok;
+import middle.ty.Unify.ures_err;
import std._str;
import std._uint;
@@ -49,7 +51,7 @@ tag any_item {
type ty_item_table = hashmap[ast.def_id,any_item];
type unify_cache_entry = tup(@ty.t,@ty.t,vec[mutable @ty.t]);
-type unify_cache = hashmap[unify_cache_entry,ty.unify_result];
+type unify_cache = hashmap[unify_cache_entry,ty.Unify.result];
type crate_ctxt = rec(session.session sess,
ty.type_cache type_cache,
@@ -805,7 +807,7 @@ mod Collect {
// Type unification
mod Unify {
- fn simple(@fn_ctxt fcx, @ty.t expected, @ty.t actual) -> ty.unify_result {
+ fn simple(@fn_ctxt fcx, @ty.t expected, @ty.t actual) -> ty.Unify.result {
// FIXME: horrid botch
let vec[mutable @ty.t] param_substs = vec(mutable ty.mk_nil());
_vec.pop[mutable @ty.t](param_substs);
@@ -813,7 +815,7 @@ mod Unify {
}
fn with_params(@fn_ctxt fcx, @ty.t expected, @ty.t actual,
- vec[mutable @ty.t] param_substs) -> ty.unify_result {
+ vec[mutable @ty.t] param_substs) -> ty.Unify.result {
auto cache_key = tup(expected, actual, param_substs);
if (fcx.ccx.unify_cache.contains_key(cache_key)) {
fcx.ccx.cache_hits += 1u;
@@ -843,7 +845,7 @@ mod Unify {
case (some[@ty.t](?old_type)) {
alt (with_params(fcx, old_type, new_type,
param_substs)) {
- case (ty.ures_ok(?ut)) { unified_type = ut; }
+ case (ures_ok(?ut)) { unified_type = ut; }
case (_) { fail; /* FIXME */ }
}
}
@@ -859,7 +861,7 @@ mod Unify {
ty.substitute_type_params(param_substs_1, unified_type);
fcx.locals.insert(id, unified_type);
}
- fn record_param(uint index, @ty.t binding) -> ty.unify_result {
+ fn record_param(uint index, @ty.t binding) -> ty.Unify.result {
// Unify with the appropriate type in the parameter
// substitution list.
auto old_subst = param_substs.(index);
@@ -867,9 +869,9 @@ mod Unify {
auto result = with_params(fcx, old_subst, binding,
param_substs);
alt (result) {
- case (ty.ures_ok(?new_subst)) {
+ case (ures_ok(?new_subst)) {
param_substs.(index) = new_subst;
- ret ty.ures_ok(ty.mk_bound_param(index));
+ ret ures_ok(ty.mk_bound_param(index));
}
case (_) { ret result; }
}
@@ -878,7 +880,7 @@ mod Unify {
auto handler = unify_handler(fcx, param_substs);
- auto result = ty.unify(expected, actual, handler);
+ auto result = ty.Unify.unify(expected, actual, handler);
fcx.ccx.unify_cache.insert(cache_key, result);
ret result;
}
@@ -965,7 +967,7 @@ mod Demand {
}
alt (Unify.with_params(fcx, expected_1, actual_1, ty_param_substs)) {
- case (ty.ures_ok(?t)) {
+ case (ures_ok(?t)) {
// TODO: Use "freeze", when we have it.
let vec[@ty.t] result_ty_param_substs = vec();
for (mutable @ty.t ty_param_subst in ty_param_substs) {
@@ -975,7 +977,7 @@ mod Demand {
ret tup(result_ty_param_substs, add_boxes(implicit_boxes, t));
}
- case (ty.ures_err(?err, ?expected, ?actual)) {
+ case (ures_err(?err, ?expected, ?actual)) {
fcx.ccx.sess.span_err(sp, "mismatched types: expected "
+ ty_to_str(expected) + " but found "
+ ty_to_str(actual) + " (" +
@@ -993,8 +995,8 @@ mod Demand {
// Returns true if the two types unify and false if they don't.
fn are_compatible(&@fn_ctxt fcx, @ty.t expected, @ty.t actual) -> bool {
alt (Unify.simple(fcx, expected, actual)) {
- case (ty.ures_ok(_)) { ret true; }
- case (ty.ures_err(_, _, _)) { ret false; }
+ case (ures_ok(_)) { ret true; }
+ case (ures_err(_, _, _)) { ret false; }
}
}
@@ -2723,7 +2725,7 @@ fn check_crate(session.session sess, @ast.crate crate) -> typecheck_result {
auto hasher = hash_unify_cache_entry;
auto eqer = eq_unify_cache_entry;
auto unify_cache =
- map.mk_hashmap[unify_cache_entry,ty.unify_result](hasher, eqer);
+ map.mk_hashmap[unify_cache_entry,ty.Unify.result](hasher, eqer);
auto ccx = @rec(sess=sess,
type_cache=result._1,