mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-16 09:43:52 +00:00
Remove @-fields from CrateContext
Remove all the explicit @mut-fields from CrateContext, though many fields are still @-ptrs. This required changing every single function call that explicitly took a @CrateContext, so I took advantage and changed as many as I could get away with to &-ptrs or &mut ptrs.
This commit is contained in:
parent
01e098aa05
commit
cc908b772c
@ -622,11 +622,11 @@ pub fn symbol_hash(tcx: ty::ctxt,
|
|||||||
hash.to_managed()
|
hash.to_managed()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_symbol_hash(ccx: @CrateContext, t: ty::t) -> @str {
|
pub fn get_symbol_hash(ccx: &mut CrateContext, t: ty::t) -> @str {
|
||||||
match ccx.type_hashcodes.find(&t) {
|
match ccx.type_hashcodes.find(&t) {
|
||||||
Some(&h) => h,
|
Some(&h) => h,
|
||||||
None => {
|
None => {
|
||||||
let hash = symbol_hash(ccx.tcx, ccx.symbol_hasher, t, ccx.link_meta);
|
let hash = symbol_hash(ccx.tcx, &mut ccx.symbol_hasher, t, ccx.link_meta);
|
||||||
ccx.type_hashcodes.insert(t, hash);
|
ccx.type_hashcodes.insert(t, hash);
|
||||||
hash
|
hash
|
||||||
}
|
}
|
||||||
@ -705,7 +705,7 @@ pub fn exported_name(sess: Session,
|
|||||||
path_name(sess.ident_of(vers))));
|
path_name(sess.ident_of(vers))));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_exported_name(ccx: @CrateContext,
|
pub fn mangle_exported_name(ccx: &mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
t: ty::t) -> ~str {
|
t: ty::t) -> ~str {
|
||||||
let hash = get_symbol_hash(ccx, t);
|
let hash = get_symbol_hash(ccx, t);
|
||||||
@ -714,7 +714,7 @@ pub fn mangle_exported_name(ccx: @CrateContext,
|
|||||||
ccx.link_meta.vers);
|
ccx.link_meta.vers);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_internal_name_by_type_only(ccx: @CrateContext,
|
pub fn mangle_internal_name_by_type_only(ccx: &mut CrateContext,
|
||||||
t: ty::t,
|
t: ty::t,
|
||||||
name: &str) -> ~str {
|
name: &str) -> ~str {
|
||||||
let s = ppaux::ty_to_short_str(ccx.tcx, t);
|
let s = ppaux::ty_to_short_str(ccx.tcx, t);
|
||||||
@ -725,7 +725,7 @@ pub fn mangle_internal_name_by_type_only(ccx: @CrateContext,
|
|||||||
path_name(ccx.sess.ident_of(hash))]);
|
path_name(ccx.sess.ident_of(hash))]);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_internal_name_by_type_and_seq(ccx: @CrateContext,
|
pub fn mangle_internal_name_by_type_and_seq(ccx: &mut CrateContext,
|
||||||
t: ty::t,
|
t: ty::t,
|
||||||
name: &str) -> ~str {
|
name: &str) -> ~str {
|
||||||
let s = ppaux::ty_to_str(ccx.tcx, t);
|
let s = ppaux::ty_to_str(ccx.tcx, t);
|
||||||
@ -736,18 +736,18 @@ pub fn mangle_internal_name_by_type_and_seq(ccx: @CrateContext,
|
|||||||
path_name((ccx.names)(name))]);
|
path_name((ccx.names)(name))]);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_internal_name_by_path_and_seq(ccx: @CrateContext,
|
pub fn mangle_internal_name_by_path_and_seq(ccx: &mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
flav: &str) -> ~str {
|
flav: &str) -> ~str {
|
||||||
return mangle(ccx.sess,
|
return mangle(ccx.sess,
|
||||||
vec::append_one(path, path_name((ccx.names)(flav))));
|
vec::append_one(path, path_name((ccx.names)(flav))));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_internal_name_by_path(ccx: @CrateContext, path: path) -> ~str {
|
pub fn mangle_internal_name_by_path(ccx: &mut CrateContext, path: path) -> ~str {
|
||||||
return mangle(ccx.sess, path);
|
return mangle(ccx.sess, path);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mangle_internal_name_by_seq(ccx: @CrateContext, flav: &str) -> ~str {
|
pub fn mangle_internal_name_by_seq(ccx: &mut CrateContext, flav: &str) -> ~str {
|
||||||
return fmt!("%s_%u", flav, (ccx.names)(flav).name);
|
return fmt!("%s_%u", flav, (ccx.names)(flav).name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,24 +47,26 @@ use syntax::parse::token;
|
|||||||
use syntax;
|
use syntax;
|
||||||
use writer = extra::ebml::writer;
|
use writer = extra::ebml::writer;
|
||||||
|
|
||||||
|
use core::cast;
|
||||||
|
|
||||||
// used by astencode:
|
// used by astencode:
|
||||||
type abbrev_map = @mut HashMap<ty::t, tyencode::ty_abbrev>;
|
type abbrev_map = @mut HashMap<ty::t, tyencode::ty_abbrev>;
|
||||||
|
|
||||||
pub type encode_inlined_item = @fn(ecx: @EncodeContext,
|
pub type encode_inlined_item<'self> = &'self fn(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
path: &[ast_map::path_elt],
|
path: &[ast_map::path_elt],
|
||||||
ii: ast::inlined_item);
|
ii: ast::inlined_item);
|
||||||
|
|
||||||
pub struct EncodeParams {
|
pub struct EncodeParams<'self> {
|
||||||
diag: @span_handler,
|
diag: @span_handler,
|
||||||
tcx: ty::ctxt,
|
tcx: ty::ctxt,
|
||||||
reachable: reachable::map,
|
reachable: reachable::map,
|
||||||
reexports2: middle::resolve::ExportMap2,
|
reexports2: middle::resolve::ExportMap2,
|
||||||
item_symbols: @mut HashMap<ast::node_id, ~str>,
|
item_symbols: &'self HashMap<ast::node_id, ~str>,
|
||||||
discrim_symbols: @mut HashMap<ast::node_id, @str>,
|
discrim_symbols: &'self HashMap<ast::node_id, @str>,
|
||||||
link_meta: LinkMeta,
|
link_meta: &'self LinkMeta,
|
||||||
cstore: @mut cstore::CStore,
|
cstore: @mut cstore::CStore,
|
||||||
encode_inlined_item: encode_inlined_item
|
encode_inlined_item: encode_inlined_item<'self>
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Stats {
|
struct Stats {
|
||||||
@ -81,31 +83,31 @@ struct Stats {
|
|||||||
n_inlines: uint
|
n_inlines: uint
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct EncodeContext {
|
pub struct EncodeContext<'self> {
|
||||||
diag: @span_handler,
|
diag: @span_handler,
|
||||||
tcx: ty::ctxt,
|
tcx: ty::ctxt,
|
||||||
stats: @mut Stats,
|
stats: @mut Stats,
|
||||||
reachable: reachable::map,
|
reachable: reachable::map,
|
||||||
reexports2: middle::resolve::ExportMap2,
|
reexports2: middle::resolve::ExportMap2,
|
||||||
item_symbols: @mut HashMap<ast::node_id, ~str>,
|
item_symbols: &'self HashMap<ast::node_id, ~str>,
|
||||||
discrim_symbols: @mut HashMap<ast::node_id, @str>,
|
discrim_symbols: &'self HashMap<ast::node_id, @str>,
|
||||||
link_meta: LinkMeta,
|
link_meta: &'self LinkMeta,
|
||||||
cstore: @mut cstore::CStore,
|
cstore: &'self cstore::CStore,
|
||||||
encode_inlined_item: encode_inlined_item,
|
encode_inlined_item: encode_inlined_item<'self>,
|
||||||
type_abbrevs: abbrev_map
|
type_abbrevs: abbrev_map
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn reachable(ecx: @EncodeContext, id: node_id) -> bool {
|
pub fn reachable(ecx: &EncodeContext, id: node_id) -> bool {
|
||||||
ecx.reachable.contains(&id)
|
ecx.reachable.contains(&id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_name(ecx: @EncodeContext,
|
fn encode_name(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
name: ident) {
|
name: ident) {
|
||||||
ebml_w.wr_tagged_str(tag_paths_data_name, ecx.tcx.sess.str_of(name));
|
ebml_w.wr_tagged_str(tag_paths_data_name, ecx.tcx.sess.str_of(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_impl_type_basename(ecx: @EncodeContext,
|
fn encode_impl_type_basename(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
name: ident) {
|
name: ident) {
|
||||||
ebml_w.wr_tagged_str(tag_item_impl_type_basename,
|
ebml_w.wr_tagged_str(tag_item_impl_type_basename,
|
||||||
@ -116,7 +118,7 @@ pub fn encode_def_id(ebml_w: &mut writer::Encoder, id: def_id) {
|
|||||||
ebml_w.wr_tagged_str(tag_def_id, def_to_str(id));
|
ebml_w.wr_tagged_str(tag_def_id, def_to_str(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_region_param(ecx: @EncodeContext,
|
fn encode_region_param(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
it: @ast::item) {
|
it: @ast::item) {
|
||||||
let opt_rp = ecx.tcx.region_paramd_items.find(&it.id);
|
let opt_rp = ecx.tcx.region_paramd_items.find(&it.id);
|
||||||
@ -147,14 +149,15 @@ fn add_to_index(ebml_w: &mut writer::Encoder,
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn encode_trait_ref(ebml_w: &mut writer::Encoder,
|
fn encode_trait_ref(ebml_w: &mut writer::Encoder,
|
||||||
ecx: @EncodeContext,
|
ecx: &EncodeContext,
|
||||||
trait_ref: &ty::TraitRef,
|
trait_ref: &ty::TraitRef,
|
||||||
tag: uint) {
|
tag: uint) {
|
||||||
|
let r = ecx.reachable;
|
||||||
let ty_str_ctxt = @tyencode::ctxt {
|
let ty_str_ctxt = @tyencode::ctxt {
|
||||||
diag: ecx.diag,
|
diag: ecx.diag,
|
||||||
ds: def_to_str,
|
ds: def_to_str,
|
||||||
tcx: ecx.tcx,
|
tcx: ecx.tcx,
|
||||||
reachable: |a| reachable(ecx, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
||||||
|
|
||||||
ebml_w.start_tag(tag);
|
ebml_w.start_tag(tag);
|
||||||
@ -174,14 +177,15 @@ pub fn def_to_str(did: def_id) -> ~str {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn encode_ty_type_param_defs(ebml_w: &mut writer::Encoder,
|
fn encode_ty_type_param_defs(ebml_w: &mut writer::Encoder,
|
||||||
ecx: @EncodeContext,
|
ecx: &EncodeContext,
|
||||||
params: @~[ty::TypeParameterDef],
|
params: @~[ty::TypeParameterDef],
|
||||||
tag: uint) {
|
tag: uint) {
|
||||||
|
let r = ecx.reachable;
|
||||||
let ty_str_ctxt = @tyencode::ctxt {
|
let ty_str_ctxt = @tyencode::ctxt {
|
||||||
diag: ecx.diag,
|
diag: ecx.diag,
|
||||||
ds: def_to_str,
|
ds: def_to_str,
|
||||||
tcx: ecx.tcx,
|
tcx: ecx.tcx,
|
||||||
reachable: |a| reachable(ecx, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
||||||
for params.each |param| {
|
for params.each |param| {
|
||||||
ebml_w.start_tag(tag);
|
ebml_w.start_tag(tag);
|
||||||
@ -191,7 +195,7 @@ fn encode_ty_type_param_defs(ebml_w: &mut writer::Encoder,
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn encode_type_param_bounds(ebml_w: &mut writer::Encoder,
|
fn encode_type_param_bounds(ebml_w: &mut writer::Encoder,
|
||||||
ecx: @EncodeContext,
|
ecx: &EncodeContext,
|
||||||
params: &OptVec<TyParam>) {
|
params: &OptVec<TyParam>) {
|
||||||
let ty_param_defs =
|
let ty_param_defs =
|
||||||
@params.map_to_vec(|param| ecx.tcx.ty_param_defs.get_copy(¶m.id));
|
@params.map_to_vec(|param| ecx.tcx.ty_param_defs.get_copy(¶m.id));
|
||||||
@ -206,31 +210,33 @@ fn encode_variant_id(ebml_w: &mut writer::Encoder, vid: def_id) {
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn write_type(ecx: @EncodeContext,
|
pub fn write_type(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
typ: ty::t) {
|
typ: ty::t) {
|
||||||
|
let r = ecx.reachable;
|
||||||
let ty_str_ctxt = @tyencode::ctxt {
|
let ty_str_ctxt = @tyencode::ctxt {
|
||||||
diag: ecx.diag,
|
diag: ecx.diag,
|
||||||
ds: def_to_str,
|
ds: def_to_str,
|
||||||
tcx: ecx.tcx,
|
tcx: ecx.tcx,
|
||||||
reachable: |a| reachable(ecx, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
||||||
tyencode::enc_ty(ebml_w.writer, ty_str_ctxt, typ);
|
tyencode::enc_ty(ebml_w.writer, ty_str_ctxt, typ);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn write_vstore(ecx: @EncodeContext,
|
pub fn write_vstore(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
vstore: ty::vstore) {
|
vstore: ty::vstore) {
|
||||||
|
let r = ecx.reachable;
|
||||||
let ty_str_ctxt = @tyencode::ctxt {
|
let ty_str_ctxt = @tyencode::ctxt {
|
||||||
diag: ecx.diag,
|
diag: ecx.diag,
|
||||||
ds: def_to_str,
|
ds: def_to_str,
|
||||||
tcx: ecx.tcx,
|
tcx: ecx.tcx,
|
||||||
reachable: |a| reachable(ecx, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
||||||
tyencode::enc_vstore(ebml_w.writer, ty_str_ctxt, vstore);
|
tyencode::enc_vstore(ebml_w.writer, ty_str_ctxt, vstore);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_type(ecx: @EncodeContext,
|
fn encode_type(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
typ: ty::t) {
|
typ: ty::t) {
|
||||||
ebml_w.start_tag(tag_items_data_item_type);
|
ebml_w.start_tag(tag_items_data_item_type);
|
||||||
@ -238,7 +244,7 @@ fn encode_type(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_transformed_self_ty(ecx: @EncodeContext,
|
fn encode_transformed_self_ty(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
opt_typ: Option<ty::t>) {
|
opt_typ: Option<ty::t>) {
|
||||||
for opt_typ.iter().advance |&typ| {
|
for opt_typ.iter().advance |&typ| {
|
||||||
@ -248,23 +254,24 @@ fn encode_transformed_self_ty(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_method_fty(ecx: @EncodeContext,
|
fn encode_method_fty(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
typ: &ty::BareFnTy) {
|
typ: &ty::BareFnTy) {
|
||||||
ebml_w.start_tag(tag_item_method_fty);
|
ebml_w.start_tag(tag_item_method_fty);
|
||||||
|
|
||||||
|
let r = ecx.reachable;
|
||||||
let ty_str_ctxt = @tyencode::ctxt {
|
let ty_str_ctxt = @tyencode::ctxt {
|
||||||
diag: ecx.diag,
|
diag: ecx.diag,
|
||||||
ds: def_to_str,
|
ds: def_to_str,
|
||||||
tcx: ecx.tcx,
|
tcx: ecx.tcx,
|
||||||
reachable: |a| reachable(ecx, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
abbrevs: tyencode::ac_use_abbrevs(ecx.type_abbrevs)};
|
||||||
tyencode::enc_bare_fn_ty(ebml_w.writer, ty_str_ctxt, typ);
|
tyencode::enc_bare_fn_ty(ebml_w.writer, ty_str_ctxt, typ);
|
||||||
|
|
||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_symbol(ecx: @EncodeContext,
|
fn encode_symbol(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
id: node_id) {
|
id: node_id) {
|
||||||
ebml_w.start_tag(tag_items_data_item_symbol);
|
ebml_w.start_tag(tag_items_data_item_symbol);
|
||||||
@ -281,7 +288,7 @@ fn encode_symbol(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_discriminant(ecx: @EncodeContext,
|
fn encode_discriminant(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
id: node_id) {
|
id: node_id) {
|
||||||
ebml_w.start_tag(tag_items_data_item_symbol);
|
ebml_w.start_tag(tag_items_data_item_symbol);
|
||||||
@ -289,7 +296,7 @@ fn encode_discriminant(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_disr_val(_: @EncodeContext,
|
fn encode_disr_val(_: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
disr_val: int) {
|
disr_val: int) {
|
||||||
ebml_w.start_tag(tag_disr_val);
|
ebml_w.start_tag(tag_disr_val);
|
||||||
@ -305,7 +312,7 @@ fn encode_parent_item(ebml_w: &mut writer::Encoder, id: def_id) {
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_enum_variant_info(ecx: @EncodeContext,
|
fn encode_enum_variant_info(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
id: node_id,
|
id: node_id,
|
||||||
variants: &[variant],
|
variants: &[variant],
|
||||||
@ -349,11 +356,11 @@ fn encode_enum_variant_info(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_path(ecx: @EncodeContext,
|
fn encode_path(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
path: &[ast_map::path_elt],
|
path: &[ast_map::path_elt],
|
||||||
name: ast_map::path_elt) {
|
name: ast_map::path_elt) {
|
||||||
fn encode_path_elt(ecx: @EncodeContext,
|
fn encode_path_elt(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
elt: ast_map::path_elt) {
|
elt: ast_map::path_elt) {
|
||||||
let (tag, name) = match elt {
|
let (tag, name) = match elt {
|
||||||
@ -373,7 +380,7 @@ fn encode_path(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_reexported_static_method(ecx: @EncodeContext,
|
fn encode_reexported_static_method(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
exp: &middle::resolve::Export2,
|
exp: &middle::resolve::Export2,
|
||||||
method_def_id: def_id,
|
method_def_id: def_id,
|
||||||
@ -390,7 +397,7 @@ fn encode_reexported_static_method(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_reexported_static_base_methods(ecx: @EncodeContext,
|
fn encode_reexported_static_base_methods(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
exp: &middle::resolve::Export2)
|
exp: &middle::resolve::Export2)
|
||||||
-> bool {
|
-> bool {
|
||||||
@ -411,7 +418,7 @@ fn encode_reexported_static_base_methods(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_reexported_static_trait_methods(ecx: @EncodeContext,
|
fn encode_reexported_static_trait_methods(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
exp: &middle::resolve::Export2)
|
exp: &middle::resolve::Export2)
|
||||||
-> bool {
|
-> bool {
|
||||||
@ -430,7 +437,7 @@ fn encode_reexported_static_trait_methods(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_reexported_static_methods(ecx: @EncodeContext,
|
fn encode_reexported_static_methods(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
mod_path: &[ast_map::path_elt],
|
mod_path: &[ast_map::path_elt],
|
||||||
exp: &middle::resolve::Export2) {
|
exp: &middle::resolve::Export2) {
|
||||||
@ -466,7 +473,7 @@ fn encode_reexported_static_methods(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_mod(ecx: @EncodeContext,
|
fn encode_info_for_mod(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
md: &_mod,
|
md: &_mod,
|
||||||
id: node_id,
|
id: node_id,
|
||||||
@ -598,7 +605,7 @@ fn encode_method_sort(ebml_w: &mut writer::Encoder, sort: char) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Returns an index of items in this class */
|
/* Returns an index of items in this class */
|
||||||
fn encode_info_for_struct(ecx: @EncodeContext,
|
fn encode_info_for_struct(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
path: &[ast_map::path_elt],
|
path: &[ast_map::path_elt],
|
||||||
fields: &[@struct_field],
|
fields: &[@struct_field],
|
||||||
@ -633,7 +640,7 @@ fn encode_info_for_struct(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This is for encoding info for ctors and dtors
|
// This is for encoding info for ctors and dtors
|
||||||
fn encode_info_for_ctor(ecx: @EncodeContext,
|
fn encode_info_for_ctor(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
id: node_id,
|
id: node_id,
|
||||||
ident: ident,
|
ident: ident,
|
||||||
@ -662,7 +669,7 @@ fn encode_info_for_ctor(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_struct_ctor(ecx: @EncodeContext,
|
fn encode_info_for_struct_ctor(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
path: &[ast_map::path_elt],
|
path: &[ast_map::path_elt],
|
||||||
name: ast::ident,
|
name: ast::ident,
|
||||||
@ -684,7 +691,7 @@ fn encode_info_for_struct_ctor(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_method_ty_fields(ecx: @EncodeContext,
|
fn encode_method_ty_fields(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
method_ty: &ty::Method) {
|
method_ty: &ty::Method) {
|
||||||
encode_def_id(ebml_w, method_ty.def_id);
|
encode_def_id(ebml_w, method_ty.def_id);
|
||||||
@ -698,7 +705,7 @@ fn encode_method_ty_fields(ecx: @EncodeContext,
|
|||||||
encode_explicit_self(ebml_w, method_ty.explicit_self);
|
encode_explicit_self(ebml_w, method_ty.explicit_self);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_method(ecx: @EncodeContext,
|
fn encode_info_for_method(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
impl_path: &[ast_map::path_elt],
|
impl_path: &[ast_map::path_elt],
|
||||||
should_inline: bool,
|
should_inline: bool,
|
||||||
@ -769,7 +776,7 @@ fn should_inline(attrs: &[attribute]) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_item(ecx: @EncodeContext,
|
fn encode_info_for_item(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
item: @item,
|
item: @item,
|
||||||
index: @mut ~[entry<int>],
|
index: @mut ~[entry<int>],
|
||||||
@ -1075,7 +1082,7 @@ fn encode_info_for_item(ecx: @EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_foreign_item(ecx: @EncodeContext,
|
fn encode_info_for_foreign_item(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
nitem: @foreign_item,
|
nitem: @foreign_item,
|
||||||
index: @mut ~[entry<int>],
|
index: @mut ~[entry<int>],
|
||||||
@ -1109,7 +1116,7 @@ fn encode_info_for_foreign_item(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_info_for_items(ecx: @EncodeContext,
|
fn encode_info_for_items(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
crate: &crate)
|
crate: &crate)
|
||||||
-> ~[entry<int>] {
|
-> ~[entry<int>] {
|
||||||
@ -1119,15 +1126,22 @@ fn encode_info_for_items(ecx: @EncodeContext,
|
|||||||
encode_info_for_mod(ecx, ebml_w, &crate.node.module,
|
encode_info_for_mod(ecx, ebml_w, &crate.node.module,
|
||||||
crate_node_id, [],
|
crate_node_id, [],
|
||||||
syntax::parse::token::special_idents::invalid);
|
syntax::parse::token::special_idents::invalid);
|
||||||
|
let items = ecx.tcx.items;
|
||||||
|
|
||||||
|
// See comment in `encode_side_tables_for_ii` in astencode
|
||||||
|
let ecx_ptr : *() = unsafe { cast::transmute(ecx) };
|
||||||
|
|
||||||
visit::visit_crate(crate, ((), visit::mk_vt(@visit::Visitor {
|
visit::visit_crate(crate, ((), visit::mk_vt(@visit::Visitor {
|
||||||
visit_expr: |_e, (_cx, _v)| { },
|
visit_expr: |_e, (_cx, _v)| { },
|
||||||
visit_item: {
|
visit_item: {
|
||||||
let ebml_w = copy *ebml_w;
|
let ebml_w = copy *ebml_w;
|
||||||
|i, (cx, v)| {
|
|i, (cx, v)| {
|
||||||
visit::visit_item(i, (cx, v));
|
visit::visit_item(i, (cx, v));
|
||||||
match ecx.tcx.items.get_copy(&i.id) {
|
match items.get_copy(&i.id) {
|
||||||
ast_map::node_item(_, pt) => {
|
ast_map::node_item(_, pt) => {
|
||||||
let mut ebml_w = copy ebml_w;
|
let mut ebml_w = copy ebml_w;
|
||||||
|
// See above
|
||||||
|
let ecx : &EncodeContext = unsafe { cast::transmute(ecx_ptr) };
|
||||||
encode_info_for_item(ecx, &mut ebml_w, i, index, *pt);
|
encode_info_for_item(ecx, &mut ebml_w, i, index, *pt);
|
||||||
}
|
}
|
||||||
_ => fail!("bad item")
|
_ => fail!("bad item")
|
||||||
@ -1138,9 +1152,11 @@ fn encode_info_for_items(ecx: @EncodeContext,
|
|||||||
let ebml_w = copy *ebml_w;
|
let ebml_w = copy *ebml_w;
|
||||||
|ni, (cx, v)| {
|
|ni, (cx, v)| {
|
||||||
visit::visit_foreign_item(ni, (cx, v));
|
visit::visit_foreign_item(ni, (cx, v));
|
||||||
match ecx.tcx.items.get_copy(&ni.id) {
|
match items.get_copy(&ni.id) {
|
||||||
ast_map::node_foreign_item(_, abi, _, pt) => {
|
ast_map::node_foreign_item(_, abi, _, pt) => {
|
||||||
let mut ebml_w = copy ebml_w;
|
let mut ebml_w = copy ebml_w;
|
||||||
|
// See above
|
||||||
|
let ecx : &EncodeContext = unsafe { cast::transmute(ecx_ptr) };
|
||||||
encode_info_for_foreign_item(ecx,
|
encode_info_for_foreign_item(ecx,
|
||||||
&mut ebml_w,
|
&mut ebml_w,
|
||||||
ni,
|
ni,
|
||||||
@ -1267,10 +1283,10 @@ fn encode_attributes(ebml_w: &mut writer::Encoder, attrs: &[attribute]) {
|
|||||||
// metadata that Rust cares about for linking crates. This attribute requires
|
// metadata that Rust cares about for linking crates. This attribute requires
|
||||||
// 'name' and 'vers' items, so if the user didn't provide them we will throw
|
// 'name' and 'vers' items, so if the user didn't provide them we will throw
|
||||||
// them in anyway with default values.
|
// them in anyway with default values.
|
||||||
fn synthesize_crate_attrs(ecx: @EncodeContext,
|
fn synthesize_crate_attrs(ecx: &EncodeContext,
|
||||||
crate: &crate) -> ~[attribute] {
|
crate: &crate) -> ~[attribute] {
|
||||||
|
|
||||||
fn synthesize_link_attr(ecx: @EncodeContext, items: ~[@meta_item]) ->
|
fn synthesize_link_attr(ecx: &EncodeContext, items: ~[@meta_item]) ->
|
||||||
attribute {
|
attribute {
|
||||||
|
|
||||||
assert!(!ecx.link_meta.name.is_empty());
|
assert!(!ecx.link_meta.name.is_empty());
|
||||||
@ -1317,10 +1333,10 @@ fn synthesize_crate_attrs(ecx: @EncodeContext,
|
|||||||
return attrs;
|
return attrs;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_crate_deps(ecx: @EncodeContext,
|
fn encode_crate_deps(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
cstore: @mut cstore::CStore) {
|
cstore: &cstore::CStore) {
|
||||||
fn get_ordered_deps(ecx: @EncodeContext, cstore: @mut cstore::CStore)
|
fn get_ordered_deps(ecx: &EncodeContext, cstore: &cstore::CStore)
|
||||||
-> ~[decoder::crate_dep] {
|
-> ~[decoder::crate_dep] {
|
||||||
type numdep = decoder::crate_dep;
|
type numdep = decoder::crate_dep;
|
||||||
|
|
||||||
@ -1359,7 +1375,7 @@ fn encode_crate_deps(ecx: @EncodeContext,
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_lang_items(ecx: @EncodeContext, ebml_w: &mut writer::Encoder) {
|
fn encode_lang_items(ecx: &EncodeContext, ebml_w: &mut writer::Encoder) {
|
||||||
ebml_w.start_tag(tag_lang_items);
|
ebml_w.start_tag(tag_lang_items);
|
||||||
|
|
||||||
for ecx.tcx.lang_items.each_item |def_id, i| {
|
for ecx.tcx.lang_items.each_item |def_id, i| {
|
||||||
@ -1383,7 +1399,7 @@ fn encode_lang_items(ecx: @EncodeContext, ebml_w: &mut writer::Encoder) {
|
|||||||
ebml_w.end_tag(); // tag_lang_items
|
ebml_w.end_tag(); // tag_lang_items
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_link_args(ecx: @EncodeContext, ebml_w: &mut writer::Encoder) {
|
fn encode_link_args(ecx: &EncodeContext, ebml_w: &mut writer::Encoder) {
|
||||||
ebml_w.start_tag(tag_link_args);
|
ebml_w.start_tag(tag_link_args);
|
||||||
|
|
||||||
let link_args = cstore::get_used_link_args(ecx.cstore);
|
let link_args = cstore::get_used_link_args(ecx.cstore);
|
||||||
@ -1396,7 +1412,7 @@ fn encode_link_args(ecx: @EncodeContext, ebml_w: &mut writer::Encoder) {
|
|||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_crate_dep(ecx: @EncodeContext,
|
fn encode_crate_dep(ecx: &EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
dep: decoder::crate_dep) {
|
dep: decoder::crate_dep) {
|
||||||
ebml_w.start_tag(tag_crate_dep);
|
ebml_w.start_tag(tag_crate_dep);
|
||||||
@ -1444,10 +1460,12 @@ pub fn encode_metadata(parms: EncodeParams, crate: &crate) -> ~[u8] {
|
|||||||
let EncodeParams{item_symbols, diag, tcx, reachable, reexports2,
|
let EncodeParams{item_symbols, diag, tcx, reachable, reexports2,
|
||||||
discrim_symbols, cstore, encode_inlined_item,
|
discrim_symbols, cstore, encode_inlined_item,
|
||||||
link_meta, _} = parms;
|
link_meta, _} = parms;
|
||||||
let ecx = @EncodeContext {
|
let type_abbrevs = @mut HashMap::new();
|
||||||
|
let stats = @mut stats;
|
||||||
|
let ecx = EncodeContext {
|
||||||
diag: diag,
|
diag: diag,
|
||||||
tcx: tcx,
|
tcx: tcx,
|
||||||
stats: @mut stats,
|
stats: stats,
|
||||||
reachable: reachable,
|
reachable: reachable,
|
||||||
reexports2: reexports2,
|
reexports2: reexports2,
|
||||||
item_symbols: item_symbols,
|
item_symbols: item_symbols,
|
||||||
@ -1455,7 +1473,7 @@ pub fn encode_metadata(parms: EncodeParams, crate: &crate) -> ~[u8] {
|
|||||||
link_meta: link_meta,
|
link_meta: link_meta,
|
||||||
cstore: cstore,
|
cstore: cstore,
|
||||||
encode_inlined_item: encode_inlined_item,
|
encode_inlined_item: encode_inlined_item,
|
||||||
type_abbrevs: @mut HashMap::new()
|
type_abbrevs: type_abbrevs
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut ebml_w = writer::Encoder(wr as @io::Writer);
|
let mut ebml_w = writer::Encoder(wr as @io::Writer);
|
||||||
@ -1463,28 +1481,28 @@ pub fn encode_metadata(parms: EncodeParams, crate: &crate) -> ~[u8] {
|
|||||||
encode_hash(&mut ebml_w, ecx.link_meta.extras_hash);
|
encode_hash(&mut ebml_w, ecx.link_meta.extras_hash);
|
||||||
|
|
||||||
let mut i = *wr.pos;
|
let mut i = *wr.pos;
|
||||||
let crate_attrs = synthesize_crate_attrs(ecx, crate);
|
let crate_attrs = synthesize_crate_attrs(&ecx, crate);
|
||||||
encode_attributes(&mut ebml_w, crate_attrs);
|
encode_attributes(&mut ebml_w, crate_attrs);
|
||||||
ecx.stats.attr_bytes = *wr.pos - i;
|
ecx.stats.attr_bytes = *wr.pos - i;
|
||||||
|
|
||||||
i = *wr.pos;
|
i = *wr.pos;
|
||||||
encode_crate_deps(ecx, &mut ebml_w, ecx.cstore);
|
encode_crate_deps(&ecx, &mut ebml_w, ecx.cstore);
|
||||||
ecx.stats.dep_bytes = *wr.pos - i;
|
ecx.stats.dep_bytes = *wr.pos - i;
|
||||||
|
|
||||||
// Encode the language items.
|
// Encode the language items.
|
||||||
i = *wr.pos;
|
i = *wr.pos;
|
||||||
encode_lang_items(ecx, &mut ebml_w);
|
encode_lang_items(&ecx, &mut ebml_w);
|
||||||
ecx.stats.lang_item_bytes = *wr.pos - i;
|
ecx.stats.lang_item_bytes = *wr.pos - i;
|
||||||
|
|
||||||
// Encode the link args.
|
// Encode the link args.
|
||||||
i = *wr.pos;
|
i = *wr.pos;
|
||||||
encode_link_args(ecx, &mut ebml_w);
|
encode_link_args(&ecx, &mut ebml_w);
|
||||||
ecx.stats.link_args_bytes = *wr.pos - i;
|
ecx.stats.link_args_bytes = *wr.pos - i;
|
||||||
|
|
||||||
// Encode and index the items.
|
// Encode and index the items.
|
||||||
ebml_w.start_tag(tag_items);
|
ebml_w.start_tag(tag_items);
|
||||||
i = *wr.pos;
|
i = *wr.pos;
|
||||||
let items_index = encode_info_for_items(ecx, &mut ebml_w, crate);
|
let items_index = encode_info_for_items(&ecx, &mut ebml_w, crate);
|
||||||
ecx.stats.item_bytes = *wr.pos - i;
|
ecx.stats.item_bytes = *wr.pos - i;
|
||||||
|
|
||||||
i = *wr.pos;
|
i = *wr.pos;
|
||||||
|
@ -44,6 +44,8 @@ use syntax::parse::token;
|
|||||||
use syntax;
|
use syntax;
|
||||||
use writer = extra::ebml::writer;
|
use writer = extra::ebml::writer;
|
||||||
|
|
||||||
|
use core::cast;
|
||||||
|
|
||||||
#[cfg(test)] use syntax::parse;
|
#[cfg(test)] use syntax::parse;
|
||||||
#[cfg(test)] use syntax::print::pprust;
|
#[cfg(test)] use syntax::print::pprust;
|
||||||
|
|
||||||
@ -80,7 +82,7 @@ trait tr_intern {
|
|||||||
// ______________________________________________________________________
|
// ______________________________________________________________________
|
||||||
// Top-level methods.
|
// Top-level methods.
|
||||||
|
|
||||||
pub fn encode_inlined_item(ecx: @e::EncodeContext,
|
pub fn encode_inlined_item(ecx: &e::EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
path: &[ast_map::path_elt],
|
path: &[ast_map::path_elt],
|
||||||
ii: ast::inlined_item,
|
ii: ast::inlined_item,
|
||||||
@ -527,7 +529,7 @@ trait read_method_map_entry_helper {
|
|||||||
-> method_map_entry;
|
-> method_map_entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_method_map_entry(ecx: @e::EncodeContext,
|
fn encode_method_map_entry(ecx: &e::EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
mme: method_map_entry) {
|
mme: method_map_entry) {
|
||||||
do ebml_w.emit_struct("method_map_entry", 3) |ebml_w| {
|
do ebml_w.emit_struct("method_map_entry", 3) |ebml_w| {
|
||||||
@ -604,7 +606,7 @@ impl tr for method_origin {
|
|||||||
// ______________________________________________________________________
|
// ______________________________________________________________________
|
||||||
// Encoding and decoding vtable_res
|
// Encoding and decoding vtable_res
|
||||||
|
|
||||||
fn encode_vtable_res(ecx: @e::EncodeContext,
|
fn encode_vtable_res(ecx: &e::EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
dr: typeck::vtable_res) {
|
dr: typeck::vtable_res) {
|
||||||
// can't autogenerate this code because automatic code of
|
// can't autogenerate this code because automatic code of
|
||||||
@ -616,7 +618,7 @@ fn encode_vtable_res(ecx: @e::EncodeContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_vtable_origin(ecx: @e::EncodeContext,
|
fn encode_vtable_origin(ecx: &e::EncodeContext,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
vtable_origin: &typeck::vtable_origin) {
|
vtable_origin: &typeck::vtable_origin) {
|
||||||
do ebml_w.emit_enum("vtable_origin") |ebml_w| {
|
do ebml_w.emit_enum("vtable_origin") |ebml_w| {
|
||||||
@ -702,53 +704,53 @@ impl vtable_decoder_helpers for reader::Decoder {
|
|||||||
// Encoding and decoding the side tables
|
// Encoding and decoding the side tables
|
||||||
|
|
||||||
trait get_ty_str_ctxt {
|
trait get_ty_str_ctxt {
|
||||||
fn ty_str_ctxt(@self) -> @tyencode::ctxt;
|
fn ty_str_ctxt(&self) -> @tyencode::ctxt;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl get_ty_str_ctxt for e::EncodeContext {
|
impl<'self> get_ty_str_ctxt for e::EncodeContext<'self> {
|
||||||
// IMPLICIT SELF WARNING: fix this!
|
fn ty_str_ctxt(&self) -> @tyencode::ctxt {
|
||||||
fn ty_str_ctxt(@self) -> @tyencode::ctxt {
|
let r = self.reachable;
|
||||||
@tyencode::ctxt {diag: self.tcx.sess.diagnostic(),
|
@tyencode::ctxt {diag: self.tcx.sess.diagnostic(),
|
||||||
ds: e::def_to_str,
|
ds: e::def_to_str,
|
||||||
tcx: self.tcx,
|
tcx: self.tcx,
|
||||||
reachable: |a| encoder::reachable(self, a),
|
reachable: |a| r.contains(&a),
|
||||||
abbrevs: tyencode::ac_use_abbrevs(self.type_abbrevs)}
|
abbrevs: tyencode::ac_use_abbrevs(self.type_abbrevs)}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
trait ebml_writer_helpers {
|
trait ebml_writer_helpers {
|
||||||
fn emit_ty(&mut self, ecx: @e::EncodeContext, ty: ty::t);
|
fn emit_ty(&mut self, ecx: &e::EncodeContext, ty: ty::t);
|
||||||
fn emit_vstore(&mut self, ecx: @e::EncodeContext, vstore: ty::vstore);
|
fn emit_vstore(&mut self, ecx: &e::EncodeContext, vstore: ty::vstore);
|
||||||
fn emit_tys(&mut self, ecx: @e::EncodeContext, tys: &[ty::t]);
|
fn emit_tys(&mut self, ecx: &e::EncodeContext, tys: &[ty::t]);
|
||||||
fn emit_type_param_def(&mut self,
|
fn emit_type_param_def(&mut self,
|
||||||
ecx: @e::EncodeContext,
|
ecx: &e::EncodeContext,
|
||||||
type_param_def: &ty::TypeParameterDef);
|
type_param_def: &ty::TypeParameterDef);
|
||||||
fn emit_tpbt(&mut self,
|
fn emit_tpbt(&mut self,
|
||||||
ecx: @e::EncodeContext,
|
ecx: &e::EncodeContext,
|
||||||
tpbt: ty::ty_param_bounds_and_ty);
|
tpbt: ty::ty_param_bounds_and_ty);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ebml_writer_helpers for writer::Encoder {
|
impl ebml_writer_helpers for writer::Encoder {
|
||||||
fn emit_ty(&mut self, ecx: @e::EncodeContext, ty: ty::t) {
|
fn emit_ty(&mut self, ecx: &e::EncodeContext, ty: ty::t) {
|
||||||
do self.emit_opaque |this| {
|
do self.emit_opaque |this| {
|
||||||
e::write_type(ecx, this, ty)
|
e::write_type(ecx, this, ty)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn emit_vstore(&mut self, ecx: @e::EncodeContext, vstore: ty::vstore) {
|
fn emit_vstore(&mut self, ecx: &e::EncodeContext, vstore: ty::vstore) {
|
||||||
do self.emit_opaque |this| {
|
do self.emit_opaque |this| {
|
||||||
e::write_vstore(ecx, this, vstore)
|
e::write_vstore(ecx, this, vstore)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn emit_tys(&mut self, ecx: @e::EncodeContext, tys: &[ty::t]) {
|
fn emit_tys(&mut self, ecx: &e::EncodeContext, tys: &[ty::t]) {
|
||||||
do self.emit_from_vec(tys) |this, ty| {
|
do self.emit_from_vec(tys) |this, ty| {
|
||||||
this.emit_ty(ecx, *ty)
|
this.emit_ty(ecx, *ty)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn emit_type_param_def(&mut self,
|
fn emit_type_param_def(&mut self,
|
||||||
ecx: @e::EncodeContext,
|
ecx: &e::EncodeContext,
|
||||||
type_param_def: &ty::TypeParameterDef) {
|
type_param_def: &ty::TypeParameterDef) {
|
||||||
do self.emit_opaque |this| {
|
do self.emit_opaque |this| {
|
||||||
tyencode::enc_type_param_def(this.writer,
|
tyencode::enc_type_param_def(this.writer,
|
||||||
@ -758,7 +760,7 @@ impl ebml_writer_helpers for writer::Encoder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn emit_tpbt(&mut self,
|
fn emit_tpbt(&mut self,
|
||||||
ecx: @e::EncodeContext,
|
ecx: &e::EncodeContext,
|
||||||
tpbt: ty::ty_param_bounds_and_ty) {
|
tpbt: ty::ty_param_bounds_and_ty) {
|
||||||
do self.emit_struct("ty_param_bounds_and_ty", 2) |this| {
|
do self.emit_struct("ty_param_bounds_and_ty", 2) |this| {
|
||||||
do this.emit_struct_field("generics", 0) |this| {
|
do this.emit_struct_field("generics", 0) |this| {
|
||||||
@ -800,12 +802,18 @@ impl write_tag_and_id for writer::Encoder {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_side_tables_for_ii(ecx: @e::EncodeContext,
|
fn encode_side_tables_for_ii(ecx: &e::EncodeContext,
|
||||||
maps: Maps,
|
maps: Maps,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
ii: &ast::inlined_item) {
|
ii: &ast::inlined_item) {
|
||||||
ebml_w.start_tag(c::tag_table as uint);
|
ebml_w.start_tag(c::tag_table as uint);
|
||||||
let new_ebml_w = copy *ebml_w;
|
let new_ebml_w = copy *ebml_w;
|
||||||
|
|
||||||
|
// Because the ast visitor uses @fn, I can't pass in
|
||||||
|
// ecx directly, but /I/ know that it'll be fine since
|
||||||
|
// the lifetime is tied to the CrateContext that
|
||||||
|
// lives this entire section.
|
||||||
|
let ecx_ptr : *() = unsafe { cast::transmute(ecx) };
|
||||||
ast_util::visit_ids_for_inlined_item(
|
ast_util::visit_ids_for_inlined_item(
|
||||||
ii,
|
ii,
|
||||||
|id: ast::node_id| {
|
|id: ast::node_id| {
|
||||||
@ -813,12 +821,14 @@ fn encode_side_tables_for_ii(ecx: @e::EncodeContext,
|
|||||||
// it is mutable. But I believe it's harmless since we generate
|
// it is mutable. But I believe it's harmless since we generate
|
||||||
// balanced EBML.
|
// balanced EBML.
|
||||||
let mut new_ebml_w = copy new_ebml_w;
|
let mut new_ebml_w = copy new_ebml_w;
|
||||||
|
// See above
|
||||||
|
let ecx : &e::EncodeContext = unsafe { cast::transmute(ecx_ptr) };
|
||||||
encode_side_tables_for_id(ecx, maps, &mut new_ebml_w, id)
|
encode_side_tables_for_id(ecx, maps, &mut new_ebml_w, id)
|
||||||
});
|
});
|
||||||
ebml_w.end_tag();
|
ebml_w.end_tag();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_side_tables_for_id(ecx: @e::EncodeContext,
|
fn encode_side_tables_for_id(ecx: &e::EncodeContext,
|
||||||
maps: Maps,
|
maps: Maps,
|
||||||
ebml_w: &mut writer::Encoder,
|
ebml_w: &mut writer::Encoder,
|
||||||
id: ast::node_id) {
|
id: ast::node_id) {
|
||||||
|
@ -1314,7 +1314,7 @@ pub fn compile_submatch(bcx: block,
|
|||||||
|
|
||||||
let vals_left = vec::append(vec::slice(vals, 0u, col).to_vec(),
|
let vals_left = vec::append(vec::slice(vals, 0u, col).to_vec(),
|
||||||
vec::slice(vals, col + 1u, vals.len()));
|
vec::slice(vals, col + 1u, vals.len()));
|
||||||
let ccx = *bcx.fcx.ccx;
|
let ccx = bcx.fcx.ccx;
|
||||||
let mut pat_id = 0;
|
let mut pat_id = 0;
|
||||||
let mut pat_span = dummy_sp();
|
let mut pat_span = dummy_sp();
|
||||||
for m.each |br| {
|
for m.each |br| {
|
||||||
@ -1755,7 +1755,7 @@ pub fn bind_irrefutable_pat(bcx: block,
|
|||||||
binding_mode: IrrefutablePatternBindingMode)
|
binding_mode: IrrefutablePatternBindingMode)
|
||||||
-> block {
|
-> block {
|
||||||
let _icx = bcx.insn_ctxt("match::bind_irrefutable_pat");
|
let _icx = bcx.insn_ctxt("match::bind_irrefutable_pat");
|
||||||
let ccx = *bcx.fcx.ccx;
|
let ccx = bcx.fcx.ccx;
|
||||||
let mut bcx = bcx;
|
let mut bcx = bcx;
|
||||||
|
|
||||||
// Necessary since bind_irrefutable_pat is called outside trans_match
|
// Necessary since bind_irrefutable_pat is called outside trans_match
|
||||||
|
@ -111,7 +111,7 @@ pub fn represent_node(bcx: block, node: ast::node_id) -> @Repr {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Decides how to represent a given type.
|
/// Decides how to represent a given type.
|
||||||
pub fn represent_type(cx: @CrateContext, t: ty::t) -> @Repr {
|
pub fn represent_type(cx: &mut CrateContext, t: ty::t) -> @Repr {
|
||||||
debug!("Representing: %s", ty_to_str(cx.tcx, t));
|
debug!("Representing: %s", ty_to_str(cx.tcx, t));
|
||||||
match cx.adt_reprs.find(&t) {
|
match cx.adt_reprs.find(&t) {
|
||||||
Some(repr) => return *repr,
|
Some(repr) => return *repr,
|
||||||
@ -123,7 +123,7 @@ pub fn represent_type(cx: @CrateContext, t: ty::t) -> @Repr {
|
|||||||
return repr;
|
return repr;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn represent_type_uncached(cx: @CrateContext, t: ty::t) -> Repr {
|
fn represent_type_uncached(cx: &mut CrateContext, t: ty::t) -> Repr {
|
||||||
match ty::get(t).sty {
|
match ty::get(t).sty {
|
||||||
ty::ty_tup(ref elems) => {
|
ty::ty_tup(ref elems) => {
|
||||||
return Univariant(mk_struct(cx, *elems, false), false)
|
return Univariant(mk_struct(cx, *elems, false), false)
|
||||||
@ -142,7 +142,7 @@ fn represent_type_uncached(cx: @CrateContext, t: ty::t) -> Repr {
|
|||||||
ty::ty_enum(def_id, ref substs) => {
|
ty::ty_enum(def_id, ref substs) => {
|
||||||
struct Case { discr: int, tys: ~[ty::t] };
|
struct Case { discr: int, tys: ~[ty::t] };
|
||||||
impl Case {
|
impl Case {
|
||||||
fn is_zerolen(&self, cx: @CrateContext) -> bool {
|
fn is_zerolen(&self, cx: &mut CrateContext) -> bool {
|
||||||
mk_struct(cx, self.tys, false).size == 0
|
mk_struct(cx, self.tys, false).size == 0
|
||||||
}
|
}
|
||||||
fn find_ptr(&self) -> Option<uint> {
|
fn find_ptr(&self) -> Option<uint> {
|
||||||
@ -211,7 +211,7 @@ fn represent_type_uncached(cx: @CrateContext, t: ty::t) -> Repr {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn mk_struct(cx: @CrateContext, tys: &[ty::t], packed: bool) -> Struct {
|
fn mk_struct(cx: &mut CrateContext, tys: &[ty::t], packed: bool) -> Struct {
|
||||||
let lltys = tys.map(|&ty| type_of::sizing_type_of(cx, ty));
|
let lltys = tys.map(|&ty| type_of::sizing_type_of(cx, ty));
|
||||||
let llty_rec = T_struct(lltys, packed);
|
let llty_rec = T_struct(lltys, packed);
|
||||||
Struct {
|
Struct {
|
||||||
@ -227,14 +227,14 @@ fn mk_struct(cx: @CrateContext, tys: &[ty::t], packed: bool) -> Struct {
|
|||||||
* All nominal types are LLVM structs, in order to be able to use
|
* All nominal types are LLVM structs, in order to be able to use
|
||||||
* forward-declared opaque types to prevent circularity in `type_of`.
|
* forward-declared opaque types to prevent circularity in `type_of`.
|
||||||
*/
|
*/
|
||||||
pub fn fields_of(cx: @CrateContext, r: &Repr) -> ~[TypeRef] {
|
pub fn fields_of(cx: &mut CrateContext, r: &Repr) -> ~[TypeRef] {
|
||||||
generic_fields_of(cx, r, false)
|
generic_fields_of(cx, r, false)
|
||||||
}
|
}
|
||||||
/// Like `fields_of`, but for `type_of::sizing_type_of` (q.v.).
|
/// Like `fields_of`, but for `type_of::sizing_type_of` (q.v.).
|
||||||
pub fn sizing_fields_of(cx: @CrateContext, r: &Repr) -> ~[TypeRef] {
|
pub fn sizing_fields_of(cx: &mut CrateContext, r: &Repr) -> ~[TypeRef] {
|
||||||
generic_fields_of(cx, r, true)
|
generic_fields_of(cx, r, true)
|
||||||
}
|
}
|
||||||
fn generic_fields_of(cx: @CrateContext, r: &Repr, sizing: bool)
|
fn generic_fields_of(cx: &mut CrateContext, r: &Repr, sizing: bool)
|
||||||
-> ~[TypeRef] {
|
-> ~[TypeRef] {
|
||||||
match *r {
|
match *r {
|
||||||
CEnum(*) => ~[T_enum_discrim(cx)],
|
CEnum(*) => ~[T_enum_discrim(cx)],
|
||||||
@ -268,7 +268,7 @@ fn generic_fields_of(cx: @CrateContext, r: &Repr, sizing: bool)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn struct_llfields(cx: @CrateContext, st: &Struct, sizing: bool)
|
fn struct_llfields(cx: &mut CrateContext, st: &Struct, sizing: bool)
|
||||||
-> ~[TypeRef] {
|
-> ~[TypeRef] {
|
||||||
if sizing {
|
if sizing {
|
||||||
st.fields.map(|&ty| type_of::sizing_type_of(cx, ty))
|
st.fields.map(|&ty| type_of::sizing_type_of(cx, ty))
|
||||||
@ -454,9 +454,10 @@ fn struct_field_ptr(bcx: block, st: &Struct, val: ValueRef, ix: uint,
|
|||||||
let ccx = bcx.ccx();
|
let ccx = bcx.ccx();
|
||||||
|
|
||||||
let val = if needs_cast {
|
let val = if needs_cast {
|
||||||
let real_llty = T_struct(st.fields.map(
|
let fields = do st.fields.map |&ty| {
|
||||||
|&ty| type_of::type_of(ccx, ty)),
|
type_of::type_of(ccx, ty)
|
||||||
st.packed);
|
};
|
||||||
|
let real_llty = T_struct(fields, st.packed);
|
||||||
PointerCast(bcx, val, T_ptr(real_llty))
|
PointerCast(bcx, val, T_ptr(real_llty))
|
||||||
} else {
|
} else {
|
||||||
val
|
val
|
||||||
@ -494,7 +495,7 @@ pub fn trans_drop_flag_ptr(bcx: block, r: &Repr, val: ValueRef) -> ValueRef {
|
|||||||
* this could be changed in the future to avoid allocating unnecessary
|
* this could be changed in the future to avoid allocating unnecessary
|
||||||
* space after values of shorter-than-maximum cases.
|
* space after values of shorter-than-maximum cases.
|
||||||
*/
|
*/
|
||||||
pub fn trans_const(ccx: @CrateContext, r: &Repr, discr: int,
|
pub fn trans_const(ccx: &mut CrateContext, r: &Repr, discr: int,
|
||||||
vals: &[ValueRef]) -> ValueRef {
|
vals: &[ValueRef]) -> ValueRef {
|
||||||
match *r {
|
match *r {
|
||||||
CEnum(min, max) => {
|
CEnum(min, max) => {
|
||||||
@ -509,8 +510,9 @@ pub fn trans_const(ccx: @CrateContext, r: &Repr, discr: int,
|
|||||||
General(ref cases) => {
|
General(ref cases) => {
|
||||||
let case = &cases[discr as uint];
|
let case = &cases[discr as uint];
|
||||||
let max_sz = cases.map(|s| s.size).max();
|
let max_sz = cases.map(|s| s.size).max();
|
||||||
|
let discr_ty = C_int(ccx, discr);
|
||||||
let contents = build_const_struct(ccx, case,
|
let contents = build_const_struct(ccx, case,
|
||||||
~[C_int(ccx, discr)] + vals);
|
~[discr_ty] + vals);
|
||||||
C_struct(contents + [padding(max_sz - case.size)])
|
C_struct(contents + [padding(max_sz - case.size)])
|
||||||
}
|
}
|
||||||
NullablePointer{ nonnull: ref nonnull, nndiscr, ptrfield, _ } => {
|
NullablePointer{ nonnull: ref nonnull, nndiscr, ptrfield, _ } => {
|
||||||
@ -538,7 +540,7 @@ pub fn trans_const(ccx: @CrateContext, r: &Repr, discr: int,
|
|||||||
* a two-element struct will locate it at offset 4, and accesses to it
|
* a two-element struct will locate it at offset 4, and accesses to it
|
||||||
* will read the wrong memory.
|
* will read the wrong memory.
|
||||||
*/
|
*/
|
||||||
fn build_const_struct(ccx: @CrateContext, st: &Struct, vals: &[ValueRef])
|
fn build_const_struct(ccx: &mut CrateContext, st: &Struct, vals: &[ValueRef])
|
||||||
-> ~[ValueRef] {
|
-> ~[ValueRef] {
|
||||||
assert_eq!(vals.len(), st.fields.len());
|
assert_eq!(vals.len(), st.fields.len());
|
||||||
|
|
||||||
@ -579,7 +581,7 @@ fn padding(size: u64) -> ValueRef {
|
|||||||
fn roundup(x: u64, a: u64) -> u64 { ((x + (a - 1)) / a) * a }
|
fn roundup(x: u64, a: u64) -> u64 { ((x + (a - 1)) / a) * a }
|
||||||
|
|
||||||
/// Get the discriminant of a constant value. (Not currently used.)
|
/// Get the discriminant of a constant value. (Not currently used.)
|
||||||
pub fn const_get_discrim(ccx: @CrateContext, r: &Repr, val: ValueRef)
|
pub fn const_get_discrim(ccx: &mut CrateContext, r: &Repr, val: ValueRef)
|
||||||
-> int {
|
-> int {
|
||||||
match *r {
|
match *r {
|
||||||
CEnum(*) => const_to_int(val) as int,
|
CEnum(*) => const_to_int(val) as int,
|
||||||
@ -598,7 +600,7 @@ pub fn const_get_discrim(ccx: @CrateContext, r: &Repr, val: ValueRef)
|
|||||||
* (Not to be confused with `common::const_get_elt`, which operates on
|
* (Not to be confused with `common::const_get_elt`, which operates on
|
||||||
* raw LLVM-level structs and arrays.)
|
* raw LLVM-level structs and arrays.)
|
||||||
*/
|
*/
|
||||||
pub fn const_get_field(ccx: @CrateContext, r: &Repr, val: ValueRef,
|
pub fn const_get_field(ccx: &mut CrateContext, r: &Repr, val: ValueRef,
|
||||||
_discr: int, ix: uint) -> ValueRef {
|
_discr: int, ix: uint) -> ValueRef {
|
||||||
match *r {
|
match *r {
|
||||||
CEnum(*) => ccx.sess.bug("element access in C-like enum const"),
|
CEnum(*) => ccx.sess.bug("element access in C-like enum const"),
|
||||||
@ -609,7 +611,7 @@ pub fn const_get_field(ccx: @CrateContext, r: &Repr, val: ValueRef,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Extract field of struct-like const, skipping our alignment padding.
|
/// Extract field of struct-like const, skipping our alignment padding.
|
||||||
fn const_struct_field(ccx: @CrateContext, val: ValueRef, ix: uint)
|
fn const_struct_field(ccx: &mut CrateContext, val: ValueRef, ix: uint)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
// Get the ix-th non-undef element of the struct.
|
// Get the ix-th non-undef element of the struct.
|
||||||
let mut real_ix = 0; // actual position in the struct
|
let mut real_ix = 0; // actual position in the struct
|
||||||
|
@ -88,7 +88,7 @@ use syntax::abi::{X86, X86_64, Arm, Mips};
|
|||||||
pub use middle::trans::context::task_llcx;
|
pub use middle::trans::context::task_llcx;
|
||||||
|
|
||||||
pub struct icx_popper {
|
pub struct icx_popper {
|
||||||
ccx: @CrateContext,
|
ccx: @mut CrateContext,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[unsafe_destructor]
|
#[unsafe_destructor]
|
||||||
@ -100,7 +100,7 @@ impl Drop for icx_popper {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn icx_popper(ccx: @CrateContext) -> icx_popper {
|
pub fn icx_popper(ccx: @mut CrateContext) -> icx_popper {
|
||||||
icx_popper {
|
icx_popper {
|
||||||
ccx: ccx
|
ccx: ccx
|
||||||
}
|
}
|
||||||
@ -110,7 +110,7 @@ pub trait get_insn_ctxt {
|
|||||||
fn insn_ctxt(&self, s: &str) -> icx_popper;
|
fn insn_ctxt(&self, s: &str) -> icx_popper;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl get_insn_ctxt for @CrateContext {
|
impl get_insn_ctxt for @mut CrateContext {
|
||||||
fn insn_ctxt(&self, s: &str) -> icx_popper {
|
fn insn_ctxt(&self, s: &str) -> icx_popper {
|
||||||
debug!("new insn_ctxt: %s", s);
|
debug!("new insn_ctxt: %s", s);
|
||||||
if self.sess.count_llvm_insns() {
|
if self.sess.count_llvm_insns() {
|
||||||
@ -139,7 +139,7 @@ fn fcx_has_nonzero_span(fcx: fn_ctxt) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn log_fn_time(ccx: @CrateContext, name: ~str, start: time::Timespec,
|
pub fn log_fn_time(ccx: @mut CrateContext, name: ~str, start: time::Timespec,
|
||||||
end: time::Timespec) {
|
end: time::Timespec) {
|
||||||
let elapsed = 1000 * ((end.sec - start.sec) as int) +
|
let elapsed = 1000 * ((end.sec - start.sec) as int) +
|
||||||
((end.nsec as int) - (start.nsec as int)) / 1000000;
|
((end.nsec as int) - (start.nsec as int)) / 1000000;
|
||||||
@ -175,7 +175,7 @@ pub fn decl_internal_cdecl_fn(llmod: ModuleRef, name: ~str, llty: TypeRef) ->
|
|||||||
return llfn;
|
return llfn;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_extern_fn(externs: ExternMap,
|
pub fn get_extern_fn(externs: &mut ExternMap,
|
||||||
llmod: ModuleRef,
|
llmod: ModuleRef,
|
||||||
name: @str,
|
name: @str,
|
||||||
cc: lib::llvm::CallConv,
|
cc: lib::llvm::CallConv,
|
||||||
@ -189,7 +189,7 @@ pub fn get_extern_fn(externs: ExternMap,
|
|||||||
return f;
|
return f;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_extern_const(externs: ExternMap, llmod: ModuleRef,
|
pub fn get_extern_const(externs: &mut ExternMap, llmod: ModuleRef,
|
||||||
name: @str, ty: TypeRef) -> ValueRef {
|
name: @str, ty: TypeRef) -> ValueRef {
|
||||||
match externs.find(&name) {
|
match externs.find(&name) {
|
||||||
Some(n) => return copy *n,
|
Some(n) => return copy *n,
|
||||||
@ -204,11 +204,11 @@ pub fn get_extern_const(externs: ExternMap, llmod: ModuleRef,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_simple_extern_fn(cx: block,
|
fn get_simple_extern_fn(cx: block,
|
||||||
externs: ExternMap,
|
externs: &mut ExternMap,
|
||||||
llmod: ModuleRef,
|
llmod: ModuleRef,
|
||||||
name: @str,
|
name: @str,
|
||||||
n_args: int) -> ValueRef {
|
n_args: int) -> ValueRef {
|
||||||
let _icx = cx.insn_ctxt("get_simple_extern_fn");
|
let _icx = cx.insn_ctxt("get_simple_extern_fn");
|
||||||
let ccx = cx.fcx.ccx;
|
let ccx = cx.fcx.ccx;
|
||||||
let inputs = vec::from_elem(n_args as uint, ccx.int_type);
|
let inputs = vec::from_elem(n_args as uint, ccx.int_type);
|
||||||
@ -217,7 +217,7 @@ pub fn get_extern_const(externs: ExternMap, llmod: ModuleRef,
|
|||||||
return get_extern_fn(externs, llmod, name, lib::llvm::CCallConv, t);
|
return get_extern_fn(externs, llmod, name, lib::llvm::CCallConv, t);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_foreign_call(cx: block, externs: ExternMap,
|
pub fn trans_foreign_call(cx: block, externs: &mut ExternMap,
|
||||||
llmod: ModuleRef, name: @str, args: &[ValueRef]) ->
|
llmod: ModuleRef, name: @str, args: &[ValueRef]) ->
|
||||||
ValueRef {
|
ValueRef {
|
||||||
let _icx = cx.insn_ctxt("trans_foreign_call");
|
let _icx = cx.insn_ctxt("trans_foreign_call");
|
||||||
@ -269,7 +269,9 @@ pub fn opaque_box_body(bcx: block,
|
|||||||
boxptr: ValueRef) -> ValueRef {
|
boxptr: ValueRef) -> ValueRef {
|
||||||
let _icx = bcx.insn_ctxt("opaque_box_body");
|
let _icx = bcx.insn_ctxt("opaque_box_body");
|
||||||
let ccx = bcx.ccx();
|
let ccx = bcx.ccx();
|
||||||
let boxptr = PointerCast(bcx, boxptr, T_ptr(T_box(ccx, type_of(ccx, body_t))));
|
let ty = type_of(ccx, body_t);
|
||||||
|
let ty = T_box(ccx, ty);
|
||||||
|
let boxptr = PointerCast(bcx, boxptr, T_ptr(ty));
|
||||||
GEPi(bcx, boxptr, [0u, abi::box_field_body])
|
GEPi(bcx, boxptr, [0u, abi::box_field_body])
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -335,7 +337,9 @@ pub fn non_gc_box_cast(bcx: block, val: ValueRef) -> ValueRef {
|
|||||||
// enough space for a box of that type. This includes a rust_opaque_box
|
// enough space for a box of that type. This includes a rust_opaque_box
|
||||||
// header.
|
// header.
|
||||||
pub fn malloc_raw(bcx: block, t: ty::t, heap: heap) -> Result {
|
pub fn malloc_raw(bcx: block, t: ty::t, heap: heap) -> Result {
|
||||||
malloc_raw_dyn(bcx, t, heap, llsize_of(bcx.ccx(), type_of(bcx.ccx(), t)))
|
let ty = type_of(bcx.ccx(), t);
|
||||||
|
let size = llsize_of(bcx.ccx(), ty);
|
||||||
|
malloc_raw_dyn(bcx, t, heap, size)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct MallocResult {
|
pub struct MallocResult {
|
||||||
@ -358,8 +362,8 @@ pub fn malloc_general_dyn(bcx: block, t: ty::t, heap: heap, size: ValueRef)
|
|||||||
|
|
||||||
pub fn malloc_general(bcx: block, t: ty::t, heap: heap)
|
pub fn malloc_general(bcx: block, t: ty::t, heap: heap)
|
||||||
-> MallocResult {
|
-> MallocResult {
|
||||||
malloc_general_dyn(bcx, t, heap,
|
let ty = type_of(bcx.ccx(), t);
|
||||||
llsize_of(bcx.ccx(), type_of(bcx.ccx(), t)))
|
malloc_general_dyn(bcx, t, heap, llsize_of(bcx.ccx(), ty))
|
||||||
}
|
}
|
||||||
pub fn malloc_boxed(bcx: block, t: ty::t)
|
pub fn malloc_boxed(bcx: block, t: ty::t)
|
||||||
-> MallocResult {
|
-> MallocResult {
|
||||||
@ -381,7 +385,8 @@ pub fn maybe_set_managed_unique_rc(bcx: block, bx: ValueRef, heap: heap) {
|
|||||||
// such as a ~(@foo) or such. These need to have their refcount forced
|
// such as a ~(@foo) or such. These need to have their refcount forced
|
||||||
// to -2 so the annihilator ignores them.
|
// to -2 so the annihilator ignores them.
|
||||||
let rc = GEPi(bcx, bx, [0u, abi::box_field_refcnt]);
|
let rc = GEPi(bcx, bx, [0u, abi::box_field_refcnt]);
|
||||||
Store(bcx, C_int(bcx.ccx(), -2), rc);
|
let rc_val = C_int(bcx.ccx(), -2);
|
||||||
|
Store(bcx, rc_val, rc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -392,11 +397,11 @@ pub fn malloc_unique(bcx: block, t: ty::t)
|
|||||||
|
|
||||||
// Type descriptor and type glue stuff
|
// Type descriptor and type glue stuff
|
||||||
|
|
||||||
pub fn get_tydesc_simple(ccx: @CrateContext, t: ty::t) -> ValueRef {
|
pub fn get_tydesc_simple(ccx: &mut CrateContext, t: ty::t) -> ValueRef {
|
||||||
get_tydesc(ccx, t).tydesc
|
get_tydesc(ccx, t).tydesc
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_tydesc(ccx: @CrateContext, t: ty::t) -> @mut tydesc_info {
|
pub fn get_tydesc(ccx: &mut CrateContext, t: ty::t) -> @mut tydesc_info {
|
||||||
match ccx.tydescs.find(&t) {
|
match ccx.tydescs.find(&t) {
|
||||||
Some(&inf) => {
|
Some(&inf) => {
|
||||||
return inf;
|
return inf;
|
||||||
@ -485,7 +490,7 @@ pub fn set_glue_inlining(f: ValueRef, t: ty::t) {
|
|||||||
|
|
||||||
// Double-check that we never ask LLVM to declare the same symbol twice. It
|
// Double-check that we never ask LLVM to declare the same symbol twice. It
|
||||||
// silently mangles such symbols, breaking our linkage model.
|
// silently mangles such symbols, breaking our linkage model.
|
||||||
pub fn note_unique_llvm_symbol(ccx: @CrateContext, sym: @str) {
|
pub fn note_unique_llvm_symbol(ccx: &mut CrateContext, sym: @str) {
|
||||||
if ccx.all_llvm_symbols.contains(&sym) {
|
if ccx.all_llvm_symbols.contains(&sym) {
|
||||||
ccx.sess.bug(~"duplicate LLVM symbol: " + sym);
|
ccx.sess.bug(~"duplicate LLVM symbol: " + sym);
|
||||||
}
|
}
|
||||||
@ -493,7 +498,7 @@ pub fn note_unique_llvm_symbol(ccx: @CrateContext, sym: @str) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
pub fn get_res_dtor(ccx: @CrateContext,
|
pub fn get_res_dtor(ccx: @mut CrateContext,
|
||||||
did: ast::def_id,
|
did: ast::def_id,
|
||||||
parent_id: ast::def_id,
|
parent_id: ast::def_id,
|
||||||
substs: &[ty::t])
|
substs: &[ty::t])
|
||||||
@ -527,7 +532,7 @@ pub fn get_res_dtor(ccx: @CrateContext,
|
|||||||
ty::lookup_item_type(tcx, parent_id).ty);
|
ty::lookup_item_type(tcx, parent_id).ty);
|
||||||
let llty = type_of_dtor(ccx, class_ty);
|
let llty = type_of_dtor(ccx, class_ty);
|
||||||
let name = name.to_managed(); // :-(
|
let name = name.to_managed(); // :-(
|
||||||
get_extern_fn(ccx.externs,
|
get_extern_fn(&mut ccx.externs,
|
||||||
ccx.llmod,
|
ccx.llmod,
|
||||||
name,
|
name,
|
||||||
lib::llvm::CCallConv,
|
lib::llvm::CCallConv,
|
||||||
@ -536,7 +541,7 @@ pub fn get_res_dtor(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Structural comparison: a rather involved form of glue.
|
// Structural comparison: a rather involved form of glue.
|
||||||
pub fn maybe_name_value(cx: @CrateContext, v: ValueRef, s: &str) {
|
pub fn maybe_name_value(cx: &CrateContext, v: ValueRef, s: &str) {
|
||||||
if cx.sess.opts.save_temps {
|
if cx.sess.opts.save_temps {
|
||||||
let _: () = str::as_c_str(s, |buf| {
|
let _: () = str::as_c_str(s, |buf| {
|
||||||
unsafe {
|
unsafe {
|
||||||
@ -818,18 +823,18 @@ pub fn null_env_ptr(bcx: block) -> ValueRef {
|
|||||||
C_null(T_opaque_box_ptr(bcx.ccx()))
|
C_null(T_opaque_box_ptr(bcx.ccx()))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_external_path(ccx: @CrateContext, did: ast::def_id, t: ty::t)
|
pub fn trans_external_path(ccx: &mut CrateContext, did: ast::def_id, t: ty::t)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
let name = csearch::get_symbol(ccx.sess.cstore, did).to_managed(); // Sad
|
let name = csearch::get_symbol(ccx.sess.cstore, did).to_managed(); // Sad
|
||||||
match ty::get(t).sty {
|
match ty::get(t).sty {
|
||||||
ty::ty_bare_fn(_) | ty::ty_closure(_) => {
|
ty::ty_bare_fn(_) | ty::ty_closure(_) => {
|
||||||
let llty = type_of_fn_from_ty(ccx, t);
|
let llty = type_of_fn_from_ty(ccx, t);
|
||||||
return get_extern_fn(ccx.externs, ccx.llmod, name,
|
return get_extern_fn(&mut ccx.externs, ccx.llmod, name,
|
||||||
lib::llvm::CCallConv, llty);
|
lib::llvm::CCallConv, llty);
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
let llty = type_of(ccx, t);
|
let llty = type_of(ccx, t);
|
||||||
return get_extern_const(ccx.externs, ccx.llmod, name, llty);
|
return get_extern_const(&mut ccx.externs, ccx.llmod, name, llty);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -1166,7 +1171,7 @@ pub fn trans_stmt(cx: block, s: &ast::stmt) -> block {
|
|||||||
debuginfo::create_local_var(bcx, *local);
|
debuginfo::create_local_var(bcx, *local);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ast::decl_item(i) => trans_item(*cx.fcx.ccx, i)
|
ast::decl_item(i) => trans_item(cx.fcx.ccx, i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ast::stmt_mac(*) => cx.tcx().sess.bug("unexpanded macro")
|
ast::stmt_mac(*) => cx.tcx().sess.bug("unexpanded macro")
|
||||||
@ -1456,7 +1461,7 @@ pub fn call_memcpy(cx: block, dst: ValueRef, src: ValueRef, n_bytes: ValueRef, a
|
|||||||
X86 | Arm | Mips => "llvm.memcpy.p0i8.p0i8.i32",
|
X86 | Arm | Mips => "llvm.memcpy.p0i8.p0i8.i32",
|
||||||
X86_64 => "llvm.memcpy.p0i8.p0i8.i64"
|
X86_64 => "llvm.memcpy.p0i8.p0i8.i64"
|
||||||
};
|
};
|
||||||
let memcpy = *ccx.intrinsics.get(&key);
|
let memcpy = ccx.intrinsics.get_copy(&key);
|
||||||
let src_ptr = PointerCast(cx, src, T_ptr(T_i8()));
|
let src_ptr = PointerCast(cx, src, T_ptr(T_i8()));
|
||||||
let dst_ptr = PointerCast(cx, dst, T_ptr(T_i8()));
|
let dst_ptr = PointerCast(cx, dst, T_ptr(T_i8()));
|
||||||
let size = IntCast(cx, n_bytes, ccx.int_type);
|
let size = IntCast(cx, n_bytes, ccx.int_type);
|
||||||
@ -1500,7 +1505,7 @@ pub fn memzero(cx: block, llptr: ValueRef, llty: TypeRef) {
|
|||||||
X86_64 => "llvm.memset.p0i8.i64"
|
X86_64 => "llvm.memset.p0i8.i64"
|
||||||
};
|
};
|
||||||
|
|
||||||
let llintrinsicfn = *ccx.intrinsics.get(&intrinsic_key);
|
let llintrinsicfn = ccx.intrinsics.get_copy(&intrinsic_key);
|
||||||
let llptr = PointerCast(cx, llptr, T_ptr(T_i8()));
|
let llptr = PointerCast(cx, llptr, T_ptr(T_i8()));
|
||||||
let llzeroval = C_u8(0);
|
let llzeroval = C_u8(0);
|
||||||
let size = IntCast(cx, machine::llsize_of(ccx, llty), ccx.int_type);
|
let size = IntCast(cx, machine::llsize_of(ccx, llty), ccx.int_type);
|
||||||
@ -1572,7 +1577,7 @@ pub fn make_return_pointer(fcx: fn_ctxt, output_type: ty::t) -> ValueRef {
|
|||||||
if !ty::type_is_immediate(output_type) {
|
if !ty::type_is_immediate(output_type) {
|
||||||
llvm::LLVMGetParam(fcx.llfn, 0)
|
llvm::LLVMGetParam(fcx.llfn, 0)
|
||||||
} else {
|
} else {
|
||||||
let lloutputtype = type_of::type_of(*fcx.ccx, output_type);
|
let lloutputtype = type_of::type_of(fcx.ccx, output_type);
|
||||||
alloca(raw_block(fcx, false, fcx.llstaticallocas), lloutputtype)
|
alloca(raw_block(fcx, false, fcx.llstaticallocas), lloutputtype)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1584,7 +1589,7 @@ pub fn make_return_pointer(fcx: fn_ctxt, output_type: ty::t) -> ValueRef {
|
|||||||
// - create_llargs_for_fn_args.
|
// - create_llargs_for_fn_args.
|
||||||
// - new_fn_ctxt
|
// - new_fn_ctxt
|
||||||
// - trans_args
|
// - trans_args
|
||||||
pub fn new_fn_ctxt_w_id(ccx: @CrateContext,
|
pub fn new_fn_ctxt_w_id(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
llfndecl: ValueRef,
|
llfndecl: ValueRef,
|
||||||
id: ast::node_id,
|
id: ast::node_id,
|
||||||
@ -1632,7 +1637,7 @@ pub fn new_fn_ctxt_w_id(ccx: @CrateContext,
|
|||||||
param_substs: param_substs,
|
param_substs: param_substs,
|
||||||
span: sp,
|
span: sp,
|
||||||
path: path,
|
path: path,
|
||||||
ccx: @ccx
|
ccx: ccx
|
||||||
};
|
};
|
||||||
fcx.llenv = unsafe {
|
fcx.llenv = unsafe {
|
||||||
llvm::LLVMGetParam(llfndecl, fcx.env_arg_pos() as c_uint)
|
llvm::LLVMGetParam(llfndecl, fcx.env_arg_pos() as c_uint)
|
||||||
@ -1641,7 +1646,7 @@ pub fn new_fn_ctxt_w_id(ccx: @CrateContext,
|
|||||||
fcx
|
fcx
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new_fn_ctxt(ccx: @CrateContext,
|
pub fn new_fn_ctxt(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
llfndecl: ValueRef,
|
llfndecl: ValueRef,
|
||||||
output_type: ty::t,
|
output_type: ty::t,
|
||||||
@ -1817,7 +1822,7 @@ pub enum self_arg { impl_self(ty::t), impl_owned_self(ty::t), no_self, }
|
|||||||
// trans_closure: Builds an LLVM function out of a source function.
|
// trans_closure: Builds an LLVM function out of a source function.
|
||||||
// If the function closes over its environment a closure will be
|
// If the function closes over its environment a closure will be
|
||||||
// returned.
|
// returned.
|
||||||
pub fn trans_closure(ccx: @CrateContext,
|
pub fn trans_closure(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
decl: &ast::fn_decl,
|
decl: &ast::fn_decl,
|
||||||
body: &ast::blk,
|
body: &ast::blk,
|
||||||
@ -1861,7 +1866,7 @@ pub fn trans_closure(ccx: @CrateContext,
|
|||||||
llvm::LLVMSetGC(fcx.llfn, strategy);
|
llvm::LLVMSetGC(fcx.llfn, strategy);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*ccx.uses_gc = true;
|
ccx.uses_gc = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the first basic block in the function and keep a handle on it to
|
// Create the first basic block in the function and keep a handle on it to
|
||||||
@ -1898,7 +1903,7 @@ pub fn trans_closure(ccx: @CrateContext,
|
|||||||
|
|
||||||
// trans_fn: creates an LLVM function corresponding to a source language
|
// trans_fn: creates an LLVM function corresponding to a source language
|
||||||
// function.
|
// function.
|
||||||
pub fn trans_fn(ccx: @CrateContext,
|
pub fn trans_fn(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
decl: &ast::fn_decl,
|
decl: &ast::fn_decl,
|
||||||
body: &ast::blk,
|
body: &ast::blk,
|
||||||
@ -1942,7 +1947,7 @@ pub fn trans_fn(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_enum_variant(ccx: @CrateContext,
|
pub fn trans_enum_variant(ccx: @mut CrateContext,
|
||||||
enum_id: ast::node_id,
|
enum_id: ast::node_id,
|
||||||
variant: &ast::variant,
|
variant: &ast::variant,
|
||||||
args: &[ast::variant_arg],
|
args: &[ast::variant_arg],
|
||||||
@ -2018,7 +2023,7 @@ pub fn trans_enum_variant(ccx: @CrateContext,
|
|||||||
|
|
||||||
// NB: In theory this should be merged with the function above. But the AST
|
// NB: In theory this should be merged with the function above. But the AST
|
||||||
// structures are completely different, so very little code would be shared.
|
// structures are completely different, so very little code would be shared.
|
||||||
pub fn trans_tuple_struct(ccx: @CrateContext,
|
pub fn trans_tuple_struct(ccx: @mut CrateContext,
|
||||||
fields: &[@ast::struct_field],
|
fields: &[@ast::struct_field],
|
||||||
ctor_id: ast::node_id,
|
ctor_id: ast::node_id,
|
||||||
param_substs: Option<@param_substs>,
|
param_substs: Option<@param_substs>,
|
||||||
@ -2085,7 +2090,7 @@ pub fn trans_tuple_struct(ccx: @CrateContext,
|
|||||||
finish_fn(fcx, lltop);
|
finish_fn(fcx, lltop);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_enum_def(ccx: @CrateContext, enum_definition: &ast::enum_def,
|
pub fn trans_enum_def(ccx: @mut CrateContext, enum_definition: &ast::enum_def,
|
||||||
id: ast::node_id, vi: @~[ty::VariantInfo],
|
id: ast::node_id, vi: @~[ty::VariantInfo],
|
||||||
i: &mut uint) {
|
i: &mut uint) {
|
||||||
for enum_definition.variants.each |variant| {
|
for enum_definition.variants.each |variant| {
|
||||||
@ -2108,7 +2113,7 @@ pub fn trans_enum_def(ccx: @CrateContext, enum_definition: &ast::enum_def,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_item(ccx: @CrateContext, item: &ast::item) {
|
pub fn trans_item(ccx: @mut CrateContext, item: &ast::item) {
|
||||||
let _icx = ccx.insn_ctxt("trans_item");
|
let _icx = ccx.insn_ctxt("trans_item");
|
||||||
let path = match ccx.tcx.items.get_copy(&item.id) {
|
let path = match ccx.tcx.items.get_copy(&item.id) {
|
||||||
ast_map::node_item(_, p) => p,
|
ast_map::node_item(_, p) => p,
|
||||||
@ -2196,7 +2201,7 @@ pub fn trans_item(ccx: @CrateContext, item: &ast::item) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_struct_def(ccx: @CrateContext, struct_def: @ast::struct_def) {
|
pub fn trans_struct_def(ccx: @mut CrateContext, struct_def: @ast::struct_def) {
|
||||||
// If this is a tuple-like struct, translate the constructor.
|
// If this is a tuple-like struct, translate the constructor.
|
||||||
match struct_def.ctor_id {
|
match struct_def.ctor_id {
|
||||||
// We only need to translate a constructor if there are fields;
|
// We only need to translate a constructor if there are fields;
|
||||||
@ -2215,14 +2220,14 @@ pub fn trans_struct_def(ccx: @CrateContext, struct_def: @ast::struct_def) {
|
|||||||
// separate modules in the compiled program. That's because modules exist
|
// separate modules in the compiled program. That's because modules exist
|
||||||
// only as a convenience for humans working with the code, to organize names
|
// only as a convenience for humans working with the code, to organize names
|
||||||
// and control visibility.
|
// and control visibility.
|
||||||
pub fn trans_mod(ccx: @CrateContext, m: &ast::_mod) {
|
pub fn trans_mod(ccx: @mut CrateContext, m: &ast::_mod) {
|
||||||
let _icx = ccx.insn_ctxt("trans_mod");
|
let _icx = ccx.insn_ctxt("trans_mod");
|
||||||
for m.items.each |item| {
|
for m.items.each |item| {
|
||||||
trans_item(ccx, *item);
|
trans_item(ccx, *item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_fn(ccx: @CrateContext,
|
pub fn register_fn(ccx: @mut CrateContext,
|
||||||
sp: span,
|
sp: span,
|
||||||
path: path,
|
path: path,
|
||||||
node_id: ast::node_id,
|
node_id: ast::node_id,
|
||||||
@ -2232,7 +2237,7 @@ pub fn register_fn(ccx: @CrateContext,
|
|||||||
register_fn_full(ccx, sp, path, node_id, attrs, t)
|
register_fn_full(ccx, sp, path, node_id, attrs, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_fn_full(ccx: @CrateContext,
|
pub fn register_fn_full(ccx: @mut CrateContext,
|
||||||
sp: span,
|
sp: span,
|
||||||
path: path,
|
path: path,
|
||||||
node_id: ast::node_id,
|
node_id: ast::node_id,
|
||||||
@ -2244,7 +2249,7 @@ pub fn register_fn_full(ccx: @CrateContext,
|
|||||||
lib::llvm::CCallConv, llfty)
|
lib::llvm::CCallConv, llfty)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_fn_fuller(ccx: @CrateContext,
|
pub fn register_fn_fuller(ccx: @mut CrateContext,
|
||||||
sp: span,
|
sp: span,
|
||||||
path: path,
|
path: path,
|
||||||
node_id: ast::node_id,
|
node_id: ast::node_id,
|
||||||
@ -2286,7 +2291,7 @@ pub fn is_entry_fn(sess: &Session, node_id: ast::node_id) -> bool {
|
|||||||
|
|
||||||
// Create a _rust_main(args: ~[str]) function which will be called from the
|
// Create a _rust_main(args: ~[str]) function which will be called from the
|
||||||
// runtime rust_start function
|
// runtime rust_start function
|
||||||
pub fn create_entry_wrapper(ccx: @CrateContext,
|
pub fn create_entry_wrapper(ccx: @mut CrateContext,
|
||||||
_sp: span, main_llfn: ValueRef) {
|
_sp: span, main_llfn: ValueRef) {
|
||||||
let et = ccx.sess.entry_type.unwrap();
|
let et = ccx.sess.entry_type.unwrap();
|
||||||
if et == session::EntryMain {
|
if et == session::EntryMain {
|
||||||
@ -2296,7 +2301,7 @@ pub fn create_entry_wrapper(ccx: @CrateContext,
|
|||||||
create_entry_fn(ccx, main_llfn, false);
|
create_entry_fn(ccx, main_llfn, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_main(ccx: @CrateContext, main_llfn: ValueRef) -> ValueRef {
|
fn create_main(ccx: @mut CrateContext, main_llfn: ValueRef) -> ValueRef {
|
||||||
let nt = ty::mk_nil();
|
let nt = ty::mk_nil();
|
||||||
|
|
||||||
let llfty = type_of_fn(ccx, [], nt);
|
let llfty = type_of_fn(ccx, [], nt);
|
||||||
@ -2326,7 +2331,7 @@ pub fn create_entry_wrapper(ccx: @CrateContext,
|
|||||||
return llfdecl;
|
return llfdecl;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_entry_fn(ccx: @CrateContext,
|
fn create_entry_fn(ccx: @mut CrateContext,
|
||||||
rust_main: ValueRef,
|
rust_main: ValueRef,
|
||||||
use_start_lang_item: bool) {
|
use_start_lang_item: bool) {
|
||||||
let llfty = T_fn([ccx.int_type, T_ptr(T_ptr(T_i8()))], ccx.int_type);
|
let llfty = T_fn([ccx.int_type, T_ptr(T_ptr(T_i8()))], ccx.int_type);
|
||||||
@ -2420,7 +2425,7 @@ pub fn fill_fn_pair(bcx: block, pair: ValueRef, llfn: ValueRef,
|
|||||||
Store(bcx, llenvblobptr, env_cell);
|
Store(bcx, llenvblobptr, env_cell);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn item_path(ccx: @CrateContext, i: @ast::item) -> path {
|
pub fn item_path(ccx: &CrateContext, i: @ast::item) -> path {
|
||||||
let base = match ccx.tcx.items.get_copy(&i.id) {
|
let base = match ccx.tcx.items.get_copy(&i.id) {
|
||||||
ast_map::node_item(_, p) => p,
|
ast_map::node_item(_, p) => p,
|
||||||
// separate map for paths?
|
// separate map for paths?
|
||||||
@ -2429,20 +2434,21 @@ pub fn item_path(ccx: @CrateContext, i: @ast::item) -> path {
|
|||||||
vec::append(/*bad*/copy *base, [path_name(i.ident)])
|
vec::append(/*bad*/copy *base, [path_name(i.ident)])
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_item_val(ccx: @CrateContext, id: ast::node_id) -> ValueRef {
|
pub fn get_item_val(ccx: @mut CrateContext, id: ast::node_id) -> ValueRef {
|
||||||
debug!("get_item_val(id=`%?`)", id);
|
debug!("get_item_val(id=`%?`)", id);
|
||||||
let tcx = ccx.tcx;
|
let val = ccx.item_vals.find_copy(&id);
|
||||||
match ccx.item_vals.find(&id) {
|
match val {
|
||||||
Some(&v) => v,
|
Some(v) => v,
|
||||||
None => {
|
None => {
|
||||||
let mut exprt = false;
|
let mut exprt = false;
|
||||||
let val = match tcx.items.get_copy(&id) {
|
let item = ccx.tcx.items.get_copy(&id);
|
||||||
|
let val = match item {
|
||||||
ast_map::node_item(i, pth) => {
|
ast_map::node_item(i, pth) => {
|
||||||
let my_path = vec::append(/*bad*/copy *pth,
|
let my_path = vec::append(/*bad*/copy *pth,
|
||||||
[path_name(i.ident)]);
|
[path_name(i.ident)]);
|
||||||
match i.node {
|
match i.node {
|
||||||
ast::item_const(_, expr) => {
|
ast::item_const(_, expr) => {
|
||||||
let typ = ty::node_id_to_type(tcx, i.id);
|
let typ = ty::node_id_to_type(ccx.tcx, i.id);
|
||||||
let s = mangle_exported_name(ccx, my_path, typ);
|
let s = mangle_exported_name(ccx, my_path, typ);
|
||||||
// We need the translated value here, because for enums the
|
// We need the translated value here, because for enums the
|
||||||
// LLVM type is not fully determined by the Rust type.
|
// LLVM type is not fully determined by the Rust type.
|
||||||
@ -2501,13 +2507,12 @@ pub fn get_item_val(ccx: @CrateContext, id: ast::node_id) -> ValueRef {
|
|||||||
ni.attrs)
|
ni.attrs)
|
||||||
}
|
}
|
||||||
ast::foreign_item_const(*) => {
|
ast::foreign_item_const(*) => {
|
||||||
let typ = ty::node_id_to_type(tcx, ni.id);
|
let typ = ty::node_id_to_type(ccx.tcx, ni.id);
|
||||||
let ident = token::ident_to_str(&ni.ident);
|
let ident = token::ident_to_str(&ni.ident);
|
||||||
let g = do str::as_c_str(ident) |buf| {
|
let g = do str::as_c_str(ident) |buf| {
|
||||||
unsafe {
|
unsafe {
|
||||||
llvm::LLVMAddGlobal(ccx.llmod,
|
let ty = type_of(ccx, typ);
|
||||||
type_of(ccx, typ),
|
llvm::LLVMAddGlobal(ccx.llmod, ty, buf)
|
||||||
buf)
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
g
|
g
|
||||||
@ -2542,7 +2547,7 @@ pub fn get_item_val(ccx: @CrateContext, id: ast::node_id) -> ValueRef {
|
|||||||
// Only register the constructor if this is a tuple-like struct.
|
// Only register the constructor if this is a tuple-like struct.
|
||||||
match struct_def.ctor_id {
|
match struct_def.ctor_id {
|
||||||
None => {
|
None => {
|
||||||
tcx.sess.bug("attempt to register a constructor of \
|
ccx.tcx.sess.bug("attempt to register a constructor of \
|
||||||
a non-tuple-like struct")
|
a non-tuple-like struct")
|
||||||
}
|
}
|
||||||
Some(ctor_id) => {
|
Some(ctor_id) => {
|
||||||
@ -2571,7 +2576,7 @@ pub fn get_item_val(ccx: @CrateContext, id: ast::node_id) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_method(ccx: @CrateContext,
|
pub fn register_method(ccx: @mut CrateContext,
|
||||||
id: ast::node_id,
|
id: ast::node_id,
|
||||||
pth: @ast_map::path,
|
pth: @ast_map::path,
|
||||||
m: @ast::method) -> ValueRef {
|
m: @ast::method) -> ValueRef {
|
||||||
@ -2584,7 +2589,7 @@ pub fn register_method(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// The constant translation pass.
|
// The constant translation pass.
|
||||||
pub fn trans_constant(ccx: @CrateContext, it: @ast::item) {
|
pub fn trans_constant(ccx: @mut CrateContext, it: @ast::item) {
|
||||||
let _icx = ccx.insn_ctxt("trans_constant");
|
let _icx = ccx.insn_ctxt("trans_constant");
|
||||||
match it.node {
|
match it.node {
|
||||||
ast::item_enum(ref enum_definition, _) => {
|
ast::item_enum(ref enum_definition, _) => {
|
||||||
@ -2620,7 +2625,7 @@ pub fn trans_constant(ccx: @CrateContext, it: @ast::item) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_constants(ccx: @CrateContext, crate: &ast::crate) {
|
pub fn trans_constants(ccx: @mut CrateContext, crate: &ast::crate) {
|
||||||
visit::visit_crate(
|
visit::visit_crate(
|
||||||
crate, ((),
|
crate, ((),
|
||||||
visit::mk_simple_visitor(@visit::SimpleVisitor {
|
visit::mk_simple_visitor(@visit::SimpleVisitor {
|
||||||
@ -2634,7 +2639,7 @@ pub fn vp2i(cx: block, v: ValueRef) -> ValueRef {
|
|||||||
return PtrToInt(cx, v, ccx.int_type);
|
return PtrToInt(cx, v, ccx.int_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn p2i(ccx: @CrateContext, v: ValueRef) -> ValueRef {
|
pub fn p2i(ccx: &CrateContext, v: ValueRef) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMConstPtrToInt(v, ccx.int_type);
|
return llvm::LLVMConstPtrToInt(v, ccx.int_type);
|
||||||
}
|
}
|
||||||
@ -2853,8 +2858,8 @@ pub fn trap(bcx: block) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn decl_gc_metadata(ccx: @CrateContext, llmod_id: &str) {
|
pub fn decl_gc_metadata(ccx: &mut CrateContext, llmod_id: &str) {
|
||||||
if !ccx.sess.opts.gc || !*ccx.uses_gc {
|
if !ccx.sess.opts.gc || !ccx.uses_gc {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2871,7 +2876,7 @@ pub fn decl_gc_metadata(ccx: @CrateContext, llmod_id: &str) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn create_module_map(ccx: @CrateContext) -> ValueRef {
|
pub fn create_module_map(ccx: &mut CrateContext) -> ValueRef {
|
||||||
let elttype = T_struct([ccx.int_type, ccx.int_type], false);
|
let elttype = T_struct([ccx.int_type, ccx.int_type], false);
|
||||||
let maptype = T_array(elttype, ccx.module_data.len() + 1);
|
let maptype = T_array(elttype, ccx.module_data.len() + 1);
|
||||||
let map = str::as_c_str("_rust_mod_map", |buf| {
|
let map = str::as_c_str("_rust_mod_map", |buf| {
|
||||||
@ -2881,9 +2886,21 @@ pub fn create_module_map(ccx: @CrateContext) -> ValueRef {
|
|||||||
});
|
});
|
||||||
lib::llvm::SetLinkage(map, lib::llvm::InternalLinkage);
|
lib::llvm::SetLinkage(map, lib::llvm::InternalLinkage);
|
||||||
let mut elts: ~[ValueRef] = ~[];
|
let mut elts: ~[ValueRef] = ~[];
|
||||||
for ccx.module_data.each |key, &val| {
|
|
||||||
let elt = C_struct([p2i(ccx, C_cstr(ccx, /* bad */key.to_managed())),
|
// This is not ideal, but the borrow checker doesn't
|
||||||
p2i(ccx, val)]);
|
// like the multiple borrows. At least, it doesn't
|
||||||
|
// like them on the current snapshot. (2013-06-14)
|
||||||
|
let mut keys = ~[];
|
||||||
|
for ccx.module_data.each_key |k| {
|
||||||
|
keys.push(k.to_managed());
|
||||||
|
}
|
||||||
|
|
||||||
|
for keys.each |key| {
|
||||||
|
let val = *ccx.module_data.find_equiv(key).get();
|
||||||
|
let s_const = C_cstr(ccx, *key);
|
||||||
|
let s_ptr = p2i(ccx, s_const);
|
||||||
|
let v_ptr = p2i(ccx, val);
|
||||||
|
let elt = C_struct([s_ptr, v_ptr]);
|
||||||
elts.push(elt);
|
elts.push(elt);
|
||||||
}
|
}
|
||||||
let term = C_struct([C_int(ccx, 0), C_int(ccx, 0)]);
|
let term = C_struct([C_int(ccx, 0), C_int(ccx, 0)]);
|
||||||
@ -2919,7 +2936,7 @@ pub fn decl_crate_map(sess: session::Session, mapmeta: LinkMeta,
|
|||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn fill_crate_map(ccx: @CrateContext, map: ValueRef) {
|
pub fn fill_crate_map(ccx: @mut CrateContext, map: ValueRef) {
|
||||||
let mut subcrates: ~[ValueRef] = ~[];
|
let mut subcrates: ~[ValueRef] = ~[];
|
||||||
let mut i = 1;
|
let mut i = 1;
|
||||||
let cstore = ccx.sess.cstore;
|
let cstore = ccx.sess.cstore;
|
||||||
@ -2952,37 +2969,44 @@ pub fn fill_crate_map(ccx: @CrateContext, map: ValueRef) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
|
let mod_map = create_module_map(ccx);
|
||||||
llvm::LLVMSetInitializer(map, C_struct(
|
llvm::LLVMSetInitializer(map, C_struct(
|
||||||
[C_i32(1),
|
[C_i32(1),
|
||||||
lib::llvm::llvm::LLVMConstPointerCast(llannihilatefn,
|
lib::llvm::llvm::LLVMConstPointerCast(llannihilatefn,
|
||||||
T_ptr(T_i8())),
|
T_ptr(T_i8())),
|
||||||
p2i(ccx, create_module_map(ccx)),
|
p2i(ccx, mod_map),
|
||||||
C_array(ccx.int_type, subcrates)]));
|
C_array(ccx.int_type, subcrates)]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn crate_ctxt_to_encode_parms(cx: @CrateContext)
|
pub fn crate_ctxt_to_encode_parms<'r>(cx: &'r CrateContext, ie: encoder::encode_inlined_item<'r>)
|
||||||
-> encoder::EncodeParams {
|
-> encoder::EncodeParams<'r> {
|
||||||
|
|
||||||
|
let diag = cx.sess.diagnostic();
|
||||||
|
let item_symbols = &cx.item_symbols;
|
||||||
|
let discrim_symbols = &cx.discrim_symbols;
|
||||||
|
let link_meta = &cx.link_meta;
|
||||||
|
encoder::EncodeParams {
|
||||||
|
diag: diag,
|
||||||
|
tcx: cx.tcx,
|
||||||
|
reachable: cx.reachable,
|
||||||
|
reexports2: cx.exp_map2,
|
||||||
|
item_symbols: item_symbols,
|
||||||
|
discrim_symbols: discrim_symbols,
|
||||||
|
link_meta: link_meta,
|
||||||
|
cstore: cx.sess.cstore,
|
||||||
|
encode_inlined_item: ie
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn write_metadata(cx: &mut CrateContext, crate: &ast::crate) {
|
||||||
|
if !*cx.sess.building_library { return; }
|
||||||
|
|
||||||
let encode_inlined_item: encoder::encode_inlined_item =
|
let encode_inlined_item: encoder::encode_inlined_item =
|
||||||
|ecx, ebml_w, path, ii|
|
|ecx, ebml_w, path, ii|
|
||||||
astencode::encode_inlined_item(ecx, ebml_w, path, ii, cx.maps);
|
astencode::encode_inlined_item(ecx, ebml_w, path, ii, cx.maps);
|
||||||
|
|
||||||
encoder::EncodeParams {
|
let encode_parms = crate_ctxt_to_encode_parms(cx, encode_inlined_item);
|
||||||
diag: cx.sess.diagnostic(),
|
|
||||||
tcx: cx.tcx,
|
|
||||||
reachable: cx.reachable,
|
|
||||||
reexports2: cx.exp_map2,
|
|
||||||
item_symbols: cx.item_symbols,
|
|
||||||
discrim_symbols: cx.discrim_symbols,
|
|
||||||
link_meta: /*bad*/copy cx.link_meta,
|
|
||||||
cstore: cx.sess.cstore,
|
|
||||||
encode_inlined_item: encode_inlined_item
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn write_metadata(cx: @CrateContext, crate: &ast::crate) {
|
|
||||||
if !*cx.sess.building_library { return; }
|
|
||||||
let encode_parms = crate_ctxt_to_encode_parms(cx);
|
|
||||||
let llmeta = C_bytes(encoder::encode_metadata(encode_parms, crate));
|
let llmeta = C_bytes(encoder::encode_metadata(encode_parms, crate));
|
||||||
let llconst = C_struct([llmeta]);
|
let llconst = C_struct([llmeta]);
|
||||||
let mut llglobal = str::as_c_str("rust_metadata", |buf| {
|
let mut llglobal = str::as_c_str("rust_metadata", |buf| {
|
||||||
@ -3008,7 +3032,7 @@ pub fn write_metadata(cx: @CrateContext, crate: &ast::crate) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Writes the current ABI version into the crate.
|
// Writes the current ABI version into the crate.
|
||||||
pub fn write_abi_version(ccx: @CrateContext) {
|
pub fn write_abi_version(ccx: &mut CrateContext) {
|
||||||
mk_global(ccx, ~"rust_abi_version", C_uint(ccx, abi::abi_version),
|
mk_global(ccx, ~"rust_abi_version", C_uint(ccx, abi::abi_version),
|
||||||
false);
|
false);
|
||||||
}
|
}
|
||||||
@ -3020,8 +3044,8 @@ pub fn trans_crate(sess: session::Session,
|
|||||||
emap2: resolve::ExportMap2,
|
emap2: resolve::ExportMap2,
|
||||||
maps: astencode::Maps) -> (ContextRef, ModuleRef, LinkMeta) {
|
maps: astencode::Maps) -> (ContextRef, ModuleRef, LinkMeta) {
|
||||||
|
|
||||||
let symbol_hasher = @mut hash::default_state();
|
let mut symbol_hasher = hash::default_state();
|
||||||
let link_meta = link::build_link_meta(sess, crate, output, symbol_hasher);
|
let link_meta = link::build_link_meta(sess, crate, output, &mut symbol_hasher);
|
||||||
let reachable = reachable::find_reachable(
|
let reachable = reachable::find_reachable(
|
||||||
&crate.node.module,
|
&crate.node.module,
|
||||||
emap2,
|
emap2,
|
||||||
@ -3038,7 +3062,14 @@ pub fn trans_crate(sess: session::Session,
|
|||||||
// such as a function name in the module.
|
// such as a function name in the module.
|
||||||
// 1. http://llvm.org/bugs/show_bug.cgi?id=11479
|
// 1. http://llvm.org/bugs/show_bug.cgi?id=11479
|
||||||
let llmod_id = link_meta.name.to_owned() + ".rc";
|
let llmod_id = link_meta.name.to_owned() + ".rc";
|
||||||
let ccx = @CrateContext::new(sess, llmod_id, tcx, emap2, maps,
|
|
||||||
|
// FIXME(#6511): get LLVM building with --enable-threads so this
|
||||||
|
// function can be called
|
||||||
|
// if !llvm::LLVMRustStartMultithreading() {
|
||||||
|
// sess.bug("couldn't enable multi-threaded LLVM");
|
||||||
|
// }
|
||||||
|
|
||||||
|
let ccx = @mut CrateContext::new(sess, llmod_id, tcx, emap2, maps,
|
||||||
symbol_hasher, link_meta, reachable);
|
symbol_hasher, link_meta, reachable);
|
||||||
// FIXME(#6511): get LLVM building with --enable-threads so this
|
// FIXME(#6511): get LLVM building with --enable-threads so this
|
||||||
// function can be called
|
// function can be called
|
||||||
|
@ -46,8 +46,8 @@ pub fn B(cx: block) -> BuilderRef {
|
|||||||
pub fn count_insn(cx: block, category: &str) {
|
pub fn count_insn(cx: block, category: &str) {
|
||||||
if cx.ccx().sess.count_llvm_insns() {
|
if cx.ccx().sess.count_llvm_insns() {
|
||||||
|
|
||||||
let h = cx.ccx().stats.llvm_insns;
|
let h = &mut cx.ccx().stats.llvm_insns;
|
||||||
let v = &*cx.ccx().stats.llvm_insn_ctxt;
|
let v : &[~str] = cx.ccx().stats.llvm_insn_ctxt;
|
||||||
|
|
||||||
// Build version of path with cycles removed.
|
// Build version of path with cycles removed.
|
||||||
|
|
||||||
@ -547,7 +547,7 @@ pub fn AtomicLoad(cx: block, PointerVal: ValueRef, order: AtomicOrdering) -> Val
|
|||||||
return llvm::LLVMGetUndef(ccx.int_type);
|
return llvm::LLVMGetUndef(ccx.int_type);
|
||||||
}
|
}
|
||||||
count_insn(cx, "load.atomic");
|
count_insn(cx, "load.atomic");
|
||||||
let align = llalign_of_min(*ccx, ccx.int_type);
|
let align = llalign_of_min(ccx, ccx.int_type);
|
||||||
return llvm::LLVMBuildAtomicLoad(B(cx), PointerVal, noname(), order, align as c_uint);
|
return llvm::LLVMBuildAtomicLoad(B(cx), PointerVal, noname(), order, align as c_uint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ use super::common::*;
|
|||||||
use super::machine::*;
|
use super::machine::*;
|
||||||
|
|
||||||
struct X86_ABIInfo {
|
struct X86_ABIInfo {
|
||||||
ccx: @CrateContext
|
ccx: @mut CrateContext
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ABIInfo for X86_ABIInfo {
|
impl ABIInfo for X86_ABIInfo {
|
||||||
@ -71,7 +71,7 @@ impl ABIInfo for X86_ABIInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn abi_info(ccx: @CrateContext) -> @ABIInfo {
|
pub fn abi_info(ccx: @mut CrateContext) -> @ABIInfo {
|
||||||
return @X86_ABIInfo {
|
return @X86_ABIInfo {
|
||||||
ccx: ccx
|
ccx: ccx
|
||||||
} as @ABIInfo;
|
} as @ABIInfo;
|
||||||
|
@ -129,7 +129,7 @@ impl EnvAction {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl EnvValue {
|
impl EnvValue {
|
||||||
pub fn to_str(&self, ccx: @CrateContext) -> ~str {
|
pub fn to_str(&self, ccx: &CrateContext) -> ~str {
|
||||||
fmt!("%s(%s)", self.action.to_str(), self.datum.to_str(ccx))
|
fmt!("%s(%s)", self.action.to_str(), self.datum.to_str(ccx))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -124,9 +124,9 @@ pub struct Stats {
|
|||||||
n_monos: uint,
|
n_monos: uint,
|
||||||
n_inlines: uint,
|
n_inlines: uint,
|
||||||
n_closures: uint,
|
n_closures: uint,
|
||||||
llvm_insn_ctxt: @mut ~[~str],
|
llvm_insn_ctxt: ~[~str],
|
||||||
llvm_insns: @mut HashMap<~str, uint>,
|
llvm_insns: HashMap<~str, uint>,
|
||||||
fn_times: @mut ~[(~str, int)] // (ident, time)
|
fn_times: ~[(~str, int)] // (ident, time)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct BuilderRef_res {
|
pub struct BuilderRef_res {
|
||||||
@ -147,7 +147,7 @@ pub fn BuilderRef_res(B: BuilderRef) -> BuilderRef_res {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub type ExternMap = @mut HashMap<@str, ValueRef>;
|
pub type ExternMap = HashMap<@str, ValueRef>;
|
||||||
|
|
||||||
// Types used for llself.
|
// Types used for llself.
|
||||||
pub struct ValSelfData {
|
pub struct ValSelfData {
|
||||||
@ -266,7 +266,7 @@ pub struct fn_ctxt_ {
|
|||||||
path: path,
|
path: path,
|
||||||
|
|
||||||
// This function's enclosing crate context.
|
// This function's enclosing crate context.
|
||||||
ccx: @@CrateContext
|
ccx: @mut CrateContext
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fn_ctxt_ {
|
impl fn_ctxt_ {
|
||||||
@ -295,9 +295,9 @@ impl fn_ctxt_ {
|
|||||||
|
|
||||||
pub type fn_ctxt = @mut fn_ctxt_;
|
pub type fn_ctxt = @mut fn_ctxt_;
|
||||||
|
|
||||||
pub fn warn_not_to_commit(ccx: @CrateContext, msg: &str) {
|
pub fn warn_not_to_commit(ccx: &mut CrateContext, msg: &str) {
|
||||||
if !*ccx.do_not_commit_warning_issued {
|
if !ccx.do_not_commit_warning_issued {
|
||||||
*ccx.do_not_commit_warning_issued = true;
|
ccx.do_not_commit_warning_issued = true;
|
||||||
ccx.sess.warn(msg.to_str() + " -- do not commit like this!");
|
ccx.sess.warn(msg.to_str() + " -- do not commit like this!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -659,7 +659,7 @@ pub fn block_parent(cx: block) -> block {
|
|||||||
// Accessors
|
// Accessors
|
||||||
|
|
||||||
impl block_ {
|
impl block_ {
|
||||||
pub fn ccx(@mut self) -> @CrateContext { *self.fcx.ccx }
|
pub fn ccx(@mut self) -> @mut CrateContext { self.fcx.ccx }
|
||||||
pub fn tcx(@mut self) -> ty::ctxt { self.fcx.ccx.tcx }
|
pub fn tcx(@mut self) -> ty::ctxt { self.fcx.ccx.tcx }
|
||||||
pub fn sess(@mut self) -> Session { self.fcx.ccx.sess }
|
pub fn sess(@mut self) -> Session { self.fcx.ccx.sess }
|
||||||
|
|
||||||
@ -754,7 +754,7 @@ pub fn T_f64() -> TypeRef {
|
|||||||
|
|
||||||
pub fn T_bool() -> TypeRef { return T_i8(); }
|
pub fn T_bool() -> TypeRef { return T_i8(); }
|
||||||
|
|
||||||
pub fn T_int(targ_cfg: @session::config) -> TypeRef {
|
pub fn T_int(targ_cfg: &session::config) -> TypeRef {
|
||||||
return match targ_cfg.arch {
|
return match targ_cfg.arch {
|
||||||
X86 => T_i32(),
|
X86 => T_i32(),
|
||||||
X86_64 => T_i64(),
|
X86_64 => T_i64(),
|
||||||
@ -763,7 +763,7 @@ pub fn T_int(targ_cfg: @session::config) -> TypeRef {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_int_ty(cx: @CrateContext, t: ast::int_ty) -> TypeRef {
|
pub fn T_int_ty(cx: &CrateContext, t: ast::int_ty) -> TypeRef {
|
||||||
match t {
|
match t {
|
||||||
ast::ty_i => cx.int_type,
|
ast::ty_i => cx.int_type,
|
||||||
ast::ty_char => T_char(),
|
ast::ty_char => T_char(),
|
||||||
@ -774,7 +774,7 @@ pub fn T_int_ty(cx: @CrateContext, t: ast::int_ty) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_uint_ty(cx: @CrateContext, t: ast::uint_ty) -> TypeRef {
|
pub fn T_uint_ty(cx: &CrateContext, t: ast::uint_ty) -> TypeRef {
|
||||||
match t {
|
match t {
|
||||||
ast::ty_u => cx.int_type,
|
ast::ty_u => cx.int_type,
|
||||||
ast::ty_u8 => T_i8(),
|
ast::ty_u8 => T_i8(),
|
||||||
@ -784,7 +784,7 @@ pub fn T_uint_ty(cx: @CrateContext, t: ast::uint_ty) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_float_ty(cx: @CrateContext, t: ast::float_ty) -> TypeRef {
|
pub fn T_float_ty(cx: &CrateContext, t: ast::float_ty) -> TypeRef {
|
||||||
match t {
|
match t {
|
||||||
ast::ty_f => cx.float_type,
|
ast::ty_f => cx.float_type,
|
||||||
ast::ty_f32 => T_f32(),
|
ast::ty_f32 => T_f32(),
|
||||||
@ -792,7 +792,7 @@ pub fn T_float_ty(cx: @CrateContext, t: ast::float_ty) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_float(targ_cfg: @session::config) -> TypeRef {
|
pub fn T_float(targ_cfg: &session::config) -> TypeRef {
|
||||||
return match targ_cfg.arch {
|
return match targ_cfg.arch {
|
||||||
X86 => T_f64(),
|
X86 => T_f64(),
|
||||||
X86_64 => T_f64(),
|
X86_64 => T_f64(),
|
||||||
@ -803,7 +803,7 @@ pub fn T_float(targ_cfg: @session::config) -> TypeRef {
|
|||||||
|
|
||||||
pub fn T_char() -> TypeRef { return T_i32(); }
|
pub fn T_char() -> TypeRef { return T_i32(); }
|
||||||
|
|
||||||
pub fn T_size_t(targ_cfg: @session::config) -> TypeRef {
|
pub fn T_size_t(targ_cfg: &session::config) -> TypeRef {
|
||||||
return T_int(targ_cfg);
|
return T_int(targ_cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -815,7 +815,7 @@ pub fn T_fn(inputs: &[TypeRef], output: TypeRef) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_fn_pair(cx: @CrateContext, tfn: TypeRef) -> TypeRef {
|
pub fn T_fn_pair(cx: &CrateContext, tfn: TypeRef) -> TypeRef {
|
||||||
return T_struct([T_ptr(tfn), T_opaque_cbox_ptr(cx)], false);
|
return T_struct([T_ptr(tfn), T_opaque_cbox_ptr(cx)], false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -865,7 +865,7 @@ pub fn T_empty_struct() -> TypeRef { return T_struct([], false); }
|
|||||||
// they are described by this opaque type.
|
// they are described by this opaque type.
|
||||||
pub fn T_vtable() -> TypeRef { T_array(T_ptr(T_i8()), 1u) }
|
pub fn T_vtable() -> TypeRef { T_array(T_ptr(T_i8()), 1u) }
|
||||||
|
|
||||||
pub fn T_tydesc_field(cx: @CrateContext, field: uint) -> TypeRef {
|
pub fn T_tydesc_field(cx: &CrateContext, field: uint) -> TypeRef {
|
||||||
// Bit of a kludge: pick the fn typeref out of the tydesc..
|
// Bit of a kludge: pick the fn typeref out of the tydesc..
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
@ -878,7 +878,7 @@ pub fn T_tydesc_field(cx: @CrateContext, field: uint) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_generic_glue_fn(cx: @CrateContext) -> TypeRef {
|
pub fn T_generic_glue_fn(cx: &mut CrateContext) -> TypeRef {
|
||||||
let s = @"glue_fn";
|
let s = @"glue_fn";
|
||||||
match name_has_type(cx.tn, s) {
|
match name_has_type(cx.tn, s) {
|
||||||
Some(t) => return t,
|
Some(t) => return t,
|
||||||
@ -918,14 +918,14 @@ pub fn T_vector(t: TypeRef, n: uint) -> TypeRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Interior vector.
|
// Interior vector.
|
||||||
pub fn T_vec2(targ_cfg: @session::config, t: TypeRef) -> TypeRef {
|
pub fn T_vec2(targ_cfg: &session::config, t: TypeRef) -> TypeRef {
|
||||||
return T_struct([T_int(targ_cfg), // fill
|
return T_struct([T_int(targ_cfg), // fill
|
||||||
T_int(targ_cfg), // alloc
|
T_int(targ_cfg), // alloc
|
||||||
T_array(t, 0u)], // elements
|
T_array(t, 0u)], // elements
|
||||||
false);
|
false);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_vec(ccx: @CrateContext, t: TypeRef) -> TypeRef {
|
pub fn T_vec(ccx: &CrateContext, t: TypeRef) -> TypeRef {
|
||||||
return T_vec2(ccx.sess.targ_cfg, t);
|
return T_vec2(ccx.sess.targ_cfg, t);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -947,16 +947,16 @@ pub fn tuplify_box_ty(tcx: ty::ctxt, t: ty::t) -> ty::t {
|
|||||||
t]);
|
t]);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_box_header_fields(cx: @CrateContext) -> ~[TypeRef] {
|
pub fn T_box_header_fields(cx: &CrateContext) -> ~[TypeRef] {
|
||||||
let ptr = T_ptr(T_i8());
|
let ptr = T_ptr(T_i8());
|
||||||
return ~[cx.int_type, T_ptr(cx.tydesc_type), ptr, ptr];
|
return ~[cx.int_type, T_ptr(cx.tydesc_type), ptr, ptr];
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_box_header(cx: @CrateContext) -> TypeRef {
|
pub fn T_box_header(cx: &CrateContext) -> TypeRef {
|
||||||
return T_struct(T_box_header_fields(cx), false);
|
return T_struct(T_box_header_fields(cx), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_box(cx: @CrateContext, t: TypeRef) -> TypeRef {
|
pub fn T_box(cx: &CrateContext, t: TypeRef) -> TypeRef {
|
||||||
return T_struct(vec::append(T_box_header_fields(cx), [t]), false);
|
return T_struct(vec::append(T_box_header_fields(cx), [t]), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -966,15 +966,15 @@ pub fn T_box_ptr(t: TypeRef) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_opaque_box(cx: @CrateContext) -> TypeRef {
|
pub fn T_opaque_box(cx: &CrateContext) -> TypeRef {
|
||||||
return T_box(cx, T_i8());
|
return T_box(cx, T_i8());
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_opaque_box_ptr(cx: @CrateContext) -> TypeRef {
|
pub fn T_opaque_box_ptr(cx: &CrateContext) -> TypeRef {
|
||||||
return T_box_ptr(T_opaque_box(cx));
|
return T_box_ptr(T_opaque_box(cx));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_unique(cx: @CrateContext, t: TypeRef) -> TypeRef {
|
pub fn T_unique(cx: &CrateContext, t: TypeRef) -> TypeRef {
|
||||||
return T_struct(vec::append(T_box_header_fields(cx), [t]), false);
|
return T_struct(vec::append(T_box_header_fields(cx), [t]), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -984,32 +984,32 @@ pub fn T_unique_ptr(t: TypeRef) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_port(cx: @CrateContext, _t: TypeRef) -> TypeRef {
|
pub fn T_port(cx: &CrateContext, _t: TypeRef) -> TypeRef {
|
||||||
return T_struct([cx.int_type], false); // Refcount
|
return T_struct([cx.int_type], false); // Refcount
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_chan(cx: @CrateContext, _t: TypeRef) -> TypeRef {
|
pub fn T_chan(cx: &CrateContext, _t: TypeRef) -> TypeRef {
|
||||||
return T_struct([cx.int_type], false); // Refcount
|
return T_struct([cx.int_type], false); // Refcount
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
pub fn T_opaque_cbox_ptr(cx: @CrateContext) -> TypeRef {
|
pub fn T_opaque_cbox_ptr(cx: &CrateContext) -> TypeRef {
|
||||||
// closures look like boxes (even when they are ~fn or &fn)
|
// closures look like boxes (even when they are ~fn or &fn)
|
||||||
// see trans_closure.rs
|
// see trans_closure.rs
|
||||||
return T_opaque_box_ptr(cx);
|
return T_opaque_box_ptr(cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_enum_discrim(cx: @CrateContext) -> TypeRef {
|
pub fn T_enum_discrim(cx: &CrateContext) -> TypeRef {
|
||||||
return cx.int_type;
|
return cx.int_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_captured_tydescs(cx: @CrateContext, n: uint) -> TypeRef {
|
pub fn T_captured_tydescs(cx: &CrateContext, n: uint) -> TypeRef {
|
||||||
return T_struct(vec::from_elem::<TypeRef>(n, T_ptr(cx.tydesc_type)), false);
|
return T_struct(vec::from_elem::<TypeRef>(n, T_ptr(cx.tydesc_type)), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn T_opaque_trait(cx: @CrateContext, store: ty::TraitStore) -> TypeRef {
|
pub fn T_opaque_trait(cx: &CrateContext, store: ty::TraitStore) -> TypeRef {
|
||||||
match store {
|
match store {
|
||||||
ty::BoxTraitStore => {
|
ty::BoxTraitStore => {
|
||||||
T_struct([T_ptr(cx.tydesc_type), T_opaque_box_ptr(cx)], false)
|
T_struct([T_ptr(cx.tydesc_type), T_opaque_box_ptr(cx)], false)
|
||||||
@ -1075,11 +1075,11 @@ pub fn C_i64(i: i64) -> ValueRef {
|
|||||||
return C_integral(T_i64(), i as u64, True);
|
return C_integral(T_i64(), i as u64, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn C_int(cx: @CrateContext, i: int) -> ValueRef {
|
pub fn C_int(cx: &CrateContext, i: int) -> ValueRef {
|
||||||
return C_integral(cx.int_type, i as u64, True);
|
return C_integral(cx.int_type, i as u64, True);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn C_uint(cx: @CrateContext, i: uint) -> ValueRef {
|
pub fn C_uint(cx: &CrateContext, i: uint) -> ValueRef {
|
||||||
return C_integral(cx.int_type, i as u64, False);
|
return C_integral(cx.int_type, i as u64, False);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1090,7 +1090,7 @@ pub fn C_u8(i: uint) -> ValueRef {
|
|||||||
|
|
||||||
// This is a 'c-like' raw string, which differs from
|
// This is a 'c-like' raw string, which differs from
|
||||||
// our boxed-and-length-annotated strings.
|
// our boxed-and-length-annotated strings.
|
||||||
pub fn C_cstr(cx: @CrateContext, s: @str) -> ValueRef {
|
pub fn C_cstr(cx: &mut CrateContext, s: @str) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
match cx.const_cstr_cache.find(&s) {
|
match cx.const_cstr_cache.find(&s) {
|
||||||
Some(&llval) => return llval,
|
Some(&llval) => return llval,
|
||||||
@ -1116,7 +1116,7 @@ pub fn C_cstr(cx: @CrateContext, s: @str) -> ValueRef {
|
|||||||
|
|
||||||
// NB: Do not use `do_spill_noroot` to make this into a constant string, or
|
// NB: Do not use `do_spill_noroot` to make this into a constant string, or
|
||||||
// you will be kicked off fast isel. See issue #4352 for an example of this.
|
// you will be kicked off fast isel. See issue #4352 for an example of this.
|
||||||
pub fn C_estr_slice(cx: @CrateContext, s: @str) -> ValueRef {
|
pub fn C_estr_slice(cx: &mut CrateContext, s: @str) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let len = s.len();
|
let len = s.len();
|
||||||
let cs = llvm::LLVMConstPointerCast(C_cstr(cx, s), T_ptr(T_i8()));
|
let cs = llvm::LLVMConstPointerCast(C_cstr(cx, s), T_ptr(T_i8()));
|
||||||
@ -1194,7 +1194,7 @@ pub fn C_bytes_plus_null(bytes: &[u8]) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn C_shape(ccx: @CrateContext, bytes: ~[u8]) -> ValueRef {
|
pub fn C_shape(ccx: &CrateContext, bytes: ~[u8]) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let llshape = C_bytes_plus_null(bytes);
|
let llshape = C_bytes_plus_null(bytes);
|
||||||
let name = fmt!("shape%u", (ccx.names)("shape").name);
|
let name = fmt!("shape%u", (ccx.names)("shape").name);
|
||||||
@ -1214,7 +1214,7 @@ pub fn get_param(fndecl: ValueRef, param: uint) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn const_get_elt(cx: @CrateContext, v: ValueRef, us: &[c_uint])
|
pub fn const_get_elt(cx: &CrateContext, v: ValueRef, us: &[c_uint])
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let r = do vec::as_imm_buf(us) |p, len| {
|
let r = do vec::as_imm_buf(us) |p, len| {
|
||||||
|
@ -34,7 +34,7 @@ use core::libc::c_uint;
|
|||||||
use core::str;
|
use core::str;
|
||||||
use syntax::{ast, ast_util, ast_map};
|
use syntax::{ast, ast_util, ast_map};
|
||||||
|
|
||||||
pub fn const_lit(cx: @CrateContext, e: @ast::expr, lit: ast::lit)
|
pub fn const_lit(cx: @mut CrateContext, e: @ast::expr, lit: ast::lit)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
let _icx = cx.insn_ctxt("trans_lit");
|
let _icx = cx.insn_ctxt("trans_lit");
|
||||||
match lit.node {
|
match lit.node {
|
||||||
@ -73,7 +73,7 @@ pub fn const_lit(cx: @CrateContext, e: @ast::expr, lit: ast::lit)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn const_ptrcast(cx: @CrateContext, a: ValueRef, t: TypeRef) -> ValueRef {
|
pub fn const_ptrcast(cx: &mut CrateContext, a: ValueRef, t: TypeRef) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let b = llvm::LLVMConstPointerCast(a, T_ptr(t));
|
let b = llvm::LLVMConstPointerCast(a, T_ptr(t));
|
||||||
assert!(cx.const_globals.insert(b as int, a));
|
assert!(cx.const_globals.insert(b as int, a));
|
||||||
@ -81,7 +81,7 @@ pub fn const_ptrcast(cx: @CrateContext, a: ValueRef, t: TypeRef) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn const_vec(cx: @CrateContext, e: @ast::expr, es: &[@ast::expr])
|
pub fn const_vec(cx: @mut CrateContext, e: @ast::expr, es: &[@ast::expr])
|
||||||
-> (ValueRef, ValueRef, TypeRef) {
|
-> (ValueRef, ValueRef, TypeRef) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let vec_ty = ty::expr_ty(cx.tcx, e);
|
let vec_ty = ty::expr_ty(cx.tcx, e);
|
||||||
@ -100,7 +100,7 @@ pub fn const_vec(cx: @CrateContext, e: @ast::expr, es: &[@ast::expr])
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn const_addr_of(cx: @CrateContext, cv: ValueRef) -> ValueRef {
|
fn const_addr_of(cx: @mut CrateContext, cv: ValueRef) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let gv = do str::as_c_str("const") |name| {
|
let gv = do str::as_c_str("const") |name| {
|
||||||
llvm::LLVMAddGlobal(cx.llmod, val_ty(cv), name)
|
llvm::LLVMAddGlobal(cx.llmod, val_ty(cv), name)
|
||||||
@ -112,7 +112,7 @@ fn const_addr_of(cx: @CrateContext, cv: ValueRef) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn const_deref_ptr(cx: @CrateContext, v: ValueRef) -> ValueRef {
|
fn const_deref_ptr(cx: @mut CrateContext, v: ValueRef) -> ValueRef {
|
||||||
let v = match cx.const_globals.find(&(v as int)) {
|
let v = match cx.const_globals.find(&(v as int)) {
|
||||||
Some(&v) => v,
|
Some(&v) => v,
|
||||||
None => v
|
None => v
|
||||||
@ -123,13 +123,13 @@ fn const_deref_ptr(cx: @CrateContext, v: ValueRef) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn const_deref_newtype(cx: @CrateContext, v: ValueRef, t: ty::t)
|
fn const_deref_newtype(cx: @mut CrateContext, v: ValueRef, t: ty::t)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
let repr = adt::represent_type(cx, t);
|
let repr = adt::represent_type(cx, t);
|
||||||
adt::const_get_field(cx, repr, v, 0, 0)
|
adt::const_get_field(cx, repr, v, 0, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn const_deref(cx: @CrateContext, v: ValueRef, t: ty::t, explicit: bool)
|
fn const_deref(cx: @mut CrateContext, v: ValueRef, t: ty::t, explicit: bool)
|
||||||
-> (ValueRef, ty::t) {
|
-> (ValueRef, ty::t) {
|
||||||
match ty::deref(cx.tcx, t, explicit) {
|
match ty::deref(cx.tcx, t, explicit) {
|
||||||
Some(ref mt) => {
|
Some(ref mt) => {
|
||||||
@ -155,10 +155,9 @@ fn const_deref(cx: @CrateContext, v: ValueRef, t: ty::t, explicit: bool)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_const_val(cx: @CrateContext, def_id: ast::def_id) -> ValueRef {
|
pub fn get_const_val(cx: @mut CrateContext, mut def_id: ast::def_id) -> ValueRef {
|
||||||
let mut def_id = def_id;
|
let contains_key = cx.const_values.contains_key(&def_id.node);
|
||||||
if !ast_util::is_local(def_id) ||
|
if !ast_util::is_local(def_id) || !contains_key {
|
||||||
!cx.const_values.contains_key(&def_id.node) {
|
|
||||||
if !ast_util::is_local(def_id) {
|
if !ast_util::is_local(def_id) {
|
||||||
def_id = inline::maybe_instantiate_inline(cx, def_id, true);
|
def_id = inline::maybe_instantiate_inline(cx, def_id, true);
|
||||||
}
|
}
|
||||||
@ -174,19 +173,20 @@ pub fn get_const_val(cx: @CrateContext, def_id: ast::def_id) -> ValueRef {
|
|||||||
cx.const_values.get_copy(&def_id.node)
|
cx.const_values.get_copy(&def_id.node)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn const_expr(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
pub fn const_expr(cx: @mut CrateContext, e: @ast::expr) -> ValueRef {
|
||||||
let mut llconst = const_expr_unadjusted(cx, e);
|
let mut llconst = const_expr_unadjusted(cx, e);
|
||||||
let ety = ty::expr_ty(cx.tcx, e);
|
let ety = ty::expr_ty(cx.tcx, e);
|
||||||
match cx.tcx.adjustments.find(&e.id) {
|
let adjustment = cx.tcx.adjustments.find_copy(&e.id);
|
||||||
|
match adjustment {
|
||||||
None => { }
|
None => { }
|
||||||
Some(&@ty::AutoAddEnv(ty::re_static, ast::BorrowedSigil)) => {
|
Some(@ty::AutoAddEnv(ty::re_static, ast::BorrowedSigil)) => {
|
||||||
llconst = C_struct([llconst, C_null(T_opaque_box_ptr(cx))])
|
llconst = C_struct([llconst, C_null(T_opaque_box_ptr(cx))])
|
||||||
}
|
}
|
||||||
Some(&@ty::AutoAddEnv(ref r, ref s)) => {
|
Some(@ty::AutoAddEnv(ref r, ref s)) => {
|
||||||
cx.sess.span_bug(e.span, fmt!("unexpected static function: \
|
cx.sess.span_bug(e.span, fmt!("unexpected static function: \
|
||||||
region %? sigil %?", *r, *s))
|
region %? sigil %?", *r, *s))
|
||||||
}
|
}
|
||||||
Some(&@ty::AutoDerefRef(ref adj)) => {
|
Some(@ty::AutoDerefRef(ref adj)) => {
|
||||||
let mut ty = ety;
|
let mut ty = ety;
|
||||||
let mut maybe_ptr = None;
|
let mut maybe_ptr = None;
|
||||||
for adj.autoderefs.times {
|
for adj.autoderefs.times {
|
||||||
@ -246,7 +246,7 @@ pub fn const_expr(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
llconst
|
llconst
|
||||||
}
|
}
|
||||||
|
|
||||||
fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
fn const_expr_unadjusted(cx: @mut CrateContext, e: @ast::expr) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let _icx = cx.insn_ctxt("const_expr");
|
let _icx = cx.insn_ctxt("const_expr");
|
||||||
return match e.node {
|
return match e.node {
|
||||||
@ -445,7 +445,8 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
(expr::cast_enum, expr::cast_integral) |
|
(expr::cast_enum, expr::cast_integral) |
|
||||||
(expr::cast_enum, expr::cast_float) => {
|
(expr::cast_enum, expr::cast_float) => {
|
||||||
let repr = adt::represent_type(cx, basety);
|
let repr = adt::represent_type(cx, basety);
|
||||||
let iv = C_int(cx, adt::const_get_discrim(cx, repr, v));
|
let discr = adt::const_get_discrim(cx, repr, v);
|
||||||
|
let iv = C_int(cx, discr);
|
||||||
let ety_cast = expr::cast_type_kind(ety);
|
let ety_cast = expr::cast_type_kind(ety);
|
||||||
match ety_cast {
|
match ety_cast {
|
||||||
expr::cast_integral => {
|
expr::cast_integral => {
|
||||||
@ -470,17 +471,20 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
ast::expr_addr_of(ast::m_imm, sub) => {
|
ast::expr_addr_of(ast::m_imm, sub) => {
|
||||||
const_addr_of(cx, const_expr(cx, sub))
|
let e = const_expr(cx, sub);
|
||||||
|
const_addr_of(cx, e)
|
||||||
}
|
}
|
||||||
ast::expr_tup(ref es) => {
|
ast::expr_tup(ref es) => {
|
||||||
let ety = ty::expr_ty(cx.tcx, e);
|
let ety = ty::expr_ty(cx.tcx, e);
|
||||||
let repr = adt::represent_type(cx, ety);
|
let repr = adt::represent_type(cx, ety);
|
||||||
adt::trans_const(cx, repr, 0, es.map(|e| const_expr(cx, *e)))
|
let vals = es.map(|&e| const_expr(cx, e));
|
||||||
|
adt::trans_const(cx, repr, 0, vals)
|
||||||
}
|
}
|
||||||
ast::expr_struct(_, ref fs, None) => {
|
ast::expr_struct(_, ref fs, None) => {
|
||||||
let ety = ty::expr_ty(cx.tcx, e);
|
let ety = ty::expr_ty(cx.tcx, e);
|
||||||
let repr = adt::represent_type(cx, ety);
|
let repr = adt::represent_type(cx, ety);
|
||||||
do expr::with_field_tys(cx.tcx, ety, Some(e.id))
|
let tcx = cx.tcx;
|
||||||
|
do expr::with_field_tys(tcx, ety, Some(e.id))
|
||||||
|discr, field_tys| {
|
|discr, field_tys| {
|
||||||
let cs = field_tys.map(|field_ty| {
|
let cs = field_tys.map(|field_ty| {
|
||||||
match fs.find(|f| field_ty.ident == f.node.ident) {
|
match fs.find(|f| field_ty.ident == f.node.ident) {
|
||||||
@ -522,7 +526,8 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
}
|
}
|
||||||
ast::expr_path(pth) => {
|
ast::expr_path(pth) => {
|
||||||
assert_eq!(pth.types.len(), 0);
|
assert_eq!(pth.types.len(), 0);
|
||||||
match cx.tcx.def_map.find(&e.id) {
|
let tcx = cx.tcx;
|
||||||
|
match tcx.def_map.find(&e.id) {
|
||||||
Some(&ast::def_fn(def_id, _purity)) => {
|
Some(&ast::def_fn(def_id, _purity)) => {
|
||||||
if !ast_util::is_local(def_id) {
|
if !ast_util::is_local(def_id) {
|
||||||
let ty = csearch::get_type(cx.tcx, def_id).ty;
|
let ty = csearch::get_type(cx.tcx, def_id).ty;
|
||||||
@ -554,12 +559,13 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
ast::expr_call(callee, ref args, _) => {
|
ast::expr_call(callee, ref args, _) => {
|
||||||
match cx.tcx.def_map.find(&callee.id) {
|
let tcx = cx.tcx;
|
||||||
|
match tcx.def_map.find(&callee.id) {
|
||||||
Some(&ast::def_struct(_)) => {
|
Some(&ast::def_struct(_)) => {
|
||||||
let ety = ty::expr_ty(cx.tcx, e);
|
let ety = ty::expr_ty(cx.tcx, e);
|
||||||
let repr = adt::represent_type(cx, ety);
|
let repr = adt::represent_type(cx, ety);
|
||||||
adt::trans_const(cx, repr, 0,
|
let arg_vals = args.map(|a| const_expr(cx, *a));
|
||||||
args.map(|a| const_expr(cx, *a)))
|
adt::trans_const(cx, repr, 0, arg_vals)
|
||||||
}
|
}
|
||||||
Some(&ast::def_variant(enum_did, variant_did)) => {
|
Some(&ast::def_variant(enum_did, variant_did)) => {
|
||||||
let ety = ty::expr_ty(cx.tcx, e);
|
let ety = ty::expr_ty(cx.tcx, e);
|
||||||
@ -567,8 +573,8 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
let vinfo = ty::enum_variant_with_id(cx.tcx,
|
let vinfo = ty::enum_variant_with_id(cx.tcx,
|
||||||
enum_did,
|
enum_did,
|
||||||
variant_did);
|
variant_did);
|
||||||
adt::trans_const(cx, repr, vinfo.disr_val,
|
let arg_vals = args.map(|a| const_expr(cx, *a));
|
||||||
args.map(|a| const_expr(cx, *a)))
|
adt::trans_const(cx, repr, vinfo.disr_val, arg_vals)
|
||||||
}
|
}
|
||||||
_ => cx.sess.span_bug(e.span, "expected a struct or variant def")
|
_ => cx.sess.span_bug(e.span, "expected a struct or variant def")
|
||||||
}
|
}
|
||||||
@ -580,7 +586,7 @@ fn const_expr_unadjusted(cx: @CrateContext, e: @ast::expr) -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_const(ccx: @CrateContext, _e: @ast::expr, id: ast::node_id) {
|
pub fn trans_const(ccx: @mut CrateContext, _e: @ast::expr, id: ast::node_id) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let _icx = ccx.insn_ctxt("trans_const");
|
let _icx = ccx.insn_ctxt("trans_const");
|
||||||
let g = base::get_item_val(ccx, id);
|
let g = base::get_item_val(ccx, id);
|
||||||
|
@ -1,3 +1,13 @@
|
|||||||
|
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
use core::prelude::*;
|
use core::prelude::*;
|
||||||
|
|
||||||
use back::{upcall};
|
use back::{upcall};
|
||||||
@ -39,29 +49,29 @@ pub struct CrateContext {
|
|||||||
tn: @TypeNames,
|
tn: @TypeNames,
|
||||||
externs: ExternMap,
|
externs: ExternMap,
|
||||||
intrinsics: HashMap<&'static str, ValueRef>,
|
intrinsics: HashMap<&'static str, ValueRef>,
|
||||||
item_vals: @mut HashMap<ast::node_id, ValueRef>,
|
item_vals: HashMap<ast::node_id, ValueRef>,
|
||||||
exp_map2: resolve::ExportMap2,
|
exp_map2: resolve::ExportMap2,
|
||||||
reachable: reachable::map,
|
reachable: reachable::map,
|
||||||
item_symbols: @mut HashMap<ast::node_id, ~str>,
|
item_symbols: HashMap<ast::node_id, ~str>,
|
||||||
link_meta: LinkMeta,
|
link_meta: LinkMeta,
|
||||||
enum_sizes: @mut HashMap<ty::t, uint>,
|
enum_sizes: HashMap<ty::t, uint>,
|
||||||
discrims: @mut HashMap<ast::def_id, ValueRef>,
|
discrims: HashMap<ast::def_id, ValueRef>,
|
||||||
discrim_symbols: @mut HashMap<ast::node_id, @str>,
|
discrim_symbols: HashMap<ast::node_id, @str>,
|
||||||
tydescs: @mut HashMap<ty::t, @mut tydesc_info>,
|
tydescs: HashMap<ty::t, @mut tydesc_info>,
|
||||||
// Set when running emit_tydescs to enforce that no more tydescs are
|
// Set when running emit_tydescs to enforce that no more tydescs are
|
||||||
// created.
|
// created.
|
||||||
finished_tydescs: @mut bool,
|
finished_tydescs: bool,
|
||||||
// Track mapping of external ids to local items imported for inlining
|
// Track mapping of external ids to local items imported for inlining
|
||||||
external: @mut HashMap<ast::def_id, Option<ast::node_id>>,
|
external: HashMap<ast::def_id, Option<ast::node_id>>,
|
||||||
// Cache instances of monomorphized functions
|
// Cache instances of monomorphized functions
|
||||||
monomorphized: @mut HashMap<mono_id, ValueRef>,
|
monomorphized: HashMap<mono_id, ValueRef>,
|
||||||
monomorphizing: @mut HashMap<ast::def_id, uint>,
|
monomorphizing: HashMap<ast::def_id, uint>,
|
||||||
// Cache computed type parameter uses (see type_use.rs)
|
// Cache computed type parameter uses (see type_use.rs)
|
||||||
type_use_cache: @mut HashMap<ast::def_id, @~[type_use::type_uses]>,
|
type_use_cache: HashMap<ast::def_id, @~[type_use::type_uses]>,
|
||||||
// Cache generated vtables
|
// Cache generated vtables
|
||||||
vtables: @mut HashMap<mono_id, ValueRef>,
|
vtables: HashMap<mono_id, ValueRef>,
|
||||||
// Cache of constant strings,
|
// Cache of constant strings,
|
||||||
const_cstr_cache: @mut HashMap<@str, ValueRef>,
|
const_cstr_cache: HashMap<@str, ValueRef>,
|
||||||
|
|
||||||
// Reverse-direction for const ptrs cast from globals.
|
// Reverse-direction for const ptrs cast from globals.
|
||||||
// Key is an int, cast from a ValueRef holding a *T,
|
// Key is an int, cast from a ValueRef holding a *T,
|
||||||
@ -71,27 +81,27 @@ pub struct CrateContext {
|
|||||||
// when we ptrcast, and we have to ptrcast during translation
|
// when we ptrcast, and we have to ptrcast during translation
|
||||||
// of a [T] const because we form a slice, a [*T,int] pair, not
|
// of a [T] const because we form a slice, a [*T,int] pair, not
|
||||||
// a pointer to an LLVM array type.
|
// a pointer to an LLVM array type.
|
||||||
const_globals: @mut HashMap<int, ValueRef>,
|
const_globals: HashMap<int, ValueRef>,
|
||||||
|
|
||||||
// Cache of emitted const values
|
// Cache of emitted const values
|
||||||
const_values: @mut HashMap<ast::node_id, ValueRef>,
|
const_values: HashMap<ast::node_id, ValueRef>,
|
||||||
|
|
||||||
// Cache of external const values
|
// Cache of external const values
|
||||||
extern_const_values: @mut HashMap<ast::def_id, ValueRef>,
|
extern_const_values: HashMap<ast::def_id, ValueRef>,
|
||||||
|
|
||||||
module_data: @mut HashMap<~str, ValueRef>,
|
module_data: HashMap<~str, ValueRef>,
|
||||||
lltypes: @mut HashMap<ty::t, TypeRef>,
|
lltypes: HashMap<ty::t, TypeRef>,
|
||||||
llsizingtypes: @mut HashMap<ty::t, TypeRef>,
|
llsizingtypes: HashMap<ty::t, TypeRef>,
|
||||||
adt_reprs: @mut HashMap<ty::t, @adt::Repr>,
|
adt_reprs: HashMap<ty::t, @adt::Repr>,
|
||||||
names: namegen,
|
names: namegen,
|
||||||
next_addrspace: addrspace_gen,
|
next_addrspace: addrspace_gen,
|
||||||
symbol_hasher: @mut hash::State,
|
symbol_hasher: hash::State,
|
||||||
type_hashcodes: @mut HashMap<ty::t, @str>,
|
type_hashcodes: HashMap<ty::t, @str>,
|
||||||
type_short_names: @mut HashMap<ty::t, ~str>,
|
type_short_names: HashMap<ty::t, ~str>,
|
||||||
all_llvm_symbols: @mut HashSet<@str>,
|
all_llvm_symbols: HashSet<@str>,
|
||||||
tcx: ty::ctxt,
|
tcx: ty::ctxt,
|
||||||
maps: astencode::Maps,
|
maps: astencode::Maps,
|
||||||
stats: @mut Stats,
|
stats: Stats,
|
||||||
upcalls: @upcall::Upcalls,
|
upcalls: @upcall::Upcalls,
|
||||||
tydesc_type: TypeRef,
|
tydesc_type: TypeRef,
|
||||||
int_type: TypeRef,
|
int_type: TypeRef,
|
||||||
@ -103,15 +113,15 @@ pub struct CrateContext {
|
|||||||
// Set when at least one function uses GC. Needed so that
|
// Set when at least one function uses GC. Needed so that
|
||||||
// decl_gc_metadata knows whether to link to the module metadata, which
|
// decl_gc_metadata knows whether to link to the module metadata, which
|
||||||
// is not emitted by LLVM's GC pass when no functions use GC.
|
// is not emitted by LLVM's GC pass when no functions use GC.
|
||||||
uses_gc: @mut bool,
|
uses_gc: bool,
|
||||||
dbg_cx: Option<debuginfo::DebugContext>,
|
dbg_cx: Option<debuginfo::DebugContext>,
|
||||||
do_not_commit_warning_issued: @mut bool
|
do_not_commit_warning_issued: bool
|
||||||
}
|
}
|
||||||
|
|
||||||
impl CrateContext {
|
impl CrateContext {
|
||||||
pub fn new(sess: session::Session, name: &str, tcx: ty::ctxt,
|
pub fn new(sess: session::Session, name: &str, tcx: ty::ctxt,
|
||||||
emap2: resolve::ExportMap2, maps: astencode::Maps,
|
emap2: resolve::ExportMap2, maps: astencode::Maps,
|
||||||
symbol_hasher: @mut hash::State, link_meta: LinkMeta,
|
symbol_hasher: hash::State, link_meta: LinkMeta,
|
||||||
reachable: reachable::map) -> CrateContext {
|
reachable: reachable::map) -> CrateContext {
|
||||||
unsafe {
|
unsafe {
|
||||||
let llcx = llvm::LLVMContextCreate();
|
let llcx = llvm::LLVMContextCreate();
|
||||||
@ -147,40 +157,40 @@ impl CrateContext {
|
|||||||
llcx: llcx,
|
llcx: llcx,
|
||||||
td: td,
|
td: td,
|
||||||
tn: tn,
|
tn: tn,
|
||||||
externs: @mut HashMap::new(),
|
externs: HashMap::new(),
|
||||||
intrinsics: intrinsics,
|
intrinsics: intrinsics,
|
||||||
item_vals: @mut HashMap::new(),
|
item_vals: HashMap::new(),
|
||||||
exp_map2: emap2,
|
exp_map2: emap2,
|
||||||
reachable: reachable,
|
reachable: reachable,
|
||||||
item_symbols: @mut HashMap::new(),
|
item_symbols: HashMap::new(),
|
||||||
link_meta: link_meta,
|
link_meta: link_meta,
|
||||||
enum_sizes: @mut HashMap::new(),
|
enum_sizes: HashMap::new(),
|
||||||
discrims: @mut HashMap::new(),
|
discrims: HashMap::new(),
|
||||||
discrim_symbols: @mut HashMap::new(),
|
discrim_symbols: HashMap::new(),
|
||||||
tydescs: @mut HashMap::new(),
|
tydescs: HashMap::new(),
|
||||||
finished_tydescs: @mut false,
|
finished_tydescs: false,
|
||||||
external: @mut HashMap::new(),
|
external: HashMap::new(),
|
||||||
monomorphized: @mut HashMap::new(),
|
monomorphized: HashMap::new(),
|
||||||
monomorphizing: @mut HashMap::new(),
|
monomorphizing: HashMap::new(),
|
||||||
type_use_cache: @mut HashMap::new(),
|
type_use_cache: HashMap::new(),
|
||||||
vtables: @mut HashMap::new(),
|
vtables: HashMap::new(),
|
||||||
const_cstr_cache: @mut HashMap::new(),
|
const_cstr_cache: HashMap::new(),
|
||||||
const_globals: @mut HashMap::new(),
|
const_globals: HashMap::new(),
|
||||||
const_values: @mut HashMap::new(),
|
const_values: HashMap::new(),
|
||||||
extern_const_values: @mut HashMap::new(),
|
extern_const_values: HashMap::new(),
|
||||||
module_data: @mut HashMap::new(),
|
module_data: HashMap::new(),
|
||||||
lltypes: @mut HashMap::new(),
|
lltypes: HashMap::new(),
|
||||||
llsizingtypes: @mut HashMap::new(),
|
llsizingtypes: HashMap::new(),
|
||||||
adt_reprs: @mut HashMap::new(),
|
adt_reprs: HashMap::new(),
|
||||||
names: new_namegen(),
|
names: new_namegen(),
|
||||||
next_addrspace: new_addrspace_gen(),
|
next_addrspace: new_addrspace_gen(),
|
||||||
symbol_hasher: symbol_hasher,
|
symbol_hasher: symbol_hasher,
|
||||||
type_hashcodes: @mut HashMap::new(),
|
type_hashcodes: HashMap::new(),
|
||||||
type_short_names: @mut HashMap::new(),
|
type_short_names: HashMap::new(),
|
||||||
all_llvm_symbols: @mut HashSet::new(),
|
all_llvm_symbols: HashSet::new(),
|
||||||
tcx: tcx,
|
tcx: tcx,
|
||||||
maps: maps,
|
maps: maps,
|
||||||
stats: @mut Stats {
|
stats: Stats {
|
||||||
n_static_tydescs: 0u,
|
n_static_tydescs: 0u,
|
||||||
n_glues_created: 0u,
|
n_glues_created: 0u,
|
||||||
n_null_glues: 0u,
|
n_null_glues: 0u,
|
||||||
@ -189,9 +199,9 @@ impl CrateContext {
|
|||||||
n_monos: 0u,
|
n_monos: 0u,
|
||||||
n_inlines: 0u,
|
n_inlines: 0u,
|
||||||
n_closures: 0u,
|
n_closures: 0u,
|
||||||
llvm_insn_ctxt: @mut ~[],
|
llvm_insn_ctxt: ~[],
|
||||||
llvm_insns: @mut HashMap::new(),
|
llvm_insns: HashMap::new(),
|
||||||
fn_times: @mut ~[]
|
fn_times: ~[]
|
||||||
},
|
},
|
||||||
upcalls: upcall::declare_upcalls(targ_cfg, llmod),
|
upcalls: upcall::declare_upcalls(targ_cfg, llmod),
|
||||||
tydesc_type: tydesc_type,
|
tydesc_type: tydesc_type,
|
||||||
@ -203,9 +213,9 @@ impl CrateContext {
|
|||||||
}),
|
}),
|
||||||
shape_cx: mk_ctxt(llmod),
|
shape_cx: mk_ctxt(llmod),
|
||||||
crate_map: crate_map,
|
crate_map: crate_map,
|
||||||
uses_gc: @mut false,
|
uses_gc: false,
|
||||||
dbg_cx: dbg_cx,
|
dbg_cx: dbg_cx,
|
||||||
do_not_commit_warning_issued: @mut false
|
do_not_commit_warning_issued: false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -844,7 +844,7 @@ impl DatumBlock {
|
|||||||
rslt(self.bcx, self.datum.to_appropriate_llval(self.bcx))
|
rslt(self.bcx, self.datum.to_appropriate_llval(self.bcx))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn ccx(&self) -> @CrateContext {
|
pub fn ccx(&self) -> @mut CrateContext {
|
||||||
self.bcx.ccx()
|
self.bcx.ccx()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ fn llnull() -> ValueRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn add_named_metadata(cx: @CrateContext, name: ~str, val: ValueRef) {
|
fn add_named_metadata(cx: &CrateContext, name: ~str, val: ValueRef) {
|
||||||
str::as_c_str(name, |sbuf| {
|
str::as_c_str(name, |sbuf| {
|
||||||
unsafe {
|
unsafe {
|
||||||
llvm::LLVMAddNamedMetadataOperand(cx.llmod, sbuf, val)
|
llvm::LLVMAddNamedMetadataOperand(cx.llmod, sbuf, val)
|
||||||
@ -208,7 +208,7 @@ fn cached_metadata<T:Copy>(cache: metadata_cache,
|
|||||||
return option::None;
|
return option::None;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_compile_unit(cx: @CrateContext) -> @Metadata<CompileUnitMetadata> {
|
fn create_compile_unit(cx: &mut CrateContext) -> @Metadata<CompileUnitMetadata> {
|
||||||
let cache = get_cache(cx);
|
let cache = get_cache(cx);
|
||||||
let crate_name = /*bad*/copy (/*bad*/copy cx.dbg_cx).get().crate_file;
|
let crate_name = /*bad*/copy (/*bad*/copy cx.dbg_cx).get().crate_file;
|
||||||
let tg = CompileUnitTag;
|
let tg = CompileUnitTag;
|
||||||
@ -244,8 +244,8 @@ fn create_compile_unit(cx: @CrateContext) -> @Metadata<CompileUnitMetadata> {
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_cache(cx: @CrateContext) -> metadata_cache {
|
fn get_cache(cx: &CrateContext) -> metadata_cache {
|
||||||
(/*bad*/copy cx.dbg_cx).get().llmetadata
|
cx.dbg_cx.get_ref().llmetadata
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_file_path_and_dir(work_dir: &str, full_path: &str) -> (~str, ~str) {
|
fn get_file_path_and_dir(work_dir: &str, full_path: &str) -> (~str, ~str) {
|
||||||
@ -257,7 +257,7 @@ fn get_file_path_and_dir(work_dir: &str, full_path: &str) -> (~str, ~str) {
|
|||||||
}, work_dir.to_owned())
|
}, work_dir.to_owned())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_file(cx: @CrateContext, full_path: ~str)
|
fn create_file(cx: &mut CrateContext, full_path: ~str)
|
||||||
-> @Metadata<FileMetadata> {
|
-> @Metadata<FileMetadata> {
|
||||||
let cache = get_cache(cx);;
|
let cache = get_cache(cx);;
|
||||||
let tg = FileDescriptorTag;
|
let tg = FileDescriptorTag;
|
||||||
@ -290,9 +290,8 @@ fn line_from_span(cm: @codemap::CodeMap, sp: span) -> uint {
|
|||||||
cm.lookup_char_pos(sp.lo).line
|
cm.lookup_char_pos(sp.lo).line
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_block(cx: block) -> @Metadata<BlockMetadata> {
|
fn create_block(mut cx: block) -> @Metadata<BlockMetadata> {
|
||||||
let cache = get_cache(cx.ccx());
|
let cache = get_cache(cx.ccx());
|
||||||
let mut cx = cx;
|
|
||||||
while cx.node_info.is_none() {
|
while cx.node_info.is_none() {
|
||||||
match cx.parent {
|
match cx.parent {
|
||||||
Some(b) => cx = b,
|
Some(b) => cx = b,
|
||||||
@ -340,13 +339,13 @@ fn create_block(cx: block) -> @Metadata<BlockMetadata> {
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn size_and_align_of(cx: @CrateContext, t: ty::t) -> (int, int) {
|
fn size_and_align_of(cx: &mut CrateContext, t: ty::t) -> (int, int) {
|
||||||
let llty = type_of::type_of(cx, t);
|
let llty = type_of::type_of(cx, t);
|
||||||
(machine::llsize_of_real(cx, llty) as int,
|
(machine::llsize_of_real(cx, llty) as int,
|
||||||
machine::llalign_of_pref(cx, llty) as int)
|
machine::llalign_of_pref(cx, llty) as int)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_basic_type(cx: @CrateContext, t: ty::t, span: span)
|
fn create_basic_type(cx: &mut CrateContext, t: ty::t, span: span)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
let cache = get_cache(cx);
|
let cache = get_cache(cx);
|
||||||
let tg = BasicTypeDescriptorTag;
|
let tg = BasicTypeDescriptorTag;
|
||||||
@ -408,7 +407,7 @@ fn create_basic_type(cx: @CrateContext, t: ty::t, span: span)
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_pointer_type(cx: @CrateContext, t: ty::t, span: span,
|
fn create_pointer_type(cx: &mut CrateContext, t: ty::t, span: span,
|
||||||
pointee: @Metadata<TyDescMetadata>)
|
pointee: @Metadata<TyDescMetadata>)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
let tg = PointerTypeTag;
|
let tg = PointerTypeTag;
|
||||||
@ -498,7 +497,7 @@ fn add_member(cx: @mut StructCtxt,
|
|||||||
cx.total_size += size * 8;
|
cx.total_size += size * 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_struct(cx: @CrateContext, t: ty::t, fields: ~[ty::field],
|
fn create_struct(cx: &mut CrateContext, t: ty::t, fields: ~[ty::field],
|
||||||
span: span) -> @Metadata<TyDescMetadata> {
|
span: span) -> @Metadata<TyDescMetadata> {
|
||||||
let fname = filename_from_span(cx, span);
|
let fname = filename_from_span(cx, span);
|
||||||
let file_node = create_file(cx, fname.to_owned());
|
let file_node = create_file(cx, fname.to_owned());
|
||||||
@ -521,7 +520,7 @@ fn create_struct(cx: @CrateContext, t: ty::t, fields: ~[ty::field],
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_tuple(cx: @CrateContext, t: ty::t, elements: &[ty::t], span: span)
|
fn create_tuple(cx: &mut CrateContext, t: ty::t, elements: &[ty::t], span: span)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
let fname = filename_from_span(cx, span);
|
let fname = filename_from_span(cx, span);
|
||||||
let file_node = create_file(cx, fname.to_owned());
|
let file_node = create_file(cx, fname.to_owned());
|
||||||
@ -555,7 +554,7 @@ fn voidptr() -> (ValueRef, int, int) {
|
|||||||
return (vp, size, align);
|
return (vp, size, align);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_boxed_type(cx: @CrateContext, contents: ty::t,
|
fn create_boxed_type(cx: &mut CrateContext, contents: ty::t,
|
||||||
span: span, boxed: @Metadata<TyDescMetadata>)
|
span: span, boxed: @Metadata<TyDescMetadata>)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
//let tg = StructureTypeTag;
|
//let tg = StructureTypeTag;
|
||||||
@ -624,7 +623,7 @@ fn create_composite_type(type_tag: int, name: &str, file: ValueRef,
|
|||||||
return llmdnode(lldata);
|
return llmdnode(lldata);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_fixed_vec(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t,
|
fn create_fixed_vec(cx: &mut CrateContext, vec_t: ty::t, elem_t: ty::t,
|
||||||
len: int, span: span) -> @Metadata<TyDescMetadata> {
|
len: int, span: span) -> @Metadata<TyDescMetadata> {
|
||||||
let t_md = create_ty(cx, elem_t, span);
|
let t_md = create_ty(cx, elem_t, span);
|
||||||
let fname = filename_from_span(cx, span);
|
let fname = filename_from_span(cx, span);
|
||||||
@ -643,7 +642,7 @@ fn create_fixed_vec(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_boxed_vec(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t,
|
fn create_boxed_vec(cx: &mut CrateContext, vec_t: ty::t, elem_t: ty::t,
|
||||||
vec_ty_span: codemap::span)
|
vec_ty_span: codemap::span)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
let fname = filename_from_span(cx, vec_ty_span);
|
let fname = filename_from_span(cx, vec_ty_span);
|
||||||
@ -695,7 +694,7 @@ fn create_boxed_vec(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t,
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_vec_slice(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t, span: span)
|
fn create_vec_slice(cx: &mut CrateContext, vec_t: ty::t, elem_t: ty::t, span: span)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
let fname = filename_from_span(cx, span);
|
let fname = filename_from_span(cx, span);
|
||||||
let file_node = create_file(cx, fname.to_owned());
|
let file_node = create_file(cx, fname.to_owned());
|
||||||
@ -717,7 +716,7 @@ fn create_vec_slice(cx: @CrateContext, vec_t: ty::t, elem_t: ty::t, span: span)
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_fn_ty(cx: @CrateContext, fn_ty: ty::t, inputs: ~[ty::t], output: ty::t,
|
fn create_fn_ty(cx: &mut CrateContext, fn_ty: ty::t, inputs: ~[ty::t], output: ty::t,
|
||||||
span: span) -> @Metadata<TyDescMetadata> {
|
span: span) -> @Metadata<TyDescMetadata> {
|
||||||
let fname = filename_from_span(cx, span);
|
let fname = filename_from_span(cx, span);
|
||||||
let file_node = create_file(cx, fname.to_owned());
|
let file_node = create_file(cx, fname.to_owned());
|
||||||
@ -737,7 +736,7 @@ fn create_fn_ty(cx: @CrateContext, fn_ty: ty::t, inputs: ~[ty::t], output: ty::t
|
|||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn create_ty(cx: @CrateContext, t: ty::t, span: span)
|
fn create_ty(cx: &mut CrateContext, t: ty::t, span: span)
|
||||||
-> @Metadata<TyDescMetadata> {
|
-> @Metadata<TyDescMetadata> {
|
||||||
debug!("create_ty: %?", ty::get(t));
|
debug!("create_ty: %?", ty::get(t));
|
||||||
/*let cache = get_cache(cx);
|
/*let cache = get_cache(cx);
|
||||||
@ -817,7 +816,7 @@ fn create_ty(cx: @CrateContext, t: ty::t, span: span)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn filename_from_span(cx: @CrateContext, sp: codemap::span) -> @str {
|
fn filename_from_span(cx: &CrateContext, sp: codemap::span) -> @str {
|
||||||
cx.sess.codemap.lookup_char_pos(sp.lo).file.name
|
cx.sess.codemap.lookup_char_pos(sp.lo).file.name
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -878,7 +877,7 @@ pub fn create_local_var(bcx: block, local: @ast::local)
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
let declargs = ~[llmdnode([llptr]), mdnode];
|
let declargs = ~[llmdnode([llptr]), mdnode];
|
||||||
trans::build::Call(bcx, *cx.intrinsics.get(&("llvm.dbg.declare")),
|
trans::build::Call(bcx, cx.intrinsics.get_copy(&("llvm.dbg.declare")),
|
||||||
declargs);
|
declargs);
|
||||||
return mdval;
|
return mdval;
|
||||||
}
|
}
|
||||||
@ -886,7 +885,7 @@ pub fn create_local_var(bcx: block, local: @ast::local)
|
|||||||
pub fn create_arg(bcx: block, arg: ast::arg, sp: span)
|
pub fn create_arg(bcx: block, arg: ast::arg, sp: span)
|
||||||
-> Option<@Metadata<ArgumentMetadata>> {
|
-> Option<@Metadata<ArgumentMetadata>> {
|
||||||
let fcx = bcx.fcx;
|
let fcx = bcx.fcx;
|
||||||
let cx = *fcx.ccx;
|
let cx = fcx.ccx;
|
||||||
let cache = get_cache(cx);
|
let cache = get_cache(cx);
|
||||||
let tg = ArgVariableTag;
|
let tg = ArgVariableTag;
|
||||||
match cached_metadata::<@Metadata<ArgumentMetadata>>(
|
match cached_metadata::<@Metadata<ArgumentMetadata>>(
|
||||||
@ -927,7 +926,7 @@ pub fn create_arg(bcx: block, arg: ast::arg, sp: span)
|
|||||||
let llptr = fcx.llargs.get_copy(&arg.id);
|
let llptr = fcx.llargs.get_copy(&arg.id);
|
||||||
let declargs = ~[llmdnode([llptr]), mdnode];
|
let declargs = ~[llmdnode([llptr]), mdnode];
|
||||||
trans::build::Call(bcx,
|
trans::build::Call(bcx,
|
||||||
*cx.intrinsics.get(&("llvm.dbg.declare")),
|
cx.intrinsics.get_copy(&("llvm.dbg.declare")),
|
||||||
declargs);
|
declargs);
|
||||||
return Some(mdval);
|
return Some(mdval);
|
||||||
}
|
}
|
||||||
@ -955,8 +954,7 @@ pub fn update_source_pos(cx: block, s: span) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn create_function(fcx: fn_ctxt) -> @Metadata<SubProgramMetadata> {
|
pub fn create_function(fcx: fn_ctxt) -> @Metadata<SubProgramMetadata> {
|
||||||
let cx = *fcx.ccx;
|
let mut cx = fcx.ccx;
|
||||||
let dbg_cx = (/*bad*/copy cx.dbg_cx).get();
|
|
||||||
|
|
||||||
debug!("~~");
|
debug!("~~");
|
||||||
|
|
||||||
@ -980,6 +978,7 @@ pub fn create_function(fcx: fn_ctxt) -> @Metadata<SubProgramMetadata> {
|
|||||||
ast_map::node_expr(expr) => {
|
ast_map::node_expr(expr) => {
|
||||||
match expr.node {
|
match expr.node {
|
||||||
ast::expr_fn_block(ref decl, _) => {
|
ast::expr_fn_block(ref decl, _) => {
|
||||||
|
let dbg_cx = cx.dbg_cx.get_ref();
|
||||||
((dbg_cx.names)("fn"), decl.output, expr.id)
|
((dbg_cx.names)("fn"), decl.output, expr.id)
|
||||||
}
|
}
|
||||||
_ => fcx.ccx.sess.span_bug(expr.span,
|
_ => fcx.ccx.sess.span_bug(expr.span,
|
||||||
|
@ -171,7 +171,7 @@ pub enum Dest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Dest {
|
impl Dest {
|
||||||
pub fn to_str(&self, ccx: @CrateContext) -> ~str {
|
pub fn to_str(&self, ccx: &CrateContext) -> ~str {
|
||||||
match *self {
|
match *self {
|
||||||
SaveIn(v) => fmt!("SaveIn(%s)", val_str(ccx.tn, v)),
|
SaveIn(v) => fmt!("SaveIn(%s)", val_str(ccx.tn, v)),
|
||||||
Ignore => ~"Ignore"
|
Ignore => ~"Ignore"
|
||||||
@ -946,7 +946,7 @@ fn trans_lvalue_unadjusted(bcx: block, expr: @ast::expr) -> DatumBlock {
|
|||||||
ast::def_const(did) => {
|
ast::def_const(did) => {
|
||||||
let const_ty = expr_ty(bcx, ref_expr);
|
let const_ty = expr_ty(bcx, ref_expr);
|
||||||
|
|
||||||
fn get_did(ccx: @CrateContext, did: ast::def_id)
|
fn get_did(ccx: @mut CrateContext, did: ast::def_id)
|
||||||
-> ast::def_id {
|
-> ast::def_id {
|
||||||
if did.crate != ast::local_crate {
|
if did.crate != ast::local_crate {
|
||||||
inline::maybe_instantiate_inline(ccx, did, true)
|
inline::maybe_instantiate_inline(ccx, did, true)
|
||||||
@ -958,20 +958,21 @@ fn trans_lvalue_unadjusted(bcx: block, expr: @ast::expr) -> DatumBlock {
|
|||||||
fn get_val(bcx: block, did: ast::def_id, const_ty: ty::t)
|
fn get_val(bcx: block, did: ast::def_id, const_ty: ty::t)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
// For external constants, we don't inline.
|
// For external constants, we don't inline.
|
||||||
let extern_const_values =
|
|
||||||
&mut *bcx.ccx().extern_const_values;
|
|
||||||
if did.crate == ast::local_crate {
|
if did.crate == ast::local_crate {
|
||||||
// The LLVM global has the type of its initializer,
|
// The LLVM global has the type of its initializer,
|
||||||
// which may not be equal to the enum's type for
|
// which may not be equal to the enum's type for
|
||||||
// non-C-like enums.
|
// non-C-like enums.
|
||||||
PointerCast(bcx,
|
let val = base::get_item_val(bcx.ccx(), did.node);
|
||||||
base::get_item_val(bcx.ccx(), did.node),
|
let pty = T_ptr(type_of(bcx.ccx(), const_ty));
|
||||||
T_ptr(type_of(bcx.ccx(), const_ty)))
|
PointerCast(bcx, val, pty)
|
||||||
} else {
|
} else {
|
||||||
match extern_const_values.find(&did) {
|
{
|
||||||
None => {} // Continue.
|
let extern_const_values = &bcx.ccx().extern_const_values;
|
||||||
Some(llval) => {
|
match extern_const_values.find(&did) {
|
||||||
return *llval;
|
None => {} // Continue.
|
||||||
|
Some(llval) => {
|
||||||
|
return *llval;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -984,6 +985,7 @@ fn trans_lvalue_unadjusted(bcx: block, expr: @ast::expr) -> DatumBlock {
|
|||||||
bcx.ccx().llmod,
|
bcx.ccx().llmod,
|
||||||
llty,
|
llty,
|
||||||
transmute::<&u8,*i8>(&symbol[0]));
|
transmute::<&u8,*i8>(&symbol[0]));
|
||||||
|
let extern_const_values = &mut bcx.ccx().extern_const_values;
|
||||||
extern_const_values.insert(did, llval);
|
extern_const_values.insert(did, llval);
|
||||||
llval
|
llval
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ use syntax::abi::{X86, X86_64, Arm, Mips};
|
|||||||
use syntax::abi::{RustIntrinsic, Rust, Stdcall, Fastcall,
|
use syntax::abi::{RustIntrinsic, Rust, Stdcall, Fastcall,
|
||||||
Cdecl, Aapcs, C};
|
Cdecl, Aapcs, C};
|
||||||
|
|
||||||
fn abi_info(ccx: @CrateContext) -> @cabi::ABIInfo {
|
fn abi_info(ccx: @mut CrateContext) -> @cabi::ABIInfo {
|
||||||
return match ccx.sess.targ_cfg.arch {
|
return match ccx.sess.targ_cfg.arch {
|
||||||
X86 => cabi_x86::abi_info(ccx),
|
X86 => cabi_x86::abi_info(ccx),
|
||||||
X86_64 => cabi_x86_64::abi_info(),
|
X86_64 => cabi_x86_64::abi_info(),
|
||||||
@ -55,7 +55,7 @@ fn abi_info(ccx: @CrateContext) -> @cabi::ABIInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn link_name(ccx: @CrateContext, i: @ast::foreign_item) -> @str {
|
pub fn link_name(ccx: &CrateContext, i: @ast::foreign_item) -> @str {
|
||||||
match attr::first_attr_value_str_by_name(i.attrs, "link_name") {
|
match attr::first_attr_value_str_by_name(i.attrs, "link_name") {
|
||||||
None => ccx.sess.str_of(i.ident),
|
None => ccx.sess.str_of(i.ident),
|
||||||
Some(ln) => ln,
|
Some(ln) => ln,
|
||||||
@ -89,7 +89,7 @@ struct LlvmSignature {
|
|||||||
sret: bool,
|
sret: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn foreign_signature(ccx: @CrateContext, fn_sig: &ty::FnSig)
|
fn foreign_signature(ccx: @mut CrateContext, fn_sig: &ty::FnSig)
|
||||||
-> LlvmSignature {
|
-> LlvmSignature {
|
||||||
/*!
|
/*!
|
||||||
* The ForeignSignature is the LLVM types of the arguments/return type
|
* The ForeignSignature is the LLVM types of the arguments/return type
|
||||||
@ -108,7 +108,7 @@ fn foreign_signature(ccx: @CrateContext, fn_sig: &ty::FnSig)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn shim_types(ccx: @CrateContext, id: ast::node_id) -> ShimTypes {
|
fn shim_types(ccx: @mut CrateContext, id: ast::node_id) -> ShimTypes {
|
||||||
let fn_sig = match ty::get(ty::node_id_to_type(ccx.tcx, id)).sty {
|
let fn_sig = match ty::get(ty::node_id_to_type(ccx.tcx, id)).sty {
|
||||||
ty::ty_bare_fn(ref fn_ty) => copy fn_ty.sig,
|
ty::ty_bare_fn(ref fn_ty) => copy fn_ty.sig,
|
||||||
_ => ccx.sess.bug("c_arg_and_ret_lltys called on non-function type")
|
_ => ccx.sess.bug("c_arg_and_ret_lltys called on non-function type")
|
||||||
@ -141,7 +141,7 @@ type shim_ret_builder<'self> =
|
|||||||
llargbundle: ValueRef,
|
llargbundle: ValueRef,
|
||||||
llretval: ValueRef);
|
llretval: ValueRef);
|
||||||
|
|
||||||
fn build_shim_fn_(ccx: @CrateContext,
|
fn build_shim_fn_(ccx: @mut CrateContext,
|
||||||
shim_name: ~str,
|
shim_name: ~str,
|
||||||
llbasefn: ValueRef,
|
llbasefn: ValueRef,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
@ -184,7 +184,7 @@ type wrap_ret_builder<'self> = &'self fn(bcx: block,
|
|||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
llargbundle: ValueRef);
|
llargbundle: ValueRef);
|
||||||
|
|
||||||
fn build_wrap_fn_(ccx: @CrateContext,
|
fn build_wrap_fn_(ccx: @mut CrateContext,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
llshimfn: ValueRef,
|
llshimfn: ValueRef,
|
||||||
llwrapfn: ValueRef,
|
llwrapfn: ValueRef,
|
||||||
@ -198,7 +198,7 @@ fn build_wrap_fn_(ccx: @CrateContext,
|
|||||||
// Patch up the return type if it's not immediate and we're returning via
|
// Patch up the return type if it's not immediate and we're returning via
|
||||||
// the C ABI.
|
// the C ABI.
|
||||||
if needs_c_return && !ty::type_is_immediate(tys.fn_sig.output) {
|
if needs_c_return && !ty::type_is_immediate(tys.fn_sig.output) {
|
||||||
let lloutputtype = type_of::type_of(*fcx.ccx, tys.fn_sig.output);
|
let lloutputtype = type_of::type_of(fcx.ccx, tys.fn_sig.output);
|
||||||
fcx.llretptr = Some(alloca(raw_block(fcx, false, fcx.llstaticallocas),
|
fcx.llretptr = Some(alloca(raw_block(fcx, false, fcx.llstaticallocas),
|
||||||
lloutputtype));
|
lloutputtype));
|
||||||
}
|
}
|
||||||
@ -282,7 +282,7 @@ fn build_wrap_fn_(ccx: @CrateContext,
|
|||||||
// round of copies. (In fact, the shim function itself is
|
// round of copies. (In fact, the shim function itself is
|
||||||
// unnecessary). We used to do this, in fact, and will perhaps do so
|
// unnecessary). We used to do this, in fact, and will perhaps do so
|
||||||
// in the future.
|
// in the future.
|
||||||
pub fn trans_foreign_mod(ccx: @CrateContext,
|
pub fn trans_foreign_mod(ccx: @mut CrateContext,
|
||||||
path: &ast_map::path,
|
path: &ast_map::path,
|
||||||
foreign_mod: &ast::foreign_mod) {
|
foreign_mod: &ast::foreign_mod) {
|
||||||
let _icx = ccx.insn_ctxt("foreign::trans_foreign_mod");
|
let _icx = ccx.insn_ctxt("foreign::trans_foreign_mod");
|
||||||
@ -350,7 +350,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_foreign_fn(ccx: @CrateContext,
|
fn build_foreign_fn(ccx: @mut CrateContext,
|
||||||
id: ast::node_id,
|
id: ast::node_id,
|
||||||
foreign_item: @ast::foreign_item,
|
foreign_item: @ast::foreign_item,
|
||||||
cc: lib::llvm::CallConv) {
|
cc: lib::llvm::CallConv) {
|
||||||
@ -367,7 +367,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_shim_fn(ccx: @CrateContext,
|
fn build_shim_fn(ccx: @mut CrateContext,
|
||||||
foreign_item: @ast::foreign_item,
|
foreign_item: @ast::foreign_item,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
cc: lib::llvm::CallConv)
|
cc: lib::llvm::CallConv)
|
||||||
@ -415,7 +415,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
build_ret)
|
build_ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn base_fn(ccx: @CrateContext,
|
fn base_fn(ccx: &CrateContext,
|
||||||
lname: &str,
|
lname: &str,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
cc: lib::llvm::CallConv)
|
cc: lib::llvm::CallConv)
|
||||||
@ -428,7 +428,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
|
|
||||||
// FIXME (#2535): this is very shaky and probably gets ABIs wrong all
|
// FIXME (#2535): this is very shaky and probably gets ABIs wrong all
|
||||||
// over the place
|
// over the place
|
||||||
fn build_direct_fn(ccx: @CrateContext,
|
fn build_direct_fn(ccx: @mut CrateContext,
|
||||||
decl: ValueRef,
|
decl: ValueRef,
|
||||||
item: @ast::foreign_item,
|
item: @ast::foreign_item,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
@ -455,7 +455,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
|
|
||||||
// FIXME (#2535): this is very shaky and probably gets ABIs wrong all
|
// FIXME (#2535): this is very shaky and probably gets ABIs wrong all
|
||||||
// over the place
|
// over the place
|
||||||
fn build_fast_ffi_fn(ccx: @CrateContext,
|
fn build_fast_ffi_fn(ccx: @mut CrateContext,
|
||||||
decl: ValueRef,
|
decl: ValueRef,
|
||||||
item: @ast::foreign_item,
|
item: @ast::foreign_item,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
@ -482,7 +482,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
finish_fn(fcx, lltop);
|
finish_fn(fcx, lltop);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_wrap_fn(ccx: @CrateContext,
|
fn build_wrap_fn(ccx: @mut CrateContext,
|
||||||
tys: &ShimTypes,
|
tys: &ShimTypes,
|
||||||
llshimfn: ValueRef,
|
llshimfn: ValueRef,
|
||||||
llwrapfn: ValueRef) {
|
llwrapfn: ValueRef) {
|
||||||
@ -546,7 +546,7 @@ pub fn trans_foreign_mod(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn trans_intrinsic(ccx: @CrateContext,
|
pub fn trans_intrinsic(ccx: @mut CrateContext,
|
||||||
decl: ValueRef,
|
decl: ValueRef,
|
||||||
item: @ast::foreign_item,
|
item: @ast::foreign_item,
|
||||||
path: ast_map::path,
|
path: ast_map::path,
|
||||||
@ -811,7 +811,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
None);
|
None);
|
||||||
}
|
}
|
||||||
"frame_address" => {
|
"frame_address" => {
|
||||||
let frameaddress = *ccx.intrinsics.get(& &"llvm.frameaddress");
|
let frameaddress = ccx.intrinsics.get_copy(& &"llvm.frameaddress");
|
||||||
let frameaddress_val = Call(bcx, frameaddress, [C_i32(0i32)]);
|
let frameaddress_val = Call(bcx, frameaddress, [C_i32(0i32)]);
|
||||||
let star_u8 = ty::mk_imm_ptr(
|
let star_u8 = ty::mk_imm_ptr(
|
||||||
bcx.tcx(),
|
bcx.tcx(),
|
||||||
@ -857,7 +857,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memcpy.p0i8.p0i8.i32");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memcpy.p0i8.p0i8.i32");
|
||||||
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"memcpy64" => {
|
"memcpy64" => {
|
||||||
@ -870,7 +870,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memcpy.p0i8.p0i8.i64");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memcpy.p0i8.p0i8.i64");
|
||||||
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"memmove32" => {
|
"memmove32" => {
|
||||||
@ -883,7 +883,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memmove.p0i8.p0i8.i32");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memmove.p0i8.p0i8.i32");
|
||||||
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"memmove64" => {
|
"memmove64" => {
|
||||||
@ -896,7 +896,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
let src_ptr = PointerCast(bcx, get_param(decl, first_real_arg + 1), T_ptr(T_i8()));
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memmove.p0i8.p0i8.i64");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memmove.p0i8.p0i8.i64");
|
||||||
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, src_ptr, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"memset32" => {
|
"memset32" => {
|
||||||
@ -909,7 +909,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let val = get_param(decl, first_real_arg + 1);
|
let val = get_param(decl, first_real_arg + 1);
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memset.p0i8.i32");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memset.p0i8.i32");
|
||||||
Call(bcx, llfn, [dst_ptr, val, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, val, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"memset64" => {
|
"memset64" => {
|
||||||
@ -922,248 +922,248 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
let val = get_param(decl, first_real_arg + 1);
|
let val = get_param(decl, first_real_arg + 1);
|
||||||
let count = get_param(decl, first_real_arg + 2);
|
let count = get_param(decl, first_real_arg + 2);
|
||||||
let volatile = C_i1(false);
|
let volatile = C_i1(false);
|
||||||
let llfn = *bcx.ccx().intrinsics.get(& &"llvm.memset.p0i8.i64");
|
let llfn = bcx.ccx().intrinsics.get_copy(& &"llvm.memset.p0i8.i64");
|
||||||
Call(bcx, llfn, [dst_ptr, val, Mul(bcx, size, count), align, volatile]);
|
Call(bcx, llfn, [dst_ptr, val, Mul(bcx, size, count), align, volatile]);
|
||||||
}
|
}
|
||||||
"sqrtf32" => {
|
"sqrtf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let sqrtf = *ccx.intrinsics.get(& &"llvm.sqrt.f32");
|
let sqrtf = ccx.intrinsics.get_copy(& &"llvm.sqrt.f32");
|
||||||
Store(bcx, Call(bcx, sqrtf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, sqrtf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"sqrtf64" => {
|
"sqrtf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let sqrtf = *ccx.intrinsics.get(& &"llvm.sqrt.f64");
|
let sqrtf = ccx.intrinsics.get_copy(& &"llvm.sqrt.f64");
|
||||||
Store(bcx, Call(bcx, sqrtf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, sqrtf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"powif32" => {
|
"powif32" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let x = get_param(decl, first_real_arg + 1u);
|
let x = get_param(decl, first_real_arg + 1u);
|
||||||
let powif = *ccx.intrinsics.get(& &"llvm.powi.f32");
|
let powif = ccx.intrinsics.get_copy(& &"llvm.powi.f32");
|
||||||
Store(bcx, Call(bcx, powif, [a, x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, powif, [a, x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"powif64" => {
|
"powif64" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let x = get_param(decl, first_real_arg + 1u);
|
let x = get_param(decl, first_real_arg + 1u);
|
||||||
let powif = *ccx.intrinsics.get(& &"llvm.powi.f64");
|
let powif = ccx.intrinsics.get_copy(& &"llvm.powi.f64");
|
||||||
Store(bcx, Call(bcx, powif, [a, x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, powif, [a, x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"sinf32" => {
|
"sinf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let sinf = *ccx.intrinsics.get(& &"llvm.sin.f32");
|
let sinf = ccx.intrinsics.get_copy(& &"llvm.sin.f32");
|
||||||
Store(bcx, Call(bcx, sinf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, sinf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"sinf64" => {
|
"sinf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let sinf = *ccx.intrinsics.get(& &"llvm.sin.f64");
|
let sinf = ccx.intrinsics.get_copy(& &"llvm.sin.f64");
|
||||||
Store(bcx, Call(bcx, sinf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, sinf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"cosf32" => {
|
"cosf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let cosf = *ccx.intrinsics.get(& &"llvm.cos.f32");
|
let cosf = ccx.intrinsics.get_copy(& &"llvm.cos.f32");
|
||||||
Store(bcx, Call(bcx, cosf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, cosf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"cosf64" => {
|
"cosf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let cosf = *ccx.intrinsics.get(& &"llvm.cos.f64");
|
let cosf = ccx.intrinsics.get_copy(& &"llvm.cos.f64");
|
||||||
Store(bcx, Call(bcx, cosf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, cosf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"powf32" => {
|
"powf32" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let x = get_param(decl, first_real_arg + 1u);
|
let x = get_param(decl, first_real_arg + 1u);
|
||||||
let powf = *ccx.intrinsics.get(& &"llvm.pow.f32");
|
let powf = ccx.intrinsics.get_copy(& &"llvm.pow.f32");
|
||||||
Store(bcx, Call(bcx, powf, [a, x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, powf, [a, x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"powf64" => {
|
"powf64" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let x = get_param(decl, first_real_arg + 1u);
|
let x = get_param(decl, first_real_arg + 1u);
|
||||||
let powf = *ccx.intrinsics.get(& &"llvm.pow.f64");
|
let powf = ccx.intrinsics.get_copy(& &"llvm.pow.f64");
|
||||||
Store(bcx, Call(bcx, powf, [a, x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, powf, [a, x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"expf32" => {
|
"expf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let expf = *ccx.intrinsics.get(& &"llvm.exp.f32");
|
let expf = ccx.intrinsics.get_copy(& &"llvm.exp.f32");
|
||||||
Store(bcx, Call(bcx, expf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, expf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"expf64" => {
|
"expf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let expf = *ccx.intrinsics.get(& &"llvm.exp.f64");
|
let expf = ccx.intrinsics.get_copy(& &"llvm.exp.f64");
|
||||||
Store(bcx, Call(bcx, expf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, expf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"exp2f32" => {
|
"exp2f32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let exp2f = *ccx.intrinsics.get(& &"llvm.exp2.f32");
|
let exp2f = ccx.intrinsics.get_copy(& &"llvm.exp2.f32");
|
||||||
Store(bcx, Call(bcx, exp2f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, exp2f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"exp2f64" => {
|
"exp2f64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let exp2f = *ccx.intrinsics.get(& &"llvm.exp2.f64");
|
let exp2f = ccx.intrinsics.get_copy(& &"llvm.exp2.f64");
|
||||||
Store(bcx, Call(bcx, exp2f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, exp2f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"logf32" => {
|
"logf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let logf = *ccx.intrinsics.get(& &"llvm.log.f32");
|
let logf = ccx.intrinsics.get_copy(& &"llvm.log.f32");
|
||||||
Store(bcx, Call(bcx, logf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, logf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"logf64" => {
|
"logf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let logf = *ccx.intrinsics.get(& &"llvm.log.f64");
|
let logf = ccx.intrinsics.get_copy(& &"llvm.log.f64");
|
||||||
Store(bcx, Call(bcx, logf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, logf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"log10f32" => {
|
"log10f32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let log10f = *ccx.intrinsics.get(& &"llvm.log10.f32");
|
let log10f = ccx.intrinsics.get_copy(& &"llvm.log10.f32");
|
||||||
Store(bcx, Call(bcx, log10f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, log10f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"log10f64" => {
|
"log10f64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let log10f = *ccx.intrinsics.get(& &"llvm.log10.f64");
|
let log10f = ccx.intrinsics.get_copy(& &"llvm.log10.f64");
|
||||||
Store(bcx, Call(bcx, log10f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, log10f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"log2f32" => {
|
"log2f32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let log2f = *ccx.intrinsics.get(& &"llvm.log2.f32");
|
let log2f = ccx.intrinsics.get_copy(& &"llvm.log2.f32");
|
||||||
Store(bcx, Call(bcx, log2f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, log2f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"log2f64" => {
|
"log2f64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let log2f = *ccx.intrinsics.get(& &"llvm.log2.f64");
|
let log2f = ccx.intrinsics.get_copy(& &"llvm.log2.f64");
|
||||||
Store(bcx, Call(bcx, log2f, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, log2f, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"fmaf32" => {
|
"fmaf32" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let b = get_param(decl, first_real_arg + 1u);
|
let b = get_param(decl, first_real_arg + 1u);
|
||||||
let c = get_param(decl, first_real_arg + 2u);
|
let c = get_param(decl, first_real_arg + 2u);
|
||||||
let fmaf = *ccx.intrinsics.get(& &"llvm.fma.f32");
|
let fmaf = ccx.intrinsics.get_copy(& &"llvm.fma.f32");
|
||||||
Store(bcx, Call(bcx, fmaf, [a, b, c]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, fmaf, [a, b, c]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"fmaf64" => {
|
"fmaf64" => {
|
||||||
let a = get_param(decl, first_real_arg);
|
let a = get_param(decl, first_real_arg);
|
||||||
let b = get_param(decl, first_real_arg + 1u);
|
let b = get_param(decl, first_real_arg + 1u);
|
||||||
let c = get_param(decl, first_real_arg + 2u);
|
let c = get_param(decl, first_real_arg + 2u);
|
||||||
let fmaf = *ccx.intrinsics.get(& &"llvm.fma.f64");
|
let fmaf = ccx.intrinsics.get_copy(& &"llvm.fma.f64");
|
||||||
Store(bcx, Call(bcx, fmaf, [a, b, c]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, fmaf, [a, b, c]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"fabsf32" => {
|
"fabsf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let fabsf = *ccx.intrinsics.get(& &"llvm.fabs.f32");
|
let fabsf = ccx.intrinsics.get_copy(& &"llvm.fabs.f32");
|
||||||
Store(bcx, Call(bcx, fabsf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, fabsf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"fabsf64" => {
|
"fabsf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let fabsf = *ccx.intrinsics.get(& &"llvm.fabs.f64");
|
let fabsf = ccx.intrinsics.get_copy(& &"llvm.fabs.f64");
|
||||||
Store(bcx, Call(bcx, fabsf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, fabsf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"floorf32" => {
|
"floorf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let floorf = *ccx.intrinsics.get(& &"llvm.floor.f32");
|
let floorf = ccx.intrinsics.get_copy(& &"llvm.floor.f32");
|
||||||
Store(bcx, Call(bcx, floorf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, floorf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"floorf64" => {
|
"floorf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let floorf = *ccx.intrinsics.get(& &"llvm.floor.f64");
|
let floorf = ccx.intrinsics.get_copy(& &"llvm.floor.f64");
|
||||||
Store(bcx, Call(bcx, floorf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, floorf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"ceilf32" => {
|
"ceilf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ceilf = *ccx.intrinsics.get(& &"llvm.ceil.f32");
|
let ceilf = ccx.intrinsics.get_copy(& &"llvm.ceil.f32");
|
||||||
Store(bcx, Call(bcx, ceilf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, ceilf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"ceilf64" => {
|
"ceilf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ceilf = *ccx.intrinsics.get(& &"llvm.ceil.f64");
|
let ceilf = ccx.intrinsics.get_copy(& &"llvm.ceil.f64");
|
||||||
Store(bcx, Call(bcx, ceilf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, ceilf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"truncf32" => {
|
"truncf32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let truncf = *ccx.intrinsics.get(& &"llvm.trunc.f32");
|
let truncf = ccx.intrinsics.get_copy(& &"llvm.trunc.f32");
|
||||||
Store(bcx, Call(bcx, truncf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, truncf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"truncf64" => {
|
"truncf64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let truncf = *ccx.intrinsics.get(& &"llvm.trunc.f64");
|
let truncf = ccx.intrinsics.get_copy(& &"llvm.trunc.f64");
|
||||||
Store(bcx, Call(bcx, truncf, [x]), fcx.llretptr.get());
|
Store(bcx, Call(bcx, truncf, [x]), fcx.llretptr.get());
|
||||||
}
|
}
|
||||||
"ctpop8" => {
|
"ctpop8" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ctpop = *ccx.intrinsics.get(& &"llvm.ctpop.i8");
|
let ctpop = ccx.intrinsics.get_copy(& &"llvm.ctpop.i8");
|
||||||
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctpop16" => {
|
"ctpop16" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ctpop = *ccx.intrinsics.get(& &"llvm.ctpop.i16");
|
let ctpop = ccx.intrinsics.get_copy(& &"llvm.ctpop.i16");
|
||||||
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctpop32" => {
|
"ctpop32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ctpop = *ccx.intrinsics.get(& &"llvm.ctpop.i32");
|
let ctpop = ccx.intrinsics.get_copy(& &"llvm.ctpop.i32");
|
||||||
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctpop64" => {
|
"ctpop64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let ctpop = *ccx.intrinsics.get(& &"llvm.ctpop.i64");
|
let ctpop = ccx.intrinsics.get_copy(& &"llvm.ctpop.i64");
|
||||||
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctpop, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctlz8" => {
|
"ctlz8" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let ctlz = *ccx.intrinsics.get(& &"llvm.ctlz.i8");
|
let ctlz = ccx.intrinsics.get_copy(& &"llvm.ctlz.i8");
|
||||||
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctlz16" => {
|
"ctlz16" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let ctlz = *ccx.intrinsics.get(& &"llvm.ctlz.i16");
|
let ctlz = ccx.intrinsics.get_copy(& &"llvm.ctlz.i16");
|
||||||
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctlz32" => {
|
"ctlz32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let ctlz = *ccx.intrinsics.get(& &"llvm.ctlz.i32");
|
let ctlz = ccx.intrinsics.get_copy(& &"llvm.ctlz.i32");
|
||||||
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"ctlz64" => {
|
"ctlz64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let ctlz = *ccx.intrinsics.get(& &"llvm.ctlz.i64");
|
let ctlz = ccx.intrinsics.get_copy(& &"llvm.ctlz.i64");
|
||||||
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, ctlz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"cttz8" => {
|
"cttz8" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.cttz.i8");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.cttz.i8");
|
||||||
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"cttz16" => {
|
"cttz16" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.cttz.i16");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.cttz.i16");
|
||||||
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"cttz32" => {
|
"cttz32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.cttz.i32");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.cttz.i32");
|
||||||
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"cttz64" => {
|
"cttz64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let y = C_i1(false);
|
let y = C_i1(false);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.cttz.i64");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.cttz.i64");
|
||||||
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x, y]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"bswap16" => {
|
"bswap16" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.bswap.i16");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.bswap.i16");
|
||||||
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"bswap32" => {
|
"bswap32" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.bswap.i32");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.bswap.i32");
|
||||||
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
"bswap64" => {
|
"bswap64" => {
|
||||||
let x = get_param(decl, first_real_arg);
|
let x = get_param(decl, first_real_arg);
|
||||||
let cttz = *ccx.intrinsics.get(& &"llvm.bswap.i64");
|
let cttz = ccx.intrinsics.get_copy(& &"llvm.bswap.i64");
|
||||||
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
Store(bcx, Call(bcx, cttz, [x]), fcx.llretptr.get())
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
@ -1202,7 +1202,7 @@ pub fn trans_intrinsic(ccx: @CrateContext,
|
|||||||
* R(args->z, NULL, args->x, args->y);
|
* R(args->z, NULL, args->x, args->y);
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
pub fn trans_foreign_fn(ccx: @CrateContext,
|
pub fn trans_foreign_fn(ccx: @mut CrateContext,
|
||||||
path: ast_map::path,
|
path: ast_map::path,
|
||||||
decl: &ast::fn_decl,
|
decl: &ast::fn_decl,
|
||||||
body: &ast::blk,
|
body: &ast::blk,
|
||||||
@ -1210,7 +1210,7 @@ pub fn trans_foreign_fn(ccx: @CrateContext,
|
|||||||
id: ast::node_id) {
|
id: ast::node_id) {
|
||||||
let _icx = ccx.insn_ctxt("foreign::build_foreign_fn");
|
let _icx = ccx.insn_ctxt("foreign::build_foreign_fn");
|
||||||
|
|
||||||
fn build_rust_fn(ccx: @CrateContext,
|
fn build_rust_fn(ccx: @mut CrateContext,
|
||||||
path: ast_map::path,
|
path: ast_map::path,
|
||||||
decl: &ast::fn_decl,
|
decl: &ast::fn_decl,
|
||||||
body: &ast::blk,
|
body: &ast::blk,
|
||||||
@ -1238,7 +1238,7 @@ pub fn trans_foreign_fn(ccx: @CrateContext,
|
|||||||
return llfndecl;
|
return llfndecl;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_shim_fn(ccx: @CrateContext,
|
fn build_shim_fn(ccx: @mut CrateContext,
|
||||||
path: ast_map::path,
|
path: ast_map::path,
|
||||||
llrustfn: ValueRef,
|
llrustfn: ValueRef,
|
||||||
tys: &ShimTypes)
|
tys: &ShimTypes)
|
||||||
@ -1323,7 +1323,7 @@ pub fn trans_foreign_fn(ccx: @CrateContext,
|
|||||||
build_ret)
|
build_ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_wrap_fn(ccx: @CrateContext,
|
fn build_wrap_fn(ccx: @mut CrateContext,
|
||||||
llshimfn: ValueRef,
|
llshimfn: ValueRef,
|
||||||
llwrapfn: ValueRef,
|
llwrapfn: ValueRef,
|
||||||
tys: &ShimTypes) {
|
tys: &ShimTypes) {
|
||||||
@ -1376,7 +1376,7 @@ pub fn trans_foreign_fn(ccx: @CrateContext,
|
|||||||
build_wrap_fn(ccx, llshimfn, llwrapfn, &tys)
|
build_wrap_fn(ccx, llshimfn, llwrapfn, &tys)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_foreign_fn(ccx: @CrateContext,
|
pub fn register_foreign_fn(ccx: @mut CrateContext,
|
||||||
sp: span,
|
sp: span,
|
||||||
path: ast_map::path,
|
path: ast_map::path,
|
||||||
node_id: ast::node_id,
|
node_id: ast::node_id,
|
||||||
|
@ -156,7 +156,7 @@ pub fn free_ty_immediate(bcx: block, v: ValueRef, t: ty::t) -> block {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn lazily_emit_all_tydesc_glue(ccx: @CrateContext,
|
pub fn lazily_emit_all_tydesc_glue(ccx: @mut CrateContext,
|
||||||
static_ti: @mut tydesc_info) {
|
static_ti: @mut tydesc_info) {
|
||||||
lazily_emit_tydesc_glue(ccx, abi::tydesc_field_take_glue, static_ti);
|
lazily_emit_tydesc_glue(ccx, abi::tydesc_field_take_glue, static_ti);
|
||||||
lazily_emit_tydesc_glue(ccx, abi::tydesc_field_drop_glue, static_ti);
|
lazily_emit_tydesc_glue(ccx, abi::tydesc_field_drop_glue, static_ti);
|
||||||
@ -218,7 +218,7 @@ pub fn simplified_glue_type(tcx: ty::ctxt, field: uint, t: ty::t) -> ty::t {
|
|||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn lazily_emit_simplified_tydesc_glue(ccx: @CrateContext,
|
pub fn lazily_emit_simplified_tydesc_glue(ccx: @mut CrateContext,
|
||||||
field: uint,
|
field: uint,
|
||||||
ti: @mut tydesc_info) -> bool {
|
ti: @mut tydesc_info) -> bool {
|
||||||
let _icx = ccx.insn_ctxt("lazily_emit_simplified_tydesc_glue");
|
let _icx = ccx.insn_ctxt("lazily_emit_simplified_tydesc_glue");
|
||||||
@ -243,7 +243,7 @@ pub fn lazily_emit_simplified_tydesc_glue(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
pub fn lazily_emit_tydesc_glue(ccx: @CrateContext,
|
pub fn lazily_emit_tydesc_glue(ccx: @mut CrateContext,
|
||||||
field: uint,
|
field: uint,
|
||||||
ti: @mut tydesc_info) {
|
ti: @mut tydesc_info) {
|
||||||
let _icx = ccx.insn_ctxt("lazily_emit_tydesc_glue");
|
let _icx = ccx.insn_ctxt("lazily_emit_tydesc_glue");
|
||||||
@ -624,7 +624,7 @@ pub fn incr_refcnt_of_boxed(cx: block, box_ptr: ValueRef) {
|
|||||||
|
|
||||||
|
|
||||||
// Chooses the addrspace for newly declared types.
|
// Chooses the addrspace for newly declared types.
|
||||||
pub fn declare_tydesc_addrspace(ccx: @CrateContext, t: ty::t) -> addrspace {
|
pub fn declare_tydesc_addrspace(ccx: &CrateContext, t: ty::t) -> addrspace {
|
||||||
if !ty::type_needs_drop(ccx.tcx, t) {
|
if !ty::type_needs_drop(ccx.tcx, t) {
|
||||||
return default_addrspace;
|
return default_addrspace;
|
||||||
} else if ty::type_is_immediate(t) {
|
} else if ty::type_is_immediate(t) {
|
||||||
@ -638,11 +638,10 @@ pub fn declare_tydesc_addrspace(ccx: @CrateContext, t: ty::t) -> addrspace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Generates the declaration for (but doesn't emit) a type descriptor.
|
// Generates the declaration for (but doesn't emit) a type descriptor.
|
||||||
pub fn declare_tydesc(ccx: @CrateContext, t: ty::t) -> @mut tydesc_info {
|
pub fn declare_tydesc(ccx: &mut CrateContext, t: ty::t) -> @mut tydesc_info {
|
||||||
let _icx = ccx.insn_ctxt("declare_tydesc");
|
|
||||||
// If emit_tydescs already ran, then we shouldn't be creating any new
|
// If emit_tydescs already ran, then we shouldn't be creating any new
|
||||||
// tydescs.
|
// tydescs.
|
||||||
assert!(!*ccx.finished_tydescs);
|
assert!(!ccx.finished_tydescs);
|
||||||
|
|
||||||
let llty = type_of(ccx, t);
|
let llty = type_of(ccx, t);
|
||||||
|
|
||||||
@ -680,7 +679,7 @@ pub fn declare_tydesc(ccx: @CrateContext, t: ty::t) -> @mut tydesc_info {
|
|||||||
|
|
||||||
pub type glue_helper = @fn(block, ValueRef, ty::t);
|
pub type glue_helper = @fn(block, ValueRef, ty::t);
|
||||||
|
|
||||||
pub fn declare_generic_glue(ccx: @CrateContext, t: ty::t, llfnty: TypeRef,
|
pub fn declare_generic_glue(ccx: @mut CrateContext, t: ty::t, llfnty: TypeRef,
|
||||||
name: ~str) -> ValueRef {
|
name: ~str) -> ValueRef {
|
||||||
let _icx = ccx.insn_ctxt("declare_generic_glue");
|
let _icx = ccx.insn_ctxt("declare_generic_glue");
|
||||||
let name = name;
|
let name = name;
|
||||||
@ -692,7 +691,7 @@ pub fn declare_generic_glue(ccx: @CrateContext, t: ty::t, llfnty: TypeRef,
|
|||||||
return llfn;
|
return llfn;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn make_generic_glue_inner(ccx: @CrateContext,
|
pub fn make_generic_glue_inner(ccx: @mut CrateContext,
|
||||||
t: ty::t,
|
t: ty::t,
|
||||||
llfn: ValueRef,
|
llfn: ValueRef,
|
||||||
helper: glue_helper)
|
helper: glue_helper)
|
||||||
@ -717,7 +716,7 @@ pub fn make_generic_glue_inner(ccx: @CrateContext,
|
|||||||
return llfn;
|
return llfn;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn make_generic_glue(ccx: @CrateContext,
|
pub fn make_generic_glue(ccx: @mut CrateContext,
|
||||||
t: ty::t,
|
t: ty::t,
|
||||||
llfn: ValueRef,
|
llfn: ValueRef,
|
||||||
helper: glue_helper,
|
helper: glue_helper,
|
||||||
@ -738,12 +737,13 @@ pub fn make_generic_glue(ccx: @CrateContext,
|
|||||||
return llval;
|
return llval;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn emit_tydescs(ccx: @CrateContext) {
|
pub fn emit_tydescs(ccx: &mut CrateContext) {
|
||||||
let _icx = ccx.insn_ctxt("emit_tydescs");
|
//let _icx = ccx.insn_ctxt("emit_tydescs");
|
||||||
// As of this point, allow no more tydescs to be created.
|
// As of this point, allow no more tydescs to be created.
|
||||||
*ccx.finished_tydescs = true;
|
ccx.finished_tydescs = true;
|
||||||
for ccx.tydescs.each_value |&val| {
|
let glue_fn_ty = T_ptr(T_generic_glue_fn(ccx));
|
||||||
let glue_fn_ty = T_ptr(T_generic_glue_fn(ccx));
|
let tyds = &mut ccx.tydescs;
|
||||||
|
for tyds.each_value |&val| {
|
||||||
let ti = val;
|
let ti = val;
|
||||||
|
|
||||||
// Each of the glue functions needs to be cast to a generic type
|
// Each of the glue functions needs to be cast to a generic type
|
||||||
|
@ -27,7 +27,7 @@ use syntax::ast_util::local_def;
|
|||||||
// `translate` will be true if this function is allowed to translate the
|
// `translate` will be true if this function is allowed to translate the
|
||||||
// item and false otherwise. Currently, this parameter is set to false when
|
// item and false otherwise. Currently, this parameter is set to false when
|
||||||
// translating default methods.
|
// translating default methods.
|
||||||
pub fn maybe_instantiate_inline(ccx: @CrateContext, fn_id: ast::def_id,
|
pub fn maybe_instantiate_inline(ccx: @mut CrateContext, fn_id: ast::def_id,
|
||||||
translate: bool)
|
translate: bool)
|
||||||
-> ast::def_id {
|
-> ast::def_id {
|
||||||
let _icx = ccx.insn_ctxt("maybe_instantiate_inline");
|
let _icx = ccx.insn_ctxt("maybe_instantiate_inline");
|
||||||
|
@ -22,7 +22,7 @@ use util::ppaux::ty_to_str;
|
|||||||
// compute sizeof / alignof
|
// compute sizeof / alignof
|
||||||
|
|
||||||
// Returns the number of bytes clobbered by a Store to this type.
|
// Returns the number of bytes clobbered by a Store to this type.
|
||||||
pub fn llsize_of_store(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llsize_of_store(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMStoreSizeOfType(cx.td.lltd, t) as uint;
|
return llvm::LLVMStoreSizeOfType(cx.td.lltd, t) as uint;
|
||||||
}
|
}
|
||||||
@ -30,7 +30,7 @@ pub fn llsize_of_store(cx: @CrateContext, t: TypeRef) -> uint {
|
|||||||
|
|
||||||
// Returns the number of bytes between successive elements of type T in an
|
// Returns the number of bytes between successive elements of type T in an
|
||||||
// array of T. This is the "ABI" size. It includes any ABI-mandated padding.
|
// array of T. This is the "ABI" size. It includes any ABI-mandated padding.
|
||||||
pub fn llsize_of_alloc(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llsize_of_alloc(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMABISizeOfType(cx.td.lltd, t) as uint;
|
return llvm::LLVMABISizeOfType(cx.td.lltd, t) as uint;
|
||||||
}
|
}
|
||||||
@ -44,7 +44,7 @@ pub fn llsize_of_alloc(cx: @CrateContext, t: TypeRef) -> uint {
|
|||||||
// that LLVM *does* distinguish between e.g. a 1-bit value and an 8-bit value
|
// that LLVM *does* distinguish between e.g. a 1-bit value and an 8-bit value
|
||||||
// at the codegen level! In general you should prefer `llbitsize_of_real`
|
// at the codegen level! In general you should prefer `llbitsize_of_real`
|
||||||
// below.
|
// below.
|
||||||
pub fn llsize_of_real(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llsize_of_real(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
let nbits = llvm::LLVMSizeOfTypeInBits(cx.td.lltd, t) as uint;
|
let nbits = llvm::LLVMSizeOfTypeInBits(cx.td.lltd, t) as uint;
|
||||||
if nbits & 7u != 0u {
|
if nbits & 7u != 0u {
|
||||||
@ -57,14 +57,14 @@ pub fn llsize_of_real(cx: @CrateContext, t: TypeRef) -> uint {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the "real" size of the type in bits.
|
/// Returns the "real" size of the type in bits.
|
||||||
pub fn llbitsize_of_real(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llbitsize_of_real(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
llvm::LLVMSizeOfTypeInBits(cx.td.lltd, t) as uint
|
llvm::LLVMSizeOfTypeInBits(cx.td.lltd, t) as uint
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the size of the type as an LLVM constant integer value.
|
/// Returns the size of the type as an LLVM constant integer value.
|
||||||
pub fn llsize_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
pub fn llsize_of(cx: &CrateContext, t: TypeRef) -> ValueRef {
|
||||||
// Once upon a time, this called LLVMSizeOf, which does a
|
// Once upon a time, this called LLVMSizeOf, which does a
|
||||||
// getelementptr(1) on a null pointer and casts to an int, in
|
// getelementptr(1) on a null pointer and casts to an int, in
|
||||||
// order to obtain the type size as a value without requiring the
|
// order to obtain the type size as a value without requiring the
|
||||||
@ -78,7 +78,7 @@ pub fn llsize_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
|||||||
// Returns the "default" size of t (see above), or 1 if the size would
|
// Returns the "default" size of t (see above), or 1 if the size would
|
||||||
// be zero. This is important for things like vectors that expect
|
// be zero. This is important for things like vectors that expect
|
||||||
// space to be consumed.
|
// space to be consumed.
|
||||||
pub fn nonzero_llsize_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
pub fn nonzero_llsize_of(cx: &CrateContext, t: TypeRef) -> ValueRef {
|
||||||
if llbitsize_of_real(cx, t) == 0 {
|
if llbitsize_of_real(cx, t) == 0 {
|
||||||
unsafe { llvm::LLVMConstInt(cx.int_type, 1, False) }
|
unsafe { llvm::LLVMConstInt(cx.int_type, 1, False) }
|
||||||
} else {
|
} else {
|
||||||
@ -90,7 +90,7 @@ pub fn nonzero_llsize_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
|||||||
// The preferred alignment may be larger than the alignment used when
|
// The preferred alignment may be larger than the alignment used when
|
||||||
// packing the type into structs. This will be used for things like
|
// packing the type into structs. This will be used for things like
|
||||||
// allocations inside a stack frame, which LLVM has a free hand in.
|
// allocations inside a stack frame, which LLVM has a free hand in.
|
||||||
pub fn llalign_of_pref(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llalign_of_pref(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMPreferredAlignmentOfType(cx.td.lltd, t) as uint;
|
return llvm::LLVMPreferredAlignmentOfType(cx.td.lltd, t) as uint;
|
||||||
}
|
}
|
||||||
@ -99,7 +99,7 @@ pub fn llalign_of_pref(cx: @CrateContext, t: TypeRef) -> uint {
|
|||||||
// Returns the minimum alignment of a type required by the platform.
|
// Returns the minimum alignment of a type required by the platform.
|
||||||
// This is the alignment that will be used for struct fields, arrays,
|
// This is the alignment that will be used for struct fields, arrays,
|
||||||
// and similar ABI-mandated things.
|
// and similar ABI-mandated things.
|
||||||
pub fn llalign_of_min(cx: @CrateContext, t: TypeRef) -> uint {
|
pub fn llalign_of_min(cx: &CrateContext, t: TypeRef) -> uint {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMABIAlignmentOfType(cx.td.lltd, t) as uint;
|
return llvm::LLVMABIAlignmentOfType(cx.td.lltd, t) as uint;
|
||||||
}
|
}
|
||||||
@ -108,7 +108,7 @@ pub fn llalign_of_min(cx: @CrateContext, t: TypeRef) -> uint {
|
|||||||
// Returns the "default" alignment of t, which is calculated by casting
|
// Returns the "default" alignment of t, which is calculated by casting
|
||||||
// null to a record containing a single-bit followed by a t value, then
|
// null to a record containing a single-bit followed by a t value, then
|
||||||
// doing gep(0,1) to get at the trailing (and presumably padded) t cell.
|
// doing gep(0,1) to get at the trailing (and presumably padded) t cell.
|
||||||
pub fn llalign_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
pub fn llalign_of(cx: &CrateContext, t: TypeRef) -> ValueRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
return llvm::LLVMConstIntCast(
|
return llvm::LLVMConstIntCast(
|
||||||
llvm::LLVMAlignOf(t), cx.int_type, False);
|
llvm::LLVMAlignOf(t), cx.int_type, False);
|
||||||
@ -116,7 +116,7 @@ pub fn llalign_of(cx: @CrateContext, t: TypeRef) -> ValueRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Computes the size of the data part of an enum.
|
// Computes the size of the data part of an enum.
|
||||||
pub fn static_size_of_enum(cx: @CrateContext, t: ty::t) -> uint {
|
pub fn static_size_of_enum(cx: &mut CrateContext, t: ty::t) -> uint {
|
||||||
if cx.enum_sizes.contains_key(&t) {
|
if cx.enum_sizes.contains_key(&t) {
|
||||||
return cx.enum_sizes.get_copy(&t);
|
return cx.enum_sizes.get_copy(&t);
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,7 @@ for non-monomorphized methods only. Other methods will
|
|||||||
be generated once they are invoked with specific type parameters,
|
be generated once they are invoked with specific type parameters,
|
||||||
see `trans::base::lval_static_fn()` or `trans::base::monomorphic_fn()`.
|
see `trans::base::lval_static_fn()` or `trans::base::monomorphic_fn()`.
|
||||||
*/
|
*/
|
||||||
pub fn trans_impl(ccx: @CrateContext,
|
pub fn trans_impl(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
name: ast::ident,
|
name: ast::ident,
|
||||||
methods: &[@ast::method],
|
methods: &[@ast::method],
|
||||||
@ -102,7 +102,7 @@ Translates a (possibly monomorphized) method body.
|
|||||||
- `llfn`: the LLVM ValueRef for the method
|
- `llfn`: the LLVM ValueRef for the method
|
||||||
- `impl_id`: the node ID of the impl this method is inside
|
- `impl_id`: the node ID of the impl this method is inside
|
||||||
*/
|
*/
|
||||||
pub fn trans_method(ccx: @CrateContext,
|
pub fn trans_method(ccx: @mut CrateContext,
|
||||||
path: path,
|
path: path,
|
||||||
method: &ast::method,
|
method: &ast::method,
|
||||||
param_substs: Option<@param_substs>,
|
param_substs: Option<@param_substs>,
|
||||||
@ -378,7 +378,7 @@ pub fn method_from_methods(ms: &[@ast::method], name: ast::ident)
|
|||||||
ms.find(|m| m.ident == name).map(|m| ast_util::local_def(m.id))
|
ms.find(|m| m.ident == name).map(|m| ast_util::local_def(m.id))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn method_with_name_or_default(ccx: @CrateContext,
|
pub fn method_with_name_or_default(ccx: @mut CrateContext,
|
||||||
impl_id: ast::def_id,
|
impl_id: ast::def_id,
|
||||||
name: ast::ident) -> ast::def_id {
|
name: ast::ident) -> ast::def_id {
|
||||||
*do ccx.impl_method_cache.find_or_insert_with((impl_id, name)) |_| {
|
*do ccx.impl_method_cache.find_or_insert_with((impl_id, name)) |_| {
|
||||||
@ -415,7 +415,7 @@ pub fn method_with_name_or_default(ccx: @CrateContext,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn method_ty_param_count(ccx: @CrateContext, m_id: ast::def_id,
|
pub fn method_ty_param_count(ccx: &CrateContext, m_id: ast::def_id,
|
||||||
i_id: ast::def_id) -> uint {
|
i_id: ast::def_id) -> uint {
|
||||||
debug!("method_ty_param_count: m_id: %?, i_id: %?", m_id, i_id);
|
debug!("method_ty_param_count: m_id: %?, i_id: %?", m_id, i_id);
|
||||||
if m_id.crate == ast::local_crate {
|
if m_id.crate == ast::local_crate {
|
||||||
@ -734,7 +734,7 @@ pub fn trans_trait_callee_from_llval(bcx: block,
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn vtable_id(ccx: @CrateContext,
|
pub fn vtable_id(ccx: @mut CrateContext,
|
||||||
origin: &typeck::vtable_origin)
|
origin: &typeck::vtable_origin)
|
||||||
-> mono_id {
|
-> mono_id {
|
||||||
match origin {
|
match origin {
|
||||||
@ -778,7 +778,7 @@ pub fn get_vtable(bcx: block,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Helper function to declare and initialize the vtable.
|
/// Helper function to declare and initialize the vtable.
|
||||||
pub fn make_vtable(ccx: @CrateContext,
|
pub fn make_vtable(ccx: @mut CrateContext,
|
||||||
tydesc: @mut tydesc_info,
|
tydesc: @mut tydesc_info,
|
||||||
ptrs: &[ValueRef])
|
ptrs: &[ValueRef])
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
|
@ -40,7 +40,7 @@ use syntax::ast_util::local_def;
|
|||||||
use syntax::opt_vec;
|
use syntax::opt_vec;
|
||||||
use syntax::abi::AbiSet;
|
use syntax::abi::AbiSet;
|
||||||
|
|
||||||
pub fn monomorphic_fn(ccx: @CrateContext,
|
pub fn monomorphic_fn(ccx: @mut CrateContext,
|
||||||
fn_id: ast::def_id,
|
fn_id: ast::def_id,
|
||||||
real_substs: &ty::substs,
|
real_substs: &ty::substs,
|
||||||
vtables: Option<typeck::vtable_res>,
|
vtables: Option<typeck::vtable_res>,
|
||||||
@ -329,7 +329,7 @@ pub fn normalize_for_monomorphization(tcx: ty::ctxt,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn make_mono_id(ccx: @CrateContext,
|
pub fn make_mono_id(ccx: @mut CrateContext,
|
||||||
item: ast::def_id,
|
item: ast::def_id,
|
||||||
substs: &[ty::t],
|
substs: &[ty::t],
|
||||||
vtables: Option<typeck::vtable_res>,
|
vtables: Option<typeck::vtable_res>,
|
||||||
|
@ -151,8 +151,7 @@ impl Reflector {
|
|||||||
// Entrypoint
|
// Entrypoint
|
||||||
pub fn visit_ty(&mut self, t: ty::t) {
|
pub fn visit_ty(&mut self, t: ty::t) {
|
||||||
let bcx = self.bcx;
|
let bcx = self.bcx;
|
||||||
debug!("reflect::visit_ty %s",
|
debug!("reflect::visit_ty %s", ty_to_str(bcx.ccx().tcx, t));
|
||||||
ty_to_str(bcx.ccx().tcx, t));
|
|
||||||
|
|
||||||
match ty::get(t).sty {
|
match ty::get(t).sty {
|
||||||
ty::ty_bot => self.leaf(~"bot"),
|
ty::ty_bot => self.leaf(~"bot"),
|
||||||
@ -312,16 +311,17 @@ impl Reflector {
|
|||||||
+ self.c_size_and_align(t);
|
+ self.c_size_and_align(t);
|
||||||
do self.bracketed(~"enum", enum_args) |this| {
|
do self.bracketed(~"enum", enum_args) |this| {
|
||||||
for variants.eachi |i, v| {
|
for variants.eachi |i, v| {
|
||||||
|
let name = ccx.sess.str_of(v.name);
|
||||||
let variant_args = ~[this.c_uint(i),
|
let variant_args = ~[this.c_uint(i),
|
||||||
this.c_int(v.disr_val),
|
this.c_int(v.disr_val),
|
||||||
this.c_uint(v.args.len()),
|
this.c_uint(v.args.len()),
|
||||||
this.c_slice(ccx.sess.str_of(v.name))];
|
this.c_slice(name)];
|
||||||
do this.bracketed(~"enum_variant", variant_args) |this| {
|
do this.bracketed(~"enum_variant", variant_args) |this| {
|
||||||
for v.args.eachi |j, a| {
|
for v.args.eachi |j, a| {
|
||||||
let bcx = this.bcx;
|
let bcx = this.bcx;
|
||||||
let null = C_null(llptrty);
|
let null = C_null(llptrty);
|
||||||
let offset = p2i(ccx, adt::trans_field_ptr(bcx, repr, null,
|
let ptr = adt::trans_field_ptr(bcx, repr, null, v.disr_val, j);
|
||||||
v.disr_val, j));
|
let offset = p2i(ccx, ptr);
|
||||||
let field_args = ~[this.c_uint(j),
|
let field_args = ~[this.c_uint(j),
|
||||||
offset,
|
offset,
|
||||||
this.c_tydesc(*a)];
|
this.c_tydesc(*a)];
|
||||||
|
@ -25,8 +25,8 @@ pub struct Ctxt {
|
|||||||
pad2: u32
|
pad2: u32
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn mk_global(ccx: @CrateContext,
|
pub fn mk_global(ccx: &CrateContext,
|
||||||
name: ~str,
|
name: &str,
|
||||||
llval: ValueRef,
|
llval: ValueRef,
|
||||||
internal: bool)
|
internal: bool)
|
||||||
-> ValueRef {
|
-> ValueRef {
|
||||||
|
@ -151,7 +151,7 @@ pub struct VecTypes {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl VecTypes {
|
impl VecTypes {
|
||||||
pub fn to_str(&self, ccx: @CrateContext) -> ~str {
|
pub fn to_str(&self, ccx: &CrateContext) -> ~str {
|
||||||
fmt!("VecTypes {vec_ty=%s, unit_ty=%s, llunit_ty=%s, llunit_size=%s}",
|
fmt!("VecTypes {vec_ty=%s, unit_ty=%s, llunit_ty=%s, llunit_size=%s}",
|
||||||
ty_to_str(ccx.tcx, self.vec_ty),
|
ty_to_str(ccx.tcx, self.vec_ty),
|
||||||
ty_to_str(ccx.tcx, self.unit_ty),
|
ty_to_str(ccx.tcx, self.unit_ty),
|
||||||
|
@ -21,21 +21,21 @@ use util::ppaux;
|
|||||||
|
|
||||||
use syntax::ast;
|
use syntax::ast;
|
||||||
|
|
||||||
pub fn arg_is_indirect(_: @CrateContext, arg_ty: &ty::t) -> bool {
|
pub fn arg_is_indirect(_: &CrateContext, arg_ty: &ty::t) -> bool {
|
||||||
!ty::type_is_immediate(*arg_ty)
|
!ty::type_is_immediate(*arg_ty)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_explicit_arg(ccx: @CrateContext, arg_ty: &ty::t) -> TypeRef {
|
pub fn type_of_explicit_arg(ccx: &mut CrateContext, arg_ty: &ty::t) -> TypeRef {
|
||||||
let llty = type_of(ccx, *arg_ty);
|
let llty = type_of(ccx, *arg_ty);
|
||||||
if arg_is_indirect(ccx, arg_ty) {T_ptr(llty)} else {llty}
|
if arg_is_indirect(ccx, arg_ty) {T_ptr(llty)} else {llty}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_explicit_args(ccx: @CrateContext,
|
pub fn type_of_explicit_args(ccx: &mut CrateContext,
|
||||||
inputs: &[ty::t]) -> ~[TypeRef] {
|
inputs: &[ty::t]) -> ~[TypeRef] {
|
||||||
inputs.map(|arg_ty| type_of_explicit_arg(ccx, arg_ty))
|
inputs.map(|arg_ty| type_of_explicit_arg(ccx, arg_ty))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_fn(cx: @CrateContext, inputs: &[ty::t], output: ty::t)
|
pub fn type_of_fn(cx: &mut CrateContext, inputs: &[ty::t], output: ty::t)
|
||||||
-> TypeRef {
|
-> TypeRef {
|
||||||
unsafe {
|
unsafe {
|
||||||
let mut atys: ~[TypeRef] = ~[];
|
let mut atys: ~[TypeRef] = ~[];
|
||||||
@ -64,7 +64,7 @@ pub fn type_of_fn(cx: @CrateContext, inputs: &[ty::t], output: ty::t)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Given a function type and a count of ty params, construct an llvm type
|
// Given a function type and a count of ty params, construct an llvm type
|
||||||
pub fn type_of_fn_from_ty(cx: @CrateContext, fty: ty::t) -> TypeRef {
|
pub fn type_of_fn_from_ty(cx: &mut CrateContext, fty: ty::t) -> TypeRef {
|
||||||
match ty::get(fty).sty {
|
match ty::get(fty).sty {
|
||||||
ty::ty_closure(ref f) => type_of_fn(cx, f.sig.inputs, f.sig.output),
|
ty::ty_closure(ref f) => type_of_fn(cx, f.sig.inputs, f.sig.output),
|
||||||
ty::ty_bare_fn(ref f) => type_of_fn(cx, f.sig.inputs, f.sig.output),
|
ty::ty_bare_fn(ref f) => type_of_fn(cx, f.sig.inputs, f.sig.output),
|
||||||
@ -74,7 +74,7 @@ pub fn type_of_fn_from_ty(cx: @CrateContext, fty: ty::t) -> TypeRef {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_non_gc_box(cx: @CrateContext, t: ty::t) -> TypeRef {
|
pub fn type_of_non_gc_box(cx: &mut CrateContext, t: ty::t) -> TypeRef {
|
||||||
assert!(!ty::type_needs_infer(t));
|
assert!(!ty::type_needs_infer(t));
|
||||||
|
|
||||||
let t_norm = ty::normalize_ty(cx.tcx, t);
|
let t_norm = ty::normalize_ty(cx.tcx, t);
|
||||||
@ -83,10 +83,12 @@ pub fn type_of_non_gc_box(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
} else {
|
} else {
|
||||||
match ty::get(t).sty {
|
match ty::get(t).sty {
|
||||||
ty::ty_box(mt) => {
|
ty::ty_box(mt) => {
|
||||||
T_ptr(T_box(cx, type_of(cx, mt.ty)))
|
let ty = type_of(cx, mt.ty);
|
||||||
|
T_ptr(T_box(cx, ty))
|
||||||
}
|
}
|
||||||
ty::ty_uniq(mt) => {
|
ty::ty_uniq(mt) => {
|
||||||
T_ptr(T_unique(cx, type_of(cx, mt.ty)))
|
let ty = type_of(cx, mt.ty);
|
||||||
|
T_ptr(T_unique(cx, ty))
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
cx.sess.bug("non-box in type_of_non_gc_box");
|
cx.sess.bug("non-box in type_of_non_gc_box");
|
||||||
@ -107,7 +109,7 @@ pub fn type_of_non_gc_box(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
// recursive types. For example, `static_size_of_enum()` relies on this
|
// recursive types. For example, `static_size_of_enum()` relies on this
|
||||||
// behavior.
|
// behavior.
|
||||||
|
|
||||||
pub fn sizing_type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
pub fn sizing_type_of(cx: &mut CrateContext, t: ty::t) -> TypeRef {
|
||||||
match cx.llsizingtypes.find(&t) {
|
match cx.llsizingtypes.find(&t) {
|
||||||
Some(t) => return *t,
|
Some(t) => return *t,
|
||||||
None => ()
|
None => ()
|
||||||
@ -146,7 +148,10 @@ pub fn sizing_type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
T_array(sizing_type_of(cx, mt.ty), size)
|
T_array(sizing_type_of(cx, mt.ty), size)
|
||||||
}
|
}
|
||||||
|
|
||||||
ty::ty_unboxed_vec(mt) => T_vec(cx, sizing_type_of(cx, mt.ty)),
|
ty::ty_unboxed_vec(mt) => {
|
||||||
|
let sz_ty = sizing_type_of(cx, mt.ty);
|
||||||
|
T_vec(cx, sz_ty)
|
||||||
|
}
|
||||||
|
|
||||||
ty::ty_tup(*) | ty::ty_enum(*) => {
|
ty::ty_tup(*) | ty::ty_enum(*) => {
|
||||||
let repr = adt::represent_type(cx, t);
|
let repr = adt::represent_type(cx, t);
|
||||||
@ -177,7 +182,7 @@ pub fn sizing_type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NB: If you update this, be sure to update `sizing_type_of()` as well.
|
// NB: If you update this, be sure to update `sizing_type_of()` as well.
|
||||||
pub fn type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
pub fn type_of(cx: &mut CrateContext, t: ty::t) -> TypeRef {
|
||||||
debug!("type_of %?: %?", t, ty::get(t));
|
debug!("type_of %?: %?", t, ty::get(t));
|
||||||
|
|
||||||
// Check the cache.
|
// Check the cache.
|
||||||
@ -223,22 +228,35 @@ pub fn type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
T_box_ptr(T_box(cx, T_vec(cx, T_i8())))
|
T_box_ptr(T_box(cx, T_vec(cx, T_i8())))
|
||||||
}
|
}
|
||||||
ty::ty_evec(ref mt, ty::vstore_box) => {
|
ty::ty_evec(ref mt, ty::vstore_box) => {
|
||||||
T_box_ptr(T_box(cx, T_vec(cx, type_of(cx, mt.ty))))
|
let e_ty = type_of(cx, mt.ty);
|
||||||
|
let v_ty = T_vec(cx, e_ty);
|
||||||
|
T_box_ptr(T_box(cx, v_ty))
|
||||||
|
}
|
||||||
|
ty::ty_box(ref mt) => {
|
||||||
|
let ty = type_of(cx, mt.ty);
|
||||||
|
T_box_ptr(T_box(cx, ty))
|
||||||
}
|
}
|
||||||
ty::ty_box(ref mt) => T_box_ptr(T_box(cx, type_of(cx, mt.ty))),
|
|
||||||
ty::ty_opaque_box => T_box_ptr(T_box(cx, T_i8())),
|
ty::ty_opaque_box => T_box_ptr(T_box(cx, T_i8())),
|
||||||
ty::ty_uniq(ref mt) => T_unique_ptr(T_unique(cx, type_of(cx, mt.ty))),
|
ty::ty_uniq(ref mt) => {
|
||||||
|
let ty = type_of(cx, mt.ty);
|
||||||
|
T_unique_ptr(T_unique(cx, ty))
|
||||||
|
}
|
||||||
ty::ty_evec(ref mt, ty::vstore_uniq) => {
|
ty::ty_evec(ref mt, ty::vstore_uniq) => {
|
||||||
T_unique_ptr(T_unique(cx, T_vec(cx, type_of(cx, mt.ty))))
|
let ty = type_of(cx, mt.ty);
|
||||||
|
let ty = T_vec(cx, ty);
|
||||||
|
T_unique_ptr(T_unique(cx, ty))
|
||||||
}
|
}
|
||||||
ty::ty_unboxed_vec(ref mt) => {
|
ty::ty_unboxed_vec(ref mt) => {
|
||||||
T_vec(cx, type_of(cx, mt.ty))
|
let ty = type_of(cx, mt.ty);
|
||||||
|
T_vec(cx, ty)
|
||||||
}
|
}
|
||||||
ty::ty_ptr(ref mt) => T_ptr(type_of(cx, mt.ty)),
|
ty::ty_ptr(ref mt) => T_ptr(type_of(cx, mt.ty)),
|
||||||
ty::ty_rptr(_, ref mt) => T_ptr(type_of(cx, mt.ty)),
|
ty::ty_rptr(_, ref mt) => T_ptr(type_of(cx, mt.ty)),
|
||||||
|
|
||||||
ty::ty_evec(ref mt, ty::vstore_slice(_)) => {
|
ty::ty_evec(ref mt, ty::vstore_slice(_)) => {
|
||||||
T_struct([T_ptr(type_of(cx, mt.ty)), T_uint_ty(cx, ast::ty_u)], false)
|
let p_ty = T_ptr(type_of(cx, mt.ty));
|
||||||
|
let u_ty = T_uint_ty(cx, ast::ty_u);
|
||||||
|
T_struct([p_ty, u_ty], false)
|
||||||
}
|
}
|
||||||
|
|
||||||
ty::ty_estr(ty::vstore_slice(_)) => {
|
ty::ty_estr(ty::vstore_slice(_)) => {
|
||||||
@ -254,7 +272,10 @@ pub fn type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ty::ty_bare_fn(_) => T_ptr(type_of_fn_from_ty(cx, t)),
|
ty::ty_bare_fn(_) => T_ptr(type_of_fn_from_ty(cx, t)),
|
||||||
ty::ty_closure(_) => T_fn_pair(cx, type_of_fn_from_ty(cx, t)),
|
ty::ty_closure(_) => {
|
||||||
|
let ty = type_of_fn_from_ty(cx, t);
|
||||||
|
T_fn_pair(cx, ty)
|
||||||
|
}
|
||||||
ty::ty_trait(_, _, store, _) => T_opaque_trait(cx, store),
|
ty::ty_trait(_, _, store, _) => T_opaque_trait(cx, store),
|
||||||
ty::ty_type => T_ptr(cx.tydesc_type),
|
ty::ty_type => T_ptr(cx.tydesc_type),
|
||||||
ty::ty_tup(*) => {
|
ty::ty_tup(*) => {
|
||||||
@ -310,7 +331,7 @@ pub fn type_of(cx: @CrateContext, t: ty::t) -> TypeRef {
|
|||||||
// Want refinements! (Or case classes, I guess
|
// Want refinements! (Or case classes, I guess
|
||||||
pub enum named_ty { a_struct, an_enum }
|
pub enum named_ty { a_struct, an_enum }
|
||||||
|
|
||||||
pub fn llvm_type_name(cx: @CrateContext,
|
pub fn llvm_type_name(cx: &CrateContext,
|
||||||
what: named_ty,
|
what: named_ty,
|
||||||
did: ast::def_id,
|
did: ast::def_id,
|
||||||
tps: &[ty::t]) -> ~str {
|
tps: &[ty::t]) -> ~str {
|
||||||
@ -330,18 +351,18 @@ pub fn llvm_type_name(cx: @CrateContext,
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_dtor(ccx: @CrateContext, self_ty: ty::t) -> TypeRef {
|
pub fn type_of_dtor(ccx: &mut CrateContext, self_ty: ty::t) -> TypeRef {
|
||||||
T_fn([T_ptr(type_of(ccx, self_ty))] /* self */, T_nil())
|
T_fn([T_ptr(type_of(ccx, self_ty))] /* self */, T_nil())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_rooted(ccx: @CrateContext, t: ty::t) -> TypeRef {
|
pub fn type_of_rooted(ccx: &mut CrateContext, t: ty::t) -> TypeRef {
|
||||||
let addrspace = base::get_tydesc(ccx, t).addrspace;
|
let addrspace = base::get_tydesc(ccx, t).addrspace;
|
||||||
debug!("type_of_rooted %s in addrspace %u",
|
debug!("type_of_rooted %s in addrspace %u",
|
||||||
ppaux::ty_to_str(ccx.tcx, t), addrspace as uint);
|
ppaux::ty_to_str(ccx.tcx, t), addrspace as uint);
|
||||||
return T_root(type_of(ccx, t), addrspace);
|
return T_root(type_of(ccx, t), addrspace);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_of_glue_fn(ccx: @CrateContext) -> TypeRef {
|
pub fn type_of_glue_fn(ccx: &CrateContext) -> TypeRef {
|
||||||
let tydescpp = T_ptr(T_ptr(ccx.tydesc_type));
|
let tydescpp = T_ptr(T_ptr(ccx.tydesc_type));
|
||||||
return T_fn([T_ptr(T_nil()), tydescpp, T_ptr(T_i8())], T_nil());
|
return T_fn([T_ptr(T_nil()), tydescpp, T_ptr(T_i8())], T_nil());
|
||||||
}
|
}
|
||||||
|
@ -51,11 +51,11 @@ pub static use_repr: uint = 1; /* Dependency on size/alignment/mode and
|
|||||||
pub static use_tydesc: uint = 2; /* Takes the tydesc, or compares */
|
pub static use_tydesc: uint = 2; /* Takes the tydesc, or compares */
|
||||||
|
|
||||||
pub struct Context {
|
pub struct Context {
|
||||||
ccx: @CrateContext,
|
ccx: @mut CrateContext,
|
||||||
uses: @mut ~[type_uses]
|
uses: @mut ~[type_uses]
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_uses_for(ccx: @CrateContext, fn_id: def_id, n_tps: uint)
|
pub fn type_uses_for(ccx: @mut CrateContext, fn_id: def_id, n_tps: uint)
|
||||||
-> @~[type_uses] {
|
-> @~[type_uses] {
|
||||||
match ccx.type_use_cache.find(&fn_id) {
|
match ccx.type_use_cache.find(&fn_id) {
|
||||||
Some(uses) => return *uses,
|
Some(uses) => return *uses,
|
||||||
|
Loading…
Reference in New Issue
Block a user