forked from OSchip/llvm-project
add a hack so that codegen doesn't abort on missing sema of initializers, now
we emit stuff like this: abort on missing sema of initializers, now we emit stuff like this: t3.c:1:24: warning: cannot codegen this initializer yet const char x[2][4] = { { 'a', 'b', '\0', '\0' }, { 'c', 'd', 'e', '\0' } }; ^~~~~~~~~~~~~~~~~~~~~~~~ This should be removed when sema is finished. llvm-svn: 45086
This commit is contained in:
parent
083bb46370
commit
28c91c5f35
|
@ -281,7 +281,15 @@ static llvm::Constant *GenerateConstantCast(const Expr *Expression,
|
|||
/// struct typed variables.
|
||||
static llvm::Constant *GenerateAggregateInit(const InitListExpr *ILE,
|
||||
CodeGenModule &CGM) {
|
||||
assert (ILE->getType()->isArrayType() || ILE->getType()->isStructureType());
|
||||
if (ILE->getType()->isVoidType()) {
|
||||
// FIXME: Remove this when sema of initializers is finished (and the code
|
||||
// below).
|
||||
CGM.WarnUnsupported(ILE, "initializer");
|
||||
return 0;
|
||||
}
|
||||
|
||||
assert((ILE->getType()->isArrayType() || ILE->getType()->isStructureType()) &&
|
||||
"Bad type for init list!");
|
||||
CodeGenTypes& Types = CGM.getTypes();
|
||||
|
||||
unsigned NumInitElements = ILE->getNumInits();
|
||||
|
@ -309,6 +317,12 @@ static llvm::Constant *GenerateAggregateInit(const InitListExpr *ILE,
|
|||
unsigned i = 0;
|
||||
for (i = 0; i < NumInitableElts; ++i) {
|
||||
llvm::Constant *C = GenerateConstantExpr(ILE->getInit(i), CGM);
|
||||
// FIXME: Remove this when sema of initializers is finished (and the code
|
||||
// above).
|
||||
if (C == 0 && ILE->getInit(i)->getType()->isVoidType()) {
|
||||
if (ILE->getType()->isVoidType()) return 0;
|
||||
return llvm::UndefValue::get(CType);
|
||||
}
|
||||
assert (C && "Failed to create initialiser expression");
|
||||
Elts.push_back(C);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue