diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/AST/Expr.cpp | 2 | ||||
-rw-r--r-- | lib/CodeGen/CGExprAgg.cpp | 8 | ||||
-rw-r--r-- | lib/CodeGen/CGExprScalar.cpp | 4 | ||||
-rw-r--r-- | lib/Sema/SemaInit.cpp | 4 |
4 files changed, 14 insertions, 4 deletions
diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index 8a04198293..35384d880c 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -224,7 +224,7 @@ InitListExpr::InitListExpr(SourceLocation lbraceloc, SourceLocation rbraceloc) : Expr(InitListExprClass, QualType()), LBraceLoc(lbraceloc), RBraceLoc(rbraceloc), SyntacticForm(0), - UnionFieldInit(0) { + UnionFieldInit(0), HadArrayRangeDesignator(false) { InitExprs.insert(InitExprs.end(), initExprs, initExprs+numInits); } diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp index f985763b5c..bf80b94d21 100644 --- a/lib/CodeGen/CGExprAgg.cpp +++ b/lib/CodeGen/CGExprAgg.cpp @@ -307,6 +307,10 @@ void AggExprEmitter::EmitNonConstInit(InitListExpr *E) { cast<llvm::PointerType>(DestPtr->getType()); const llvm::Type *DestType = APType->getElementType(); + if (E->hadArrayRangeDesignator()) { + CGF.ErrorUnsupported(E, "GNU array range designator extension"); + } + if (const llvm::ArrayType *AType = dyn_cast<llvm::ArrayType>(DestType)) { unsigned NumInitElements = E->getNumInits(); @@ -397,6 +401,10 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) { return; } #endif + if (E->hadArrayRangeDesignator()) { + CGF.ErrorUnsupported(E, "GNU array range designator extension"); + } + // Handle initialization of an array. if (E->getType()->isArrayType()) { const llvm::PointerType *APType = diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index f855e23ba0..1d389b6049 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -169,6 +169,10 @@ public: Value *VisitInitListExpr(InitListExpr *E) { unsigned NumInitElements = E->getNumInits(); + if (E->hadArrayRangeDesignator()) { + CGF.ErrorUnsupported(E, "GNU array range designator extension"); + } + const llvm::VectorType *VType = dyn_cast<llvm::VectorType>(ConvertType(E->getType())); diff --git a/lib/Sema/SemaInit.cpp b/lib/Sema/SemaInit.cpp index 5d7f705edb..77679ee36f 100644 --- a/lib/Sema/SemaInit.cpp +++ b/lib/Sema/SemaInit.cpp @@ -867,9 +867,7 @@ InitListChecker::CheckDesignatedInitializer(InitListExpr *IList, IndexExpr = DIE->getArrayRangeEnd(*D); if (DesignatedStartIndex.getZExtValue() != DesignatedEndIndex.getZExtValue()) - SemaRef->Diag(D->getEllipsisLoc(), - diag::warn_gnu_array_range_designator_side_effects) - << SourceRange(D->getLBracketLoc(), D->getRBracketLoc()); + FullyStructuredList->sawArrayRangeDesignator(); } if (isa<ConstantArrayType>(AT)) { |