2011-08-04 12:46:10 -05:00
|
|
|
// A "shape" is a compact encoding of a type that is used by interpreted glue.
|
|
|
|
// This substitutes for the runtime tags used by e.g. MLs.
|
|
|
|
|
2012-09-04 13:54:36 -05:00
|
|
|
use lib::llvm::llvm;
|
|
|
|
use lib::llvm::{True, False, ModuleRef, TypeRef, ValueRef};
|
|
|
|
use driver::session;
|
|
|
|
use driver::session::session;
|
|
|
|
use trans::base;
|
|
|
|
use middle::trans::common::*;
|
2012-09-25 17:21:16 -05:00
|
|
|
use middle::trans::machine::*;
|
2012-09-04 13:54:36 -05:00
|
|
|
use back::abi;
|
|
|
|
use middle::ty;
|
|
|
|
use middle::ty::field;
|
|
|
|
use syntax::ast;
|
2012-09-19 17:13:04 -05:00
|
|
|
use syntax::ast_util::dummy_sp;
|
2012-09-04 13:54:36 -05:00
|
|
|
use syntax::util::interner;
|
|
|
|
use util::ppaux::ty_to_str;
|
|
|
|
use syntax::codemap::span;
|
|
|
|
use dvec::DVec;
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-09-10 17:38:28 -05:00
|
|
|
use std::map::HashMap;
|
2012-09-04 13:54:36 -05:00
|
|
|
use option::is_some;
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-09-04 13:54:36 -05:00
|
|
|
use ty_ctxt = middle::ty::ctxt;
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-09-25 19:39:23 -05:00
|
|
|
type ctxt = {mut next_tag_id: u16, pad: u16, pad2: u32};
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-07-14 00:57:48 -05:00
|
|
|
fn mk_global(ccx: @crate_ctxt, name: ~str, llval: ValueRef, internal: bool) ->
|
2011-10-12 15:31:41 -05:00
|
|
|
ValueRef {
|
2012-09-25 19:39:23 -05:00
|
|
|
let llglobal = do str::as_c_str(name) |buf| {
|
|
|
|
lib::llvm::llvm::LLVMAddGlobal(ccx.llmod, val_ty(llval), buf)
|
|
|
|
};
|
2011-08-04 12:46:10 -05:00
|
|
|
lib::llvm::llvm::LLVMSetInitializer(llglobal, llval);
|
|
|
|
lib::llvm::llvm::LLVMSetGlobalConstant(llglobal, True);
|
2011-08-20 16:22:09 -05:00
|
|
|
|
2011-09-02 17:34:58 -05:00
|
|
|
if internal {
|
2012-02-01 04:04:56 -06:00
|
|
|
lib::llvm::SetLinkage(llglobal, lib::llvm::InternalLinkage);
|
2011-08-20 16:22:09 -05:00
|
|
|
}
|
|
|
|
|
2012-08-01 19:30:05 -05:00
|
|
|
return llglobal;
|
2011-08-04 12:46:10 -05:00
|
|
|
}
|
|
|
|
|
2011-10-12 15:31:41 -05:00
|
|
|
fn mk_ctxt(llmod: ModuleRef) -> ctxt {
|
2012-07-14 00:57:48 -05:00
|
|
|
let llshapetablesty = trans::common::T_named_struct(~"shapes");
|
2012-09-25 19:39:23 -05:00
|
|
|
let _llshapetables = str::as_c_str(~"shapes", |buf| {
|
2012-01-27 06:17:06 -06:00
|
|
|
lib::llvm::llvm::LLVMAddGlobal(llmod, llshapetablesty, buf)
|
|
|
|
});
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-09-25 19:39:23 -05:00
|
|
|
return {mut next_tag_id: 0u16, pad: 0u16, pad2: 0u32};
|
2012-06-25 22:00:46 -05:00
|
|
|
}
|
2011-08-04 12:46:10 -05:00
|
|
|
|
2012-10-05 21:23:44 -05:00
|
|
|
/*
|
|
|
|
Although these two functions are never called, they are here
|
|
|
|
for a VERY GOOD REASON. See #3670
|
|
|
|
*/
|
|
|
|
fn add_u16(dest: &mut ~[u8], val: u16) {
|
|
|
|
*dest += ~[(val & 0xffu16) as u8, (val >> 8u16) as u8];
|
2011-08-04 12:46:10 -05:00
|
|
|
}
|
|
|
|
|
2012-10-05 21:23:44 -05:00
|
|
|
fn add_substr(dest: &mut ~[u8], src: ~[u8]) {
|
2011-08-15 18:38:23 -05:00
|
|
|
add_u16(dest, vec::len(src) as u16);
|
2012-10-05 21:23:44 -05:00
|
|
|
*dest += src;
|
2011-08-04 12:46:10 -05:00
|
|
|
}
|
|
|
|
|