InitExprs[Init] = expr;
}
+ /// \brief Reserve space for some number of initializers.
+ void reserveInits(unsigned NumInits);
+
/// @brief Specify the number of initializers
///
/// If there are more than @p NumInits initializers, the remaining
InitExprs.insert(InitExprs.end(), initExprs, initExprs+numInits);
}
+void InitListExpr::reserveInits(unsigned NumInits) {
+ if (NumInits > InitExprs.size())
+ InitExprs.reserve(NumInits);
+}
+
void InitListExpr::resizeInits(ASTContext &Context, unsigned NumInits) {
for (unsigned Idx = NumInits, LastIdx = InitExprs.size();
Idx < LastIdx; ++Idx)
Result->setType(CurrentObjectType);
+ // Pre-allocate storage for the structured initializer list.
+ unsigned NumElements = 0;
+ if (const ArrayType *AType
+ = SemaRef.Context.getAsArrayType(CurrentObjectType)) {
+ if (const ConstantArrayType *CAType = dyn_cast<ConstantArrayType>(AType)) {
+ NumElements = CAType->getSize().getZExtValue();
+ // Simple heuristic so that we don't allocate a very large
+ // initializer with many empty entries at the end.
+ if (IList && NumElements > IList->getNumInits())
+ NumElements = 0;
+ }
+ } else if (const VectorType *VType = CurrentObjectType->getAsVectorType())
+ NumElements = VType->getNumElements();
+ else if (const RecordType *RType = CurrentObjectType->getAsRecordType()) {
+ RecordDecl *RDecl = RType->getDecl();
+ if (RDecl->isUnion())
+ NumElements = 1;
+ else
+ NumElements = std::distance(RDecl->field_begin(), RDecl->field_end());
+ }
+
+ if (IList && NumElements < IList->getNumInits())
+ NumElements = IList->getNumInits();
+
+ Result->reserveInits(NumElements);
+
// Link this new initializer list into the structured initializer
// lists.
if (StructuredList)