mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-01-12 10:53:14 +01:00
[svn r311] Fixed: structs no longer output two static typeinfos.
Updated the DtoTypeInfoOf helper a bit after figuring out how it worked.
This commit is contained in:
@@ -1085,17 +1085,16 @@ void DtoAnnotation(const char* str)
|
||||
|
||||
LLConstant* DtoTypeInfoOf(Type* type, bool base)
|
||||
{
|
||||
type = type->merge(); // seems like this is needed in some cases with templates.
|
||||
const LLType* typeinfotype = DtoType(Type::typeinfo->type);
|
||||
if (!type->vtinfo)
|
||||
type->getTypeInfo(NULL);
|
||||
type = type->merge(); // needed.. getTypeInfo does the same
|
||||
type->getTypeInfo(NULL);
|
||||
TypeInfoDeclaration* tidecl = type->vtinfo;
|
||||
assert(tidecl);
|
||||
DtoForceDeclareDsymbol(tidecl);
|
||||
assert(tidecl->ir.irGlobal != NULL);
|
||||
LLConstant* c = isaConstant(tidecl->ir.irGlobal->value);
|
||||
assert(c != NULL);
|
||||
if (base)
|
||||
return llvm::ConstantExpr::getBitCast(c, typeinfotype);
|
||||
return llvm::ConstantExpr::getBitCast(c, DtoType(Type::typeinfo->type));
|
||||
return c;
|
||||
}
|
||||
|
||||
|
||||
@@ -383,6 +383,7 @@ void TypeInfoTypedefDeclaration::llvmDefine()
|
||||
TypedefDeclaration *sd = tc->sym;
|
||||
|
||||
// TypeInfo base
|
||||
sd->basetype = sd->basetype->merge(); // DMD does this!
|
||||
LLConstant* castbase = DtoTypeInfoOf(sd->basetype, true);
|
||||
assert(castbase->getType() == stype->getElementType(2));
|
||||
sinits.push_back(castbase);
|
||||
@@ -962,8 +963,6 @@ void TypeInfoStructDeclaration::llvmDefine()
|
||||
|
||||
// create the symbol
|
||||
LLConstant* tiInit = llvm::ConstantStruct::get(stype, sinits);
|
||||
llvm::GlobalVariable* gvar = new llvm::GlobalVariable(stype,true,llvm::GlobalValue::WeakLinkage,tiInit,toChars(),gIR->module);
|
||||
|
||||
isaGlobalVar(this->ir.irGlobal->value)->setInitializer(tiInit);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user