Add a type abbreviation and redo first pass of collect_item_types to collect across the whole crate, not just top level.

This commit is contained in:
Graydon Hoare 2010-12-09 15:03:19 -08:00
parent 876282791e
commit b7e344622c

View File

@ -353,7 +353,10 @@ fn type_err_to_str(&type_err err) -> str {
// AST, along with a table mapping item IDs to their types. // AST, along with a table mapping item IDs to their types.
fn collect_item_types(@ast.crate crate) -> tup(@ast.crate, @ty_table) { fn collect_item_types(@ast.crate crate) -> tup(@ast.crate, @ty_table) {
fn trans_ty_item_id_to_ty(@hashmap[ast.def_id,@ast.item] id_to_ty_item,
type ty_item_table = hashmap[ast.def_id,@ast.item];
fn trans_ty_item_id_to_ty(@ty_item_table id_to_ty_item,
@ty_table item_to_ty, @ty_table item_to_ty,
ast.def_id id) -> @ty { ast.def_id id) -> @ty {
check (id_to_ty_item.contains_key(id)); check (id_to_ty_item.contains_key(id));
@ -361,14 +364,14 @@ fn collect_item_types(@ast.crate crate) -> tup(@ast.crate, @ty_table) {
ret trans_ty_item_to_ty(id_to_ty_item, item_to_ty, item); ret trans_ty_item_to_ty(id_to_ty_item, item_to_ty, item);
} }
fn trans_fn_arg_to_ty(@hashmap[ast.def_id,@ast.item] id_to_ty_item, fn trans_fn_arg_to_ty(@ty_item_table id_to_ty_item,
@ty_table item_to_ty, @ty_table item_to_ty,
&ast.arg a) -> arg { &ast.arg a) -> arg {
auto f = bind trans_ty_item_id_to_ty(id_to_ty_item, item_to_ty, _); auto f = bind trans_ty_item_id_to_ty(id_to_ty_item, item_to_ty, _);
ret rec(mode=a.mode, ty=ast_ty_to_ty(f, a.ty)); ret rec(mode=a.mode, ty=ast_ty_to_ty(f, a.ty));
} }
fn trans_ty_item_to_ty(@hashmap[ast.def_id,@ast.item] id_to_ty_item, fn trans_ty_item_to_ty(@ty_item_table id_to_ty_item,
@ty_table item_to_ty, @ty_table item_to_ty,
@ast.item it) -> @ty { @ast.item it) -> @ty {
alt (it.node) { alt (it.node) {
@ -414,7 +417,7 @@ fn collect_item_types(@ast.crate crate) -> tup(@ast.crate, @ty_table) {
} }
} }
fn get_tag_variant_types(@hashmap[ast.def_id,@ast.item] id_to_ty_item, fn get_tag_variant_types(@ty_item_table id_to_ty_item,
@ty_table item_to_ty, @ty_table item_to_ty,
&ast.def_id tag_id, &ast.def_id tag_id,
&vec[ast.variant] variants) -> vec[ast.variant] { &vec[ast.variant] variants) -> vec[ast.variant] {
@ -452,14 +455,22 @@ fn collect_item_types(@ast.crate crate) -> tup(@ast.crate, @ty_table) {
// First pass: collect all type item IDs. // First pass: collect all type item IDs.
auto module = crate.node.module; auto module = crate.node.module;
auto id_to_ty_item = @common.new_def_hash[@ast.item](); auto id_to_ty_item = @common.new_def_hash[@ast.item]();
for (@ast.item item in module.items) { fn collect(&@ty_item_table id_to_ty_item, @ast.item i)
alt (item.node) { -> @ty_item_table {
alt (i.node) {
case (ast.item_ty(_, _, _, ?def_id, _)) { case (ast.item_ty(_, _, _, ?def_id, _)) {
id_to_ty_item.insert(def_id, item); id_to_ty_item.insert(def_id, i);
} }
case (_) { /* empty */ } case (_) { /* empty */ }
} }
ret id_to_ty_item;
} }
auto fld_1 = fold.new_identity_fold[@ty_item_table]();
auto f = collect;
fld_1 = @rec(update_env_for_item = f with *fld_1);
fold.fold_crate[@ty_item_table](id_to_ty_item, fld_1, crate);
// Second pass: translate the types of all items. // Second pass: translate the types of all items.
auto item_to_ty = @common.new_def_hash[@ty](); auto item_to_ty = @common.new_def_hash[@ty]();