aboutsummaryrefslogtreecommitdiff
path: root/src/comp/middle
diff options
context:
space:
mode:
authorGraydon Hoare <[email protected]>2011-03-26 17:36:47 -0700
committerGraydon Hoare <[email protected]>2011-03-26 17:36:47 -0700
commitdbc7289a4deb8dad8727962661bb2138a98ff5d2 (patch)
tree2df6e455dc798e4357bc35ad9e440998c4db0879 /src/comp/middle
parentAdd visibility enum values to lib.llvm. (diff)
downloadrust-dbc7289a4deb8dad8727962661bb2138a98ff5d2.tar.xz
rust-dbc7289a4deb8dad8727962661bb2138a98ff5d2.zip
Start refactoring name-mangling in trans.
Diffstat (limited to 'src/comp/middle')
-rw-r--r--src/comp/middle/trans.rs133
1 files changed, 90 insertions, 43 deletions
diff --git a/src/comp/middle/trans.rs b/src/comp/middle/trans.rs
index a9dbf13a..10742d7b 100644
--- a/src/comp/middle/trans.rs
+++ b/src/comp/middle/trans.rs
@@ -90,7 +90,6 @@ state type crate_ctxt = rec(session.session sess,
ValueRef crate_ptr,
hashmap[str, ValueRef] externs,
hashmap[str, ValueRef] intrinsics,
- hashmap[str, ValueRef] item_names,
hashmap[ast.def_id, ValueRef] item_ids,
hashmap[ast.def_id, @ast.item] items,
hashmap[ast.def_id,
@@ -108,7 +107,8 @@ state type crate_ctxt = rec(session.session sess,
vec[ast.obj_field] obj_fields,
@glue_fns glues,
namegen names,
- str path);
+ vec[str] path,
+ std.sha1.sha1 sha);
state type fn_ctxt = rec(ValueRef llfn,
ValueRef lltaskptr,
@@ -156,6 +156,30 @@ fn sep() -> str {
ret "_";
}
+fn extend_path(@crate_ctxt cx, str name) -> @crate_ctxt {
+ ret @rec(path = cx.path + vec(name) with *cx);
+}
+
+fn path_name(vec[str] path) -> str {
+ ret _str.connect(path, sep());
+}
+
+
+fn mangle_name_by_type(@crate_ctxt cx, @ty.t t) -> str {
+ cx.sha.reset();
+ auto f = metadata.def_to_str;
+ cx.sha.input_str(metadata.ty_str(t, f));
+ ret sep() + "rust" + sep()
+ + cx.sha.result_str() + sep()
+ + path_name(cx.path);
+}
+
+fn mangle_name_by_seq(@crate_ctxt cx, str flav) -> str {
+ ret sep() + "rust" + sep()
+ + cx.names.next(flav) + sep()
+ + path_name(cx.path);
+}
+
fn res(@block_ctxt bcx, ValueRef val) -> result {
ret rec(mutable bcx = bcx,
mutable val = val);
@@ -1549,7 +1573,8 @@ fn define_tydesc(@crate_ctxt cx, @ty.t t, vec[ast.def_id] typaram_defs) {
fn declare_generic_glue(@crate_ctxt cx, @ty.t t, str name) -> ValueRef {
auto llfnty = T_glue_fn(cx.tn);
- auto fn_name = cx.names.next("_rust_" + name) + sep() + ty.ty_to_str(t);
+ auto gcx = @rec(path=vec("glue", name) with *cx);
+ auto fn_name = mangle_name_by_type(gcx, t);
fn_name = sanitize(fn_name);
auto llfn = decl_fastcall_fn(cx.llmod, fn_name, llfnty);
llvm.LLVMSetLinkage(llfn, lib.llvm.LLVMPrivateLinkage as llvm.Linkage);
@@ -3193,9 +3218,7 @@ fn trans_for_each(@block_ctxt cx,
// Step 2: Declare foreach body function.
- let str s =
- cx.fcx.ccx.names.next("_rust_foreach")
- + sep() + cx.fcx.ccx.path;
+ let str s = mangle_name_by_seq(cx.fcx.ccx, "foreach");
// The 'env' arg entering the body function is a fake env member (as in
// the env-part of the normal rust calling convention) that actually
@@ -3788,7 +3811,7 @@ fn trans_bind_thunk(@crate_ctxt cx,
// Construct a thunk-call with signature incoming_fty, and that copies
// args forward into a call to outgoing_fty.
- let str s = cx.names.next("_rust_thunk") + sep() + cx.path;
+ let str s = mangle_name_by_seq(cx, "thunk");
let TypeRef llthunk_ty = get_pair_fn_ty(type_of(cx, incoming_fty));
let ValueRef llthunk = decl_fastcall_fn(cx.llmod, s, llthunk_ty);
@@ -5327,7 +5350,6 @@ fn trans_fn(@crate_ctxt cx, &ast._fn f, ast.def_id fid,
&vec[ast.ty_param] ty_params, &ast.ann ann) {
auto llfndecl = cx.item_ids.get(fid);
- cx.item_names.insert(cx.path, llfndecl);
auto fcx = new_fn_ctxt(cx, llfndecl);
create_llargs_for_fn_args(fcx, f.proto,
@@ -5378,22 +5400,21 @@ fn trans_vtbl(@crate_ctxt cx, TypeRef self_ty,
}
}
- let @crate_ctxt mcx = @rec(path=cx.path + sep() + m.node.ident
- with *cx);
-
- let str s = cx.names.next("_rust_method") + sep() + mcx.path;
+ let @crate_ctxt mcx = extend_path(cx, m.node.ident);
+ let str s = mangle_name_by_seq(mcx, "method");
let ValueRef llfn = decl_fastcall_fn(cx.llmod, s, llfnty);
cx.item_ids.insert(m.node.id, llfn);
cx.item_symbols.insert(m.node.id, s);
+
trans_fn(mcx, m.node.meth, m.node.id, some[TypeRef](self_ty),
ty_params, m.node.ann);
methods += vec(llfn);
}
auto vtbl = C_struct(methods);
- auto gvar = llvm.LLVMAddGlobal(cx.llmod,
- val_ty(vtbl),
- _str.buf("_rust_vtbl" + sep() + cx.path));
+ auto vtbl_name = mangle_name_by_seq(cx, "vtbl");
+ auto gvar = llvm.LLVMAddGlobal(cx.llmod, val_ty(vtbl),
+ _str.buf(vtbl_name));
llvm.LLVMSetInitializer(gvar, vtbl);
llvm.LLVMSetGlobalConstant(gvar, True);
llvm.LLVMSetLinkage(gvar, lib.llvm.LLVMPrivateLinkage
@@ -5405,7 +5426,6 @@ fn trans_obj(@crate_ctxt cx, &ast._obj ob, ast.def_id oid,
&vec[ast.ty_param] ty_params, &ast.ann ann) {
auto llctor_decl = cx.item_ids.get(oid);
- cx.item_names.insert(cx.path, llctor_decl);
// Translate obj ctor args to function arguments.
let vec[ast.arg] fn_args = vec();
@@ -5628,21 +5648,21 @@ fn trans_const(@crate_ctxt cx, @ast.expr e,
fn trans_item(@crate_ctxt cx, &ast.item item) {
alt (item.node) {
case (ast.item_fn(?name, ?f, ?tps, ?fid, ?ann)) {
- auto sub_cx = @rec(path=cx.path + sep() + name with *cx);
+ auto sub_cx = extend_path(cx, name);
trans_fn(sub_cx, f, fid, none[TypeRef], tps, ann);
}
case (ast.item_obj(?name, ?ob, ?tps, ?oid, ?ann)) {
- auto sub_cx = @rec(path=cx.path + sep() + name,
- obj_typarams=tps,
- obj_fields=ob.fields with *cx);
+ auto sub_cx = @rec(obj_typarams=tps,
+ obj_fields=ob.fields with
+ *extend_path(cx, name));
trans_obj(sub_cx, ob, oid, tps, ann);
}
case (ast.item_mod(?name, ?m, _)) {
- auto sub_cx = @rec(path=cx.path + sep() + name with *cx);
+ auto sub_cx = extend_path(cx, name);
trans_mod(sub_cx, m);
}
case (ast.item_tag(?name, ?variants, ?tps, ?tag_id)) {
- auto sub_cx = @rec(path=cx.path + sep() + name with *cx);
+ auto sub_cx = extend_path(cx, name);
auto i = 0;
for (ast.variant variant in variants) {
trans_tag_variant(sub_cx, tag_id, variant, i, tps);
@@ -5650,7 +5670,7 @@ fn trans_item(@crate_ctxt cx, &ast.item item) {
}
}
case (ast.item_const(?name, _, ?expr, ?cid, ?ann)) {
- auto sub_cx = @rec(path=cx.path + sep() + name with *cx);
+ auto sub_cx = extend_path(cx, name);
trans_const(sub_cx, expr, cid, ann);
}
case (_) { /* fall through */ }
@@ -5672,8 +5692,7 @@ fn get_pair_fn_ty(TypeRef llpairty) -> TypeRef {
}
fn decl_fn_and_pair(@crate_ctxt cx,
- str kind,
- str name,
+ str flav,
vec[ast.ty_param] ty_params,
&ast.ann ann,
ast.def_id id) {
@@ -5693,11 +5712,11 @@ fn decl_fn_and_pair(@crate_ctxt cx,
}
// Declare the function itself.
- let str s = cx.names.next("_rust_" + kind) + sep() + name;
+ let str s = mangle_name_by_seq(cx, flav);
let ValueRef llfn = decl_fastcall_fn(cx.llmod, s, llfty);
// Declare the global constant pair that points to it.
- let str ps = cx.names.next("_rust_" + kind + "_pair") + sep() + name;
+ let str ps = mangle_name_by_type(cx, node_ann_type(cx, ann));
register_fn_pair(cx, ps, llpairty, llfn, id);
}
@@ -5756,14 +5775,14 @@ fn decl_native_fn_and_pair(@crate_ctxt cx,
// Declare the wrapper.
auto wrapper_type = native_fn_wrapper_type(cx, num_ty_param, ann);
- let str s = cx.names.next("_rust_wrapper") + sep() + name;
+ let str s = mangle_name_by_seq(cx, "wrapper");
let ValueRef wrapper_fn = decl_fastcall_fn(cx.llmod, s, wrapper_type);
llvm.LLVMSetLinkage(wrapper_fn, lib.llvm.LLVMPrivateLinkage
as llvm.Linkage);
// Declare the global constant pair that points to it.
auto wrapper_pair_type = T_fn_pair(cx.tn, wrapper_type);
- let str ps = cx.names.next("_rust_wrapper_pair") + sep() + name;
+ let str ps = mangle_name_by_type(cx, node_ann_type(cx, ann));
register_fn_pair(cx, ps, wrapper_pair_type, wrapper_fn, id);
@@ -5827,8 +5846,33 @@ fn collect_native_item(&@crate_ctxt cx, @ast.native_item i) -> @crate_ctxt {
ret cx;
}
-fn collect_item(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
+fn item_name(@ast.item i) -> str {
+ alt (i.node) {
+ case (ast.item_mod(?name, _, _)) {
+ ret name;
+ }
+ case (ast.item_tag(?name, _, _, _)) {
+ ret name;
+ }
+ case (ast.item_const(?name, _, _, _, _)) {
+ ret name;
+ }
+ case (ast.item_fn(?name, _, _, _, _)) {
+ ret name;
+ }
+ case (ast.item_native_mod(?name, _, _)) {
+ ret name;
+ }
+ case (ast.item_ty(?name, _, _, _, _)) {
+ ret name;
+ }
+ case (ast.item_obj(?name, _, _, _, _)) {
+ ret name;
+ }
+ }
+}
+fn collect_item(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
alt (i.node) {
case (ast.item_const(?name, _, _, ?cid, ?ann)) {
auto typ = node_ann_type(cx, ann);
@@ -5844,13 +5888,12 @@ fn collect_item(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
cx.items.insert(mid, i);
}
- case (ast.item_tag(_, ?variants, ?tps, ?tag_id)) {
+ case (ast.item_tag(?name, ?variants, ?tps, ?tag_id)) {
cx.items.insert(tag_id, i);
}
-
case (_) { /* fall through */ }
}
- ret cx;
+ ret extend_path(cx, item_name(i));
}
fn collect_item_pass2(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
@@ -5858,13 +5901,15 @@ fn collect_item_pass2(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
case (ast.item_fn(?name, ?f, ?tps, ?fid, ?ann)) {
cx.items.insert(fid, i);
if (! cx.obj_methods.contains_key(fid)) {
- decl_fn_and_pair(cx, "fn", name, tps, ann, fid);
+ decl_fn_and_pair(extend_path(cx, name), "fn",
+ tps, ann, fid);
}
}
case (ast.item_obj(?name, ?ob, ?tps, ?oid, ?ann)) {
cx.items.insert(oid, i);
- decl_fn_and_pair(cx, "obj_ctor", name, tps, ann, oid);
+ decl_fn_and_pair(extend_path(cx, name), "obj_ctor",
+ tps, ann, oid);
for (@ast.method m in ob.methods) {
cx.obj_methods.insert(m.node.id, ());
}
@@ -5872,7 +5917,7 @@ fn collect_item_pass2(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
case (_) { /* fall through */ }
}
- ret cx;
+ ret extend_path(cx, item_name(i));
}
@@ -5904,7 +5949,7 @@ fn collect_tag_ctor(&@crate_ctxt cx, @ast.item i) -> @crate_ctxt {
case (ast.item_tag(_, ?variants, ?tps, _)) {
for (ast.variant variant in variants) {
if (_vec.len[ast.variant_arg](variant.args) != 0u) {
- decl_fn_and_pair(cx, "tag", variant.name,
+ decl_fn_and_pair(extend_path(cx, variant.name), "tag",
tps, variant.ann, variant.id);
}
}
@@ -5963,7 +6008,8 @@ fn trans_constant(&@crate_ctxt cx, @ast.item it) -> @crate_ctxt {
// with consts.
auto v = C_int(1);
cx.item_ids.insert(cid, v);
- auto s = cx.names.next("_rust_const") + sep() + name;
+ auto s = mangle_name_by_type(extend_path(cx, name),
+ node_ann_type(cx, ann));
cx.item_symbols.insert(cid, s);
}
@@ -6064,10 +6110,10 @@ fn find_main_fn(@crate_ctxt cx) -> ValueRef {
auto e = sep() + "main";
let ValueRef v = C_nil();
let uint n = 0u;
- for each (@tup(str,ValueRef) i in cx.item_names.items()) {
- if (_str.ends_with(i._0, e)) {
+ for each (@tup(ast.def_id, str) i in cx.item_symbols.items()) {
+ if (_str.ends_with(i._1, e)) {
n += 1u;
- v = i._1;
+ v = cx.item_ids.get(i._0);
}
}
alt (n) {
@@ -6534,6 +6580,7 @@ fn trans_crate(session.session sess, @ast.crate crate, str output,
let vec[ast.ty_param] obj_typarams = vec();
let vec[ast.obj_field] obj_fields = vec();
+ let vec[str] pth = vec();
auto cx = @rec(sess = sess,
llmod = llmod,
td = td,
@@ -6541,7 +6588,6 @@ fn trans_crate(session.session sess, @ast.crate crate, str output,
crate_ptr = crate_ptr,
externs = new_str_hash[ValueRef](),
intrinsics = intrinsics,
- item_names = new_str_hash[ValueRef](),
item_ids = new_def_hash[ValueRef](),
items = new_def_hash[@ast.item](),
native_items = new_def_hash[@ast.native_item](),
@@ -6557,7 +6603,8 @@ fn trans_crate(session.session sess, @ast.crate crate, str output,
obj_fields = obj_fields,
glues = glues,
names = namegen(0),
- path = "_rust");
+ path = pth,
+ sha = std.sha1.mk_sha1());
create_typedefs(cx);