diff options
Diffstat (limited to 'lib/CodeGen/CGExprAgg.cpp')
-rw-r--r-- | lib/CodeGen/CGExprAgg.cpp | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp index 2534a14cb6..075a12c57e 100644 --- a/lib/CodeGen/CGExprAgg.cpp +++ b/lib/CodeGen/CGExprAgg.cpp @@ -454,10 +454,17 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) { if (Field->getType()->isIncompleteArrayType()) break; - if (Field->getIdentifier() == 0) { - // Initializers can't initialize unnamed fields, e.g. "int : 20;" + if (Field->isUnnamedBitfield()) continue; - } + + // When we're coping with C99 designated initializers into a + // union, find the field that has the same type as the expression + // we're initializing the union with. + if (isUnion && CurInitVal < NumInitElements && + (CGF.getContext().getCanonicalType(Field->getType()) != + CGF.getContext().getCanonicalType(E->getInit(CurInitVal)->getType()))) + continue; + // FIXME: volatility LValue FieldLoc = CGF.EmitLValueForField(DestPtr, *Field, isUnion,0); if (CurInitVal < NumInitElements) { @@ -471,8 +478,6 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) { } // Unions only initialize one field. - // (FIXME: things can get weird with designators, but they aren't - // supported yet.) if (isUnion) break; } |