blob: ee32c6bd8bd19f37cb326c77519fc0fdf1f938c6 [file] [log] [blame]
Steve Naroff0cca7492008-05-01 22:18:59 +00001//===--- SemaInit.cpp - Semantic Analysis for Initializers ----------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
Sebastian Redl5d3d41d2011-09-24 17:47:39 +000010// This file implements semantic analysis for initializers.
Chris Lattnerdd8e0062009-02-24 22:27:37 +000011//
Steve Naroff0cca7492008-05-01 22:18:59 +000012//===----------------------------------------------------------------------===//
13
John McCall19510852010-08-20 18:27:03 +000014#include "clang/Sema/Designator.h"
Douglas Gregore737f502010-08-12 20:07:10 +000015#include "clang/Sema/Initialization.h"
16#include "clang/Sema/Lookup.h"
John McCall2d887082010-08-25 22:03:47 +000017#include "clang/Sema/SemaInternal.h"
Tanya Lattner1e1d3962010-03-07 04:17:15 +000018#include "clang/Lex/Preprocessor.h"
Steve Naroff0cca7492008-05-01 22:18:59 +000019#include "clang/AST/ASTContext.h"
John McCall7cd088e2010-08-24 07:21:54 +000020#include "clang/AST/DeclObjC.h"
Anders Carlsson2078bb92009-05-27 16:10:08 +000021#include "clang/AST/ExprCXX.h"
Chris Lattner79e079d2009-02-24 23:10:27 +000022#include "clang/AST/ExprObjC.h"
Douglas Gregord6542d82009-12-22 15:35:07 +000023#include "clang/AST/TypeLoc.h"
Sebastian Redl2b916b82012-01-17 22:49:42 +000024#include "llvm/ADT/APInt.h"
Benjamin Kramer8fe83e12012-02-04 13:45:25 +000025#include "llvm/ADT/SmallString.h"
Douglas Gregor20093b42009-12-09 23:02:17 +000026#include "llvm/Support/ErrorHandling.h"
Jeffrey Yasskin19159132011-07-26 23:20:30 +000027#include "llvm/Support/raw_ostream.h"
Douglas Gregorc34ee5e2009-01-29 00:45:39 +000028#include <map>
Douglas Gregor05c13a32009-01-22 00:58:24 +000029using namespace clang;
Steve Naroff0cca7492008-05-01 22:18:59 +000030
Chris Lattnerdd8e0062009-02-24 22:27:37 +000031//===----------------------------------------------------------------------===//
32// Sema Initialization Checking
33//===----------------------------------------------------------------------===//
34
John McCallce6c9b72011-02-21 07:22:22 +000035static Expr *IsStringInit(Expr *Init, const ArrayType *AT,
36 ASTContext &Context) {
Eli Friedman8718a6a2009-05-29 18:22:49 +000037 if (!isa<ConstantArrayType>(AT) && !isa<IncompleteArrayType>(AT))
38 return 0;
39
Chris Lattner8879e3b2009-02-26 23:26:43 +000040 // See if this is a string literal or @encode.
41 Init = Init->IgnoreParens();
Mike Stump1eb44332009-09-09 15:08:12 +000042
Chris Lattner8879e3b2009-02-26 23:26:43 +000043 // Handle @encode, which is a narrow string.
44 if (isa<ObjCEncodeExpr>(Init) && AT->getElementType()->isCharType())
45 return Init;
46
47 // Otherwise we can only handle string literals.
48 StringLiteral *SL = dyn_cast<StringLiteral>(Init);
Chris Lattner220b6362009-02-26 23:42:47 +000049 if (SL == 0) return 0;
Eli Friedmanbb6415c2009-05-31 10:54:53 +000050
51 QualType ElemTy = Context.getCanonicalType(AT->getElementType());
Douglas Gregor5cee1192011-07-27 05:40:30 +000052
53 switch (SL->getKind()) {
54 case StringLiteral::Ascii:
55 case StringLiteral::UTF8:
56 // char array can be initialized with a narrow string.
57 // Only allow char x[] = "foo"; not char x[] = L"foo";
Eli Friedmanbb6415c2009-05-31 10:54:53 +000058 return ElemTy->isCharType() ? Init : 0;
Douglas Gregor5cee1192011-07-27 05:40:30 +000059 case StringLiteral::UTF16:
60 return ElemTy->isChar16Type() ? Init : 0;
61 case StringLiteral::UTF32:
62 return ElemTy->isChar32Type() ? Init : 0;
63 case StringLiteral::Wide:
64 // wchar_t array can be initialized with a wide string: C99 6.7.8p15 (with
65 // correction from DR343): "An array with element type compatible with a
66 // qualified or unqualified version of wchar_t may be initialized by a wide
67 // string literal, optionally enclosed in braces."
68 if (Context.typesAreCompatible(Context.getWCharType(),
69 ElemTy.getUnqualifiedType()))
70 return Init;
Chris Lattner8879e3b2009-02-26 23:26:43 +000071
Douglas Gregor5cee1192011-07-27 05:40:30 +000072 return 0;
73 }
Mike Stump1eb44332009-09-09 15:08:12 +000074
Douglas Gregor5cee1192011-07-27 05:40:30 +000075 llvm_unreachable("missed a StringLiteral kind?");
Chris Lattnerdd8e0062009-02-24 22:27:37 +000076}
77
John McCallce6c9b72011-02-21 07:22:22 +000078static Expr *IsStringInit(Expr *init, QualType declType, ASTContext &Context) {
79 const ArrayType *arrayType = Context.getAsArrayType(declType);
80 if (!arrayType) return 0;
81
82 return IsStringInit(init, arrayType, Context);
83}
84
John McCallfef8b342011-02-21 07:57:55 +000085static void CheckStringInit(Expr *Str, QualType &DeclT, const ArrayType *AT,
86 Sema &S) {
Chris Lattner79e079d2009-02-24 23:10:27 +000087 // Get the length of the string as parsed.
88 uint64_t StrLength =
89 cast<ConstantArrayType>(Str->getType())->getSize().getZExtValue();
90
Mike Stump1eb44332009-09-09 15:08:12 +000091
Chris Lattnerdd8e0062009-02-24 22:27:37 +000092 if (const IncompleteArrayType *IAT = dyn_cast<IncompleteArrayType>(AT)) {
Mike Stump1eb44332009-09-09 15:08:12 +000093 // C99 6.7.8p14. We have an array of character type with unknown size
Chris Lattnerdd8e0062009-02-24 22:27:37 +000094 // being initialized to a string literal.
Benjamin Kramer65263b42012-08-04 17:00:46 +000095 llvm::APInt ConstVal(32, StrLength);
Chris Lattnerdd8e0062009-02-24 22:27:37 +000096 // Return a new array type (C99 6.7.8p22).
John McCall46a617a2009-10-16 00:14:28 +000097 DeclT = S.Context.getConstantArrayType(IAT->getElementType(),
98 ConstVal,
99 ArrayType::Normal, 0);
Chris Lattner19da8cd2009-02-24 23:01:39 +0000100 return;
Chris Lattnerdd8e0062009-02-24 22:27:37 +0000101 }
Mike Stump1eb44332009-09-09 15:08:12 +0000102
Eli Friedman8718a6a2009-05-29 18:22:49 +0000103 const ConstantArrayType *CAT = cast<ConstantArrayType>(AT);
Mike Stump1eb44332009-09-09 15:08:12 +0000104
Eli Friedmanbc34b1d2011-04-11 00:23:45 +0000105 // We have an array of character type with known size. However,
Eli Friedman8718a6a2009-05-29 18:22:49 +0000106 // the size may be smaller or larger than the string we are initializing.
107 // FIXME: Avoid truncation for 64-bit length strings.
David Blaikie4e4d0842012-03-11 07:00:24 +0000108 if (S.getLangOpts().CPlusPlus) {
Anders Carlssonb8fc45f2011-04-14 00:41:11 +0000109 if (StringLiteral *SL = dyn_cast<StringLiteral>(Str)) {
110 // For Pascal strings it's OK to strip off the terminating null character,
111 // so the example below is valid:
112 //
113 // unsigned char a[2] = "\pa";
114 if (SL->isPascal())
115 StrLength--;
116 }
117
Eli Friedmanbc34b1d2011-04-11 00:23:45 +0000118 // [dcl.init.string]p2
119 if (StrLength > CAT->getSize().getZExtValue())
Daniel Dunbar96a00142012-03-09 18:35:03 +0000120 S.Diag(Str->getLocStart(),
Eli Friedmanbc34b1d2011-04-11 00:23:45 +0000121 diag::err_initializer_string_for_char_array_too_long)
122 << Str->getSourceRange();
123 } else {
124 // C99 6.7.8p14.
125 if (StrLength-1 > CAT->getSize().getZExtValue())
Daniel Dunbar96a00142012-03-09 18:35:03 +0000126 S.Diag(Str->getLocStart(),
Eli Friedmanbc34b1d2011-04-11 00:23:45 +0000127 diag::warn_initializer_string_for_char_array_too_long)
128 << Str->getSourceRange();
129 }
Mike Stump1eb44332009-09-09 15:08:12 +0000130
Eli Friedman8718a6a2009-05-29 18:22:49 +0000131 // Set the type to the actual size that we are initializing. If we have
132 // something like:
133 // char x[1] = "foo";
134 // then this will set the string literal's type to char[1].
135 Str->setType(DeclT);
Chris Lattnerdd8e0062009-02-24 22:27:37 +0000136}
137
Chris Lattnerdd8e0062009-02-24 22:27:37 +0000138//===----------------------------------------------------------------------===//
139// Semantic checking for initializer lists.
140//===----------------------------------------------------------------------===//
141
Douglas Gregor9e80f722009-01-29 01:05:33 +0000142/// @brief Semantic checking for initializer lists.
143///
144/// The InitListChecker class contains a set of routines that each
145/// handle the initialization of a certain kind of entity, e.g.,
146/// arrays, vectors, struct/union types, scalars, etc. The
147/// InitListChecker itself performs a recursive walk of the subobject
148/// structure of the type to be initialized, while stepping through
149/// the initializer list one element at a time. The IList and Index
150/// parameters to each of the Check* routines contain the active
151/// (syntactic) initializer list and the index into that initializer
152/// list that represents the current initializer. Each routine is
153/// responsible for moving that Index forward as it consumes elements.
154///
155/// Each Check* routine also has a StructuredList/StructuredIndex
Abramo Bagnara63e7d252011-01-27 19:55:10 +0000156/// arguments, which contains the current "structured" (semantic)
Douglas Gregor9e80f722009-01-29 01:05:33 +0000157/// initializer list and the index into that initializer list where we
158/// are copying initializers as we map them over to the semantic
159/// list. Once we have completed our recursive walk of the subobject
160/// structure, we will have constructed a full semantic initializer
161/// list.
162///
163/// C99 designators cause changes in the initializer list traversal,
164/// because they make the initialization "jump" into a specific
165/// subobject and then continue the initialization from that
166/// point. CheckDesignatedInitializer() recursively steps into the
167/// designated subobject and manages backing out the recursion to
168/// initialize the subobjects after the one designated.
Chris Lattner8b419b92009-02-24 22:48:58 +0000169namespace {
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000170class InitListChecker {
Chris Lattner08202542009-02-24 22:50:46 +0000171 Sema &SemaRef;
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000172 bool hadError;
Sebastian Redl14b0c192011-09-24 17:48:00 +0000173 bool VerifyOnly; // no diagnostics, no structure building
Sebastian Redlc2235182011-10-16 18:19:28 +0000174 bool AllowBraceElision;
Benjamin Kramera7894162012-02-23 14:48:40 +0000175 llvm::DenseMap<InitListExpr *, InitListExpr *> SyntacticToSemantic;
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000176 InitListExpr *FullyStructuredList;
Mike Stump1eb44332009-09-09 15:08:12 +0000177
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000178 void CheckImplicitInitList(const InitializedEntity &Entity,
Anders Carlsson987dc6a2010-01-23 20:47:59 +0000179 InitListExpr *ParentIList, QualType T,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000180 unsigned &Index, InitListExpr *StructuredList,
Eli Friedman629f1182011-08-23 20:17:13 +0000181 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000182 void CheckExplicitInitList(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000183 InitListExpr *IList, QualType &T,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000184 unsigned &Index, InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000185 unsigned &StructuredIndex,
186 bool TopLevelObject = false);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000187 void CheckListElementTypes(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000188 InitListExpr *IList, QualType &DeclType,
Mike Stump1eb44332009-09-09 15:08:12 +0000189 bool SubobjectIsDesignatorContext,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000190 unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000191 InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000192 unsigned &StructuredIndex,
193 bool TopLevelObject = false);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000194 void CheckSubElementType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000195 InitListExpr *IList, QualType ElemType,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000196 unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000197 InitListExpr *StructuredList,
198 unsigned &StructuredIndex);
Eli Friedman0c706c22011-09-19 23:17:44 +0000199 void CheckComplexType(const InitializedEntity &Entity,
200 InitListExpr *IList, QualType DeclType,
201 unsigned &Index,
202 InitListExpr *StructuredList,
203 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000204 void CheckScalarType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000205 InitListExpr *IList, QualType DeclType,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000206 unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000207 InitListExpr *StructuredList,
208 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000209 void CheckReferenceType(const InitializedEntity &Entity,
210 InitListExpr *IList, QualType DeclType,
Douglas Gregor930d8b52009-01-30 22:09:00 +0000211 unsigned &Index,
212 InitListExpr *StructuredList,
213 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000214 void CheckVectorType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000215 InitListExpr *IList, QualType DeclType, unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000216 InitListExpr *StructuredList,
217 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000218 void CheckStructUnionTypes(const InitializedEntity &Entity,
Anders Carlsson2bbae5d2010-01-23 20:20:40 +0000219 InitListExpr *IList, QualType DeclType,
Mike Stump1eb44332009-09-09 15:08:12 +0000220 RecordDecl::field_iterator Field,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000221 bool SubobjectIsDesignatorContext, unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000222 InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000223 unsigned &StructuredIndex,
224 bool TopLevelObject = false);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000225 void CheckArrayType(const InitializedEntity &Entity,
Anders Carlsson784f6992010-01-23 20:13:41 +0000226 InitListExpr *IList, QualType &DeclType,
Mike Stump1eb44332009-09-09 15:08:12 +0000227 llvm::APSInt elementIndex,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000228 bool SubobjectIsDesignatorContext, unsigned &Index,
Douglas Gregor9e80f722009-01-29 01:05:33 +0000229 InitListExpr *StructuredList,
230 unsigned &StructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000231 bool CheckDesignatedInitializer(const InitializedEntity &Entity,
Anders Carlsson9a8a70e2010-01-23 22:49:02 +0000232 InitListExpr *IList, DesignatedInitExpr *DIE,
Douglas Gregor71199712009-04-15 04:56:10 +0000233 unsigned DesigIdx,
Mike Stump1eb44332009-09-09 15:08:12 +0000234 QualType &CurrentObjectType,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000235 RecordDecl::field_iterator *NextField,
236 llvm::APSInt *NextElementIndex,
237 unsigned &Index,
238 InitListExpr *StructuredList,
239 unsigned &StructuredIndex,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000240 bool FinishSubobjectInit,
241 bool TopLevelObject);
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000242 InitListExpr *getStructuredSubobjectInit(InitListExpr *IList, unsigned Index,
243 QualType CurrentObjectType,
244 InitListExpr *StructuredList,
245 unsigned StructuredIndex,
246 SourceRange InitRange);
Douglas Gregor9e80f722009-01-29 01:05:33 +0000247 void UpdateStructuredListElement(InitListExpr *StructuredList,
248 unsigned &StructuredIndex,
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000249 Expr *expr);
250 int numArrayElements(QualType DeclType);
251 int numStructUnionElements(QualType DeclType);
Douglas Gregor930d8b52009-01-30 22:09:00 +0000252
Douglas Gregord6d37de2009-12-22 00:05:34 +0000253 void FillInValueInitForField(unsigned Init, FieldDecl *Field,
254 const InitializedEntity &ParentEntity,
255 InitListExpr *ILE, bool &RequiresSecondPass);
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000256 void FillInValueInitializations(const InitializedEntity &Entity,
257 InitListExpr *ILE, bool &RequiresSecondPass);
Eli Friedmanf40fd6b2011-08-23 22:24:57 +0000258 bool CheckFlexibleArrayInit(const InitializedEntity &Entity,
259 Expr *InitExpr, FieldDecl *Field,
260 bool TopLevelObject);
Sebastian Redl3ff5c862011-10-16 18:19:20 +0000261 void CheckValueInitializable(const InitializedEntity &Entity);
262
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000263public:
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000264 InitListChecker(Sema &S, const InitializedEntity &Entity,
Sebastian Redlc2235182011-10-16 18:19:28 +0000265 InitListExpr *IL, QualType &T, bool VerifyOnly,
266 bool AllowBraceElision);
Douglas Gregorc34ee5e2009-01-29 00:45:39 +0000267 bool HadError() { return hadError; }
268
269 // @brief Retrieves the fully-structured initializer list used for
270 // semantic analysis and code generation.
271 InitListExpr *getFullyStructuredList() const { return FullyStructuredList; }
272};
Chris Lattner8b419b92009-02-24 22:48:58 +0000273} // end anonymous namespace
Chris Lattner68355a52009-01-29 05:10:57 +0000274
Sebastian Redl3ff5c862011-10-16 18:19:20 +0000275void InitListChecker::CheckValueInitializable(const InitializedEntity &Entity) {
276 assert(VerifyOnly &&
277 "CheckValueInitializable is only inteded for verification mode.");
278
279 SourceLocation Loc;
280 InitializationKind Kind = InitializationKind::CreateValue(Loc, Loc, Loc,
281 true);
282 InitializationSequence InitSeq(SemaRef, Entity, Kind, 0, 0);
283 if (InitSeq.Failed())
284 hadError = true;
285}
286
Douglas Gregord6d37de2009-12-22 00:05:34 +0000287void InitListChecker::FillInValueInitForField(unsigned Init, FieldDecl *Field,
288 const InitializedEntity &ParentEntity,
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000289 InitListExpr *ILE,
Douglas Gregord6d37de2009-12-22 00:05:34 +0000290 bool &RequiresSecondPass) {
Daniel Dunbar96a00142012-03-09 18:35:03 +0000291 SourceLocation Loc = ILE->getLocStart();
Douglas Gregord6d37de2009-12-22 00:05:34 +0000292 unsigned NumInits = ILE->getNumInits();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000293 InitializedEntity MemberEntity
Douglas Gregord6d37de2009-12-22 00:05:34 +0000294 = InitializedEntity::InitializeMember(Field, &ParentEntity);
295 if (Init >= NumInits || !ILE->getInit(Init)) {
296 // FIXME: We probably don't need to handle references
297 // specially here, since value-initialization of references is
298 // handled in InitializationSequence.
299 if (Field->getType()->isReferenceType()) {
300 // C++ [dcl.init.aggr]p9:
301 // If an incomplete or empty initializer-list leaves a
302 // member of reference type uninitialized, the program is
303 // ill-formed.
304 SemaRef.Diag(Loc, diag::err_init_reference_member_uninitialized)
305 << Field->getType()
306 << ILE->getSyntacticForm()->getSourceRange();
307 SemaRef.Diag(Field->getLocation(),
308 diag::note_uninit_reference_member);
309 hadError = true;
310 return;
311 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000312
Douglas Gregord6d37de2009-12-22 00:05:34 +0000313 InitializationKind Kind = InitializationKind::CreateValue(Loc, Loc, Loc,
314 true);
315 InitializationSequence InitSeq(SemaRef, MemberEntity, Kind, 0, 0);
316 if (!InitSeq) {
317 InitSeq.Diagnose(SemaRef, MemberEntity, Kind, 0, 0);
318 hadError = true;
319 return;
320 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000321
John McCall60d7b3a2010-08-24 06:29:42 +0000322 ExprResult MemberInit
John McCallf312b1e2010-08-26 23:41:50 +0000323 = InitSeq.Perform(SemaRef, MemberEntity, Kind, MultiExprArg());
Douglas Gregord6d37de2009-12-22 00:05:34 +0000324 if (MemberInit.isInvalid()) {
325 hadError = true;
326 return;
327 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000328
Douglas Gregord6d37de2009-12-22 00:05:34 +0000329 if (hadError) {
330 // Do nothing
331 } else if (Init < NumInits) {
332 ILE->setInit(Init, MemberInit.takeAs<Expr>());
Sebastian Redl7491c492011-06-05 13:59:11 +0000333 } else if (InitSeq.isConstructorInitialization()) {
Douglas Gregord6d37de2009-12-22 00:05:34 +0000334 // Value-initialization requires a constructor call, so
335 // extend the initializer list to include the constructor
336 // call and make a note that we'll need to take another pass
337 // through the initializer list.
Ted Kremenek709210f2010-04-13 23:39:13 +0000338 ILE->updateInit(SemaRef.Context, Init, MemberInit.takeAs<Expr>());
Douglas Gregord6d37de2009-12-22 00:05:34 +0000339 RequiresSecondPass = true;
340 }
341 } else if (InitListExpr *InnerILE
342 = dyn_cast<InitListExpr>(ILE->getInit(Init)))
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000343 FillInValueInitializations(MemberEntity, InnerILE,
344 RequiresSecondPass);
Douglas Gregord6d37de2009-12-22 00:05:34 +0000345}
346
Douglas Gregor4c678342009-01-28 21:54:33 +0000347/// Recursively replaces NULL values within the given initializer list
348/// with expressions that perform value-initialization of the
349/// appropriate type.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000350void
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000351InitListChecker::FillInValueInitializations(const InitializedEntity &Entity,
352 InitListExpr *ILE,
353 bool &RequiresSecondPass) {
Mike Stump1eb44332009-09-09 15:08:12 +0000354 assert((ILE->getType() != SemaRef.Context.VoidTy) &&
Douglas Gregor930d8b52009-01-30 22:09:00 +0000355 "Should not have void type");
Daniel Dunbar96a00142012-03-09 18:35:03 +0000356 SourceLocation Loc = ILE->getLocStart();
Douglas Gregor87fd7032009-02-02 17:43:21 +0000357 if (ILE->getSyntacticForm())
Daniel Dunbar96a00142012-03-09 18:35:03 +0000358 Loc = ILE->getSyntacticForm()->getLocStart();
Mike Stump1eb44332009-09-09 15:08:12 +0000359
Ted Kremenek6217b802009-07-29 21:53:49 +0000360 if (const RecordType *RType = ILE->getType()->getAs<RecordType>()) {
Douglas Gregord6d37de2009-12-22 00:05:34 +0000361 if (RType->getDecl()->isUnion() &&
362 ILE->getInitializedFieldInUnion())
363 FillInValueInitForField(0, ILE->getInitializedFieldInUnion(),
364 Entity, ILE, RequiresSecondPass);
365 else {
366 unsigned Init = 0;
367 for (RecordDecl::field_iterator
368 Field = RType->getDecl()->field_begin(),
369 FieldEnd = RType->getDecl()->field_end();
370 Field != FieldEnd; ++Field) {
371 if (Field->isUnnamedBitfield())
372 continue;
Douglas Gregor4c678342009-01-28 21:54:33 +0000373
Douglas Gregord6d37de2009-12-22 00:05:34 +0000374 if (hadError)
Douglas Gregor87fd7032009-02-02 17:43:21 +0000375 return;
Douglas Gregord6d37de2009-12-22 00:05:34 +0000376
David Blaikie581deb32012-06-06 20:45:41 +0000377 FillInValueInitForField(Init, *Field, Entity, ILE, RequiresSecondPass);
Douglas Gregord6d37de2009-12-22 00:05:34 +0000378 if (hadError)
Douglas Gregor87fd7032009-02-02 17:43:21 +0000379 return;
Douglas Gregor87fd7032009-02-02 17:43:21 +0000380
Douglas Gregord6d37de2009-12-22 00:05:34 +0000381 ++Init;
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000382
Douglas Gregord6d37de2009-12-22 00:05:34 +0000383 // Only look at the first initialization of a union.
384 if (RType->getDecl()->isUnion())
385 break;
386 }
Douglas Gregor4c678342009-01-28 21:54:33 +0000387 }
388
389 return;
Mike Stump1eb44332009-09-09 15:08:12 +0000390 }
Douglas Gregor4c678342009-01-28 21:54:33 +0000391
392 QualType ElementType;
Mike Stump1eb44332009-09-09 15:08:12 +0000393
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000394 InitializedEntity ElementEntity = Entity;
Douglas Gregor87fd7032009-02-02 17:43:21 +0000395 unsigned NumInits = ILE->getNumInits();
396 unsigned NumElements = NumInits;
Chris Lattner08202542009-02-24 22:50:46 +0000397 if (const ArrayType *AType = SemaRef.Context.getAsArrayType(ILE->getType())) {
Douglas Gregor4c678342009-01-28 21:54:33 +0000398 ElementType = AType->getElementType();
Douglas Gregor87fd7032009-02-02 17:43:21 +0000399 if (const ConstantArrayType *CAType = dyn_cast<ConstantArrayType>(AType))
400 NumElements = CAType->getSize().getZExtValue();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000401 ElementEntity = InitializedEntity::InitializeElement(SemaRef.Context,
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000402 0, Entity);
John McCall183700f2009-09-21 23:43:11 +0000403 } else if (const VectorType *VType = ILE->getType()->getAs<VectorType>()) {
Douglas Gregor4c678342009-01-28 21:54:33 +0000404 ElementType = VType->getElementType();
Douglas Gregor87fd7032009-02-02 17:43:21 +0000405 NumElements = VType->getNumElements();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000406 ElementEntity = InitializedEntity::InitializeElement(SemaRef.Context,
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000407 0, Entity);
Mike Stump1eb44332009-09-09 15:08:12 +0000408 } else
Douglas Gregor4c678342009-01-28 21:54:33 +0000409 ElementType = ILE->getType();
Mike Stump1eb44332009-09-09 15:08:12 +0000410
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000411
Douglas Gregor87fd7032009-02-02 17:43:21 +0000412 for (unsigned Init = 0; Init != NumElements; ++Init) {
Douglas Gregor16006c92009-12-16 18:50:27 +0000413 if (hadError)
414 return;
415
Anders Carlssond3d824d2010-01-23 04:34:47 +0000416 if (ElementEntity.getKind() == InitializedEntity::EK_ArrayElement ||
417 ElementEntity.getKind() == InitializedEntity::EK_VectorElement)
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000418 ElementEntity.setElementIndex(Init);
419
Argyrios Kyrtzidis21f77cd2011-10-21 23:02:22 +0000420 Expr *InitExpr = (Init < NumInits ? ILE->getInit(Init) : 0);
421 if (!InitExpr && !ILE->hasArrayFiller()) {
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000422 InitializationKind Kind = InitializationKind::CreateValue(Loc, Loc, Loc,
423 true);
424 InitializationSequence InitSeq(SemaRef, ElementEntity, Kind, 0, 0);
425 if (!InitSeq) {
426 InitSeq.Diagnose(SemaRef, ElementEntity, Kind, 0, 0);
Douglas Gregor87fd7032009-02-02 17:43:21 +0000427 hadError = true;
428 return;
429 }
430
John McCall60d7b3a2010-08-24 06:29:42 +0000431 ExprResult ElementInit
John McCallf312b1e2010-08-26 23:41:50 +0000432 = InitSeq.Perform(SemaRef, ElementEntity, Kind, MultiExprArg());
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000433 if (ElementInit.isInvalid()) {
Douglas Gregor16006c92009-12-16 18:50:27 +0000434 hadError = true;
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000435 return;
436 }
437
438 if (hadError) {
439 // Do nothing
440 } else if (Init < NumInits) {
Argyrios Kyrtzidis3e8dc2a2011-04-21 20:03:38 +0000441 // For arrays, just set the expression used for value-initialization
442 // of the "holes" in the array.
443 if (ElementEntity.getKind() == InitializedEntity::EK_ArrayElement)
444 ILE->setArrayFiller(ElementInit.takeAs<Expr>());
445 else
446 ILE->setInit(Init, ElementInit.takeAs<Expr>());
Argyrios Kyrtzidis4423ac02011-04-21 00:27:41 +0000447 } else {
448 // For arrays, just set the expression used for value-initialization
449 // of the rest of elements and exit.
450 if (ElementEntity.getKind() == InitializedEntity::EK_ArrayElement) {
451 ILE->setArrayFiller(ElementInit.takeAs<Expr>());
452 return;
453 }
454
Sebastian Redl7491c492011-06-05 13:59:11 +0000455 if (InitSeq.isConstructorInitialization()) {
Argyrios Kyrtzidis4423ac02011-04-21 00:27:41 +0000456 // Value-initialization requires a constructor call, so
457 // extend the initializer list to include the constructor
458 // call and make a note that we'll need to take another pass
459 // through the initializer list.
460 ILE->updateInit(SemaRef.Context, Init, ElementInit.takeAs<Expr>());
461 RequiresSecondPass = true;
462 }
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000463 }
Mike Stumpac5fc7c2009-08-04 21:02:39 +0000464 } else if (InitListExpr *InnerILE
Argyrios Kyrtzidis21f77cd2011-10-21 23:02:22 +0000465 = dyn_cast_or_null<InitListExpr>(InitExpr))
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000466 FillInValueInitializations(ElementEntity, InnerILE, RequiresSecondPass);
Douglas Gregor4c678342009-01-28 21:54:33 +0000467 }
468}
469
Chris Lattner68355a52009-01-29 05:10:57 +0000470
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000471InitListChecker::InitListChecker(Sema &S, const InitializedEntity &Entity,
Sebastian Redl14b0c192011-09-24 17:48:00 +0000472 InitListExpr *IL, QualType &T,
Sebastian Redlc2235182011-10-16 18:19:28 +0000473 bool VerifyOnly, bool AllowBraceElision)
Richard Smithb6f8d282011-12-20 04:00:21 +0000474 : SemaRef(S), VerifyOnly(VerifyOnly), AllowBraceElision(AllowBraceElision) {
Steve Naroff0cca7492008-05-01 22:18:59 +0000475 hadError = false;
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000476
Eli Friedmanb85f7072008-05-19 19:16:24 +0000477 unsigned newIndex = 0;
Douglas Gregor4c678342009-01-28 21:54:33 +0000478 unsigned newStructuredIndex = 0;
Mike Stump1eb44332009-09-09 15:08:12 +0000479 FullyStructuredList
Douglas Gregored8a93d2009-03-01 17:12:46 +0000480 = getStructuredSubobjectInit(IL, newIndex, T, 0, 0, IL->getSourceRange());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000481 CheckExplicitInitList(Entity, IL, T, newIndex,
Anders Carlsson46f46592010-01-23 19:55:29 +0000482 FullyStructuredList, newStructuredIndex,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000483 /*TopLevelObject=*/true);
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000484
Sebastian Redl14b0c192011-09-24 17:48:00 +0000485 if (!hadError && !VerifyOnly) {
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000486 bool RequiresSecondPass = false;
487 FillInValueInitializations(Entity, FullyStructuredList, RequiresSecondPass);
Douglas Gregor16006c92009-12-16 18:50:27 +0000488 if (RequiresSecondPass && !hadError)
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000489 FillInValueInitializations(Entity, FullyStructuredList,
Douglas Gregorcb57fb92009-12-16 06:35:08 +0000490 RequiresSecondPass);
491 }
Steve Naroff0cca7492008-05-01 22:18:59 +0000492}
493
494int InitListChecker::numArrayElements(QualType DeclType) {
Eli Friedman638e1442008-05-25 13:22:35 +0000495 // FIXME: use a proper constant
496 int maxElements = 0x7FFFFFFF;
Chris Lattnerc63a1f22008-08-04 07:31:14 +0000497 if (const ConstantArrayType *CAT =
Chris Lattner08202542009-02-24 22:50:46 +0000498 SemaRef.Context.getAsConstantArrayType(DeclType)) {
Steve Naroff0cca7492008-05-01 22:18:59 +0000499 maxElements = static_cast<int>(CAT->getSize().getZExtValue());
500 }
501 return maxElements;
502}
503
504int InitListChecker::numStructUnionElements(QualType DeclType) {
Ted Kremenek6217b802009-07-29 21:53:49 +0000505 RecordDecl *structDecl = DeclType->getAs<RecordType>()->getDecl();
Douglas Gregor4c678342009-01-28 21:54:33 +0000506 int InitializableMembers = 0;
Mike Stump1eb44332009-09-09 15:08:12 +0000507 for (RecordDecl::field_iterator
Argyrios Kyrtzidis17945a02009-06-30 02:36:12 +0000508 Field = structDecl->field_begin(),
509 FieldEnd = structDecl->field_end();
Douglas Gregor4c678342009-01-28 21:54:33 +0000510 Field != FieldEnd; ++Field) {
Douglas Gregord61db332011-10-10 17:22:13 +0000511 if (!Field->isUnnamedBitfield())
Douglas Gregor4c678342009-01-28 21:54:33 +0000512 ++InitializableMembers;
513 }
Argyrios Kyrtzidis39ba4ae2008-06-09 23:19:58 +0000514 if (structDecl->isUnion())
Eli Friedmanf84eda32008-05-25 14:03:31 +0000515 return std::min(InitializableMembers, 1);
516 return InitializableMembers - structDecl->hasFlexibleArrayMember();
Steve Naroff0cca7492008-05-01 22:18:59 +0000517}
518
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000519void InitListChecker::CheckImplicitInitList(const InitializedEntity &Entity,
Anders Carlsson987dc6a2010-01-23 20:47:59 +0000520 InitListExpr *ParentIList,
Douglas Gregor4c678342009-01-28 21:54:33 +0000521 QualType T, unsigned &Index,
522 InitListExpr *StructuredList,
Eli Friedman629f1182011-08-23 20:17:13 +0000523 unsigned &StructuredIndex) {
Steve Naroff0cca7492008-05-01 22:18:59 +0000524 int maxElements = 0;
Mike Stump1eb44332009-09-09 15:08:12 +0000525
Steve Naroff0cca7492008-05-01 22:18:59 +0000526 if (T->isArrayType())
527 maxElements = numArrayElements(T);
Douglas Gregorfb87b892010-04-26 21:31:17 +0000528 else if (T->isRecordType())
Steve Naroff0cca7492008-05-01 22:18:59 +0000529 maxElements = numStructUnionElements(T);
Eli Friedmanb85f7072008-05-19 19:16:24 +0000530 else if (T->isVectorType())
John McCall183700f2009-09-21 23:43:11 +0000531 maxElements = T->getAs<VectorType>()->getNumElements();
Steve Naroff0cca7492008-05-01 22:18:59 +0000532 else
David Blaikieb219cfc2011-09-23 05:06:16 +0000533 llvm_unreachable("CheckImplicitInitList(): Illegal type");
Eli Friedmanb85f7072008-05-19 19:16:24 +0000534
Eli Friedman402256f2008-05-25 13:49:22 +0000535 if (maxElements == 0) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000536 if (!VerifyOnly)
537 SemaRef.Diag(ParentIList->getInit(Index)->getLocStart(),
538 diag::err_implicit_empty_initializer);
Douglas Gregor4c678342009-01-28 21:54:33 +0000539 ++Index;
Eli Friedman402256f2008-05-25 13:49:22 +0000540 hadError = true;
541 return;
542 }
543
Douglas Gregor4c678342009-01-28 21:54:33 +0000544 // Build a structured initializer list corresponding to this subobject.
545 InitListExpr *StructuredSubobjectInitList
Mike Stump1eb44332009-09-09 15:08:12 +0000546 = getStructuredSubobjectInit(ParentIList, Index, T, StructuredList,
547 StructuredIndex,
Daniel Dunbar96a00142012-03-09 18:35:03 +0000548 SourceRange(ParentIList->getInit(Index)->getLocStart(),
Douglas Gregored8a93d2009-03-01 17:12:46 +0000549 ParentIList->getSourceRange().getEnd()));
Douglas Gregor4c678342009-01-28 21:54:33 +0000550 unsigned StructuredSubobjectInitIndex = 0;
Eli Friedmanb85f7072008-05-19 19:16:24 +0000551
Douglas Gregor4c678342009-01-28 21:54:33 +0000552 // Check the element types and build the structural subobject.
Douglas Gregor87fd7032009-02-02 17:43:21 +0000553 unsigned StartIndex = Index;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000554 CheckListElementTypes(Entity, ParentIList, T,
Anders Carlsson987dc6a2010-01-23 20:47:59 +0000555 /*SubobjectIsDesignatorContext=*/false, Index,
Mike Stump1eb44332009-09-09 15:08:12 +0000556 StructuredSubobjectInitList,
Eli Friedman629f1182011-08-23 20:17:13 +0000557 StructuredSubobjectInitIndex);
Sebastian Redlc2235182011-10-16 18:19:28 +0000558
559 if (VerifyOnly) {
560 if (!AllowBraceElision && (T->isArrayType() || T->isRecordType()))
561 hadError = true;
562 } else {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000563 StructuredSubobjectInitList->setType(T);
Douglas Gregora6457962009-03-20 00:32:56 +0000564
Sebastian Redlc2235182011-10-16 18:19:28 +0000565 unsigned EndIndex = (Index == StartIndex? StartIndex : Index - 1);
Sebastian Redl14b0c192011-09-24 17:48:00 +0000566 // Update the structured sub-object initializer so that it's ending
567 // range corresponds with the end of the last initializer it used.
568 if (EndIndex < ParentIList->getNumInits()) {
569 SourceLocation EndLoc
570 = ParentIList->getInit(EndIndex)->getSourceRange().getEnd();
571 StructuredSubobjectInitList->setRBraceLoc(EndLoc);
572 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000573
Sebastian Redlc2235182011-10-16 18:19:28 +0000574 // Complain about missing braces.
Sebastian Redl14b0c192011-09-24 17:48:00 +0000575 if (T->isArrayType() || T->isRecordType()) {
576 SemaRef.Diag(StructuredSubobjectInitList->getLocStart(),
Sebastian Redlc2235182011-10-16 18:19:28 +0000577 AllowBraceElision ? diag::warn_missing_braces :
578 diag::err_missing_braces)
Sebastian Redl14b0c192011-09-24 17:48:00 +0000579 << StructuredSubobjectInitList->getSourceRange()
580 << FixItHint::CreateInsertion(
581 StructuredSubobjectInitList->getLocStart(), "{")
582 << FixItHint::CreateInsertion(
583 SemaRef.PP.getLocForEndOfToken(
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000584 StructuredSubobjectInitList->getLocEnd()),
Sebastian Redl14b0c192011-09-24 17:48:00 +0000585 "}");
Sebastian Redlc2235182011-10-16 18:19:28 +0000586 if (!AllowBraceElision)
587 hadError = true;
Sebastian Redl14b0c192011-09-24 17:48:00 +0000588 }
Tanya Lattner1e1d3962010-03-07 04:17:15 +0000589 }
Steve Naroff0cca7492008-05-01 22:18:59 +0000590}
591
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000592void InitListChecker::CheckExplicitInitList(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000593 InitListExpr *IList, QualType &T,
Douglas Gregor4c678342009-01-28 21:54:33 +0000594 unsigned &Index,
595 InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000596 unsigned &StructuredIndex,
597 bool TopLevelObject) {
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000598 assert(IList->isExplicit() && "Illegal Implicit InitListExpr");
Sebastian Redl14b0c192011-09-24 17:48:00 +0000599 if (!VerifyOnly) {
600 SyntacticToSemantic[IList] = StructuredList;
601 StructuredList->setSyntacticForm(IList);
602 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000603 CheckListElementTypes(Entity, IList, T, /*SubobjectIsDesignatorContext=*/true,
Anders Carlsson46f46592010-01-23 19:55:29 +0000604 Index, StructuredList, StructuredIndex, TopLevelObject);
Sebastian Redl14b0c192011-09-24 17:48:00 +0000605 if (!VerifyOnly) {
Eli Friedman5c89c392012-02-23 02:25:10 +0000606 QualType ExprTy = T;
607 if (!ExprTy->isArrayType())
608 ExprTy = ExprTy.getNonLValueExprType(SemaRef.Context);
Sebastian Redl14b0c192011-09-24 17:48:00 +0000609 IList->setType(ExprTy);
610 StructuredList->setType(ExprTy);
611 }
Eli Friedman638e1442008-05-25 13:22:35 +0000612 if (hadError)
613 return;
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000614
Eli Friedman638e1442008-05-25 13:22:35 +0000615 if (Index < IList->getNumInits()) {
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000616 // We have leftover initializers
Sebastian Redl14b0c192011-09-24 17:48:00 +0000617 if (VerifyOnly) {
David Blaikie4e4d0842012-03-11 07:00:24 +0000618 if (SemaRef.getLangOpts().CPlusPlus ||
619 (SemaRef.getLangOpts().OpenCL &&
Sebastian Redl14b0c192011-09-24 17:48:00 +0000620 IList->getType()->isVectorType())) {
621 hadError = true;
622 }
623 return;
624 }
625
Eli Friedmane5408582009-05-29 20:20:05 +0000626 if (StructuredIndex == 1 &&
627 IsStringInit(StructuredList->getInit(0), T, SemaRef.Context)) {
Douglas Gregor7c53ca62009-02-18 22:23:55 +0000628 unsigned DK = diag::warn_excess_initializers_in_char_array_initializer;
David Blaikie4e4d0842012-03-11 07:00:24 +0000629 if (SemaRef.getLangOpts().CPlusPlus) {
Douglas Gregor7c53ca62009-02-18 22:23:55 +0000630 DK = diag::err_excess_initializers_in_char_array_initializer;
Eli Friedmane5408582009-05-29 20:20:05 +0000631 hadError = true;
632 }
Eli Friedmanbb504d32008-05-19 20:12:18 +0000633 // Special-case
Chris Lattner08202542009-02-24 22:50:46 +0000634 SemaRef.Diag(IList->getInit(Index)->getLocStart(), DK)
Chris Lattnerdcd5ef12008-11-19 05:27:50 +0000635 << IList->getInit(Index)->getSourceRange();
Eli Friedmand8dc2102008-05-20 05:25:56 +0000636 } else if (!T->isIncompleteType()) {
Douglas Gregorb574e562009-01-30 22:26:29 +0000637 // Don't complain for incomplete types, since we'll get an error
638 // elsewhere
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000639 QualType CurrentObjectType = StructuredList->getType();
Mike Stump1eb44332009-09-09 15:08:12 +0000640 int initKind =
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000641 CurrentObjectType->isArrayType()? 0 :
642 CurrentObjectType->isVectorType()? 1 :
643 CurrentObjectType->isScalarType()? 2 :
644 CurrentObjectType->isUnionType()? 3 :
645 4;
Douglas Gregor7c53ca62009-02-18 22:23:55 +0000646
647 unsigned DK = diag::warn_excess_initializers;
David Blaikie4e4d0842012-03-11 07:00:24 +0000648 if (SemaRef.getLangOpts().CPlusPlus) {
Eli Friedmane5408582009-05-29 20:20:05 +0000649 DK = diag::err_excess_initializers;
650 hadError = true;
651 }
David Blaikie4e4d0842012-03-11 07:00:24 +0000652 if (SemaRef.getLangOpts().OpenCL && initKind == 1) {
Nate Begeman08634522009-07-07 21:53:06 +0000653 DK = diag::err_excess_initializers;
654 hadError = true;
655 }
Douglas Gregor7c53ca62009-02-18 22:23:55 +0000656
Chris Lattner08202542009-02-24 22:50:46 +0000657 SemaRef.Diag(IList->getInit(Index)->getLocStart(), DK)
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000658 << initKind << IList->getInit(Index)->getSourceRange();
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000659 }
660 }
Eli Friedmancda25a92008-05-19 20:20:43 +0000661
Sebastian Redl14b0c192011-09-24 17:48:00 +0000662 if (!VerifyOnly && T->isScalarType() && IList->getNumInits() == 1 &&
663 !TopLevelObject)
Chris Lattner08202542009-02-24 22:50:46 +0000664 SemaRef.Diag(IList->getLocStart(), diag::warn_braces_around_scalar_init)
Douglas Gregora3a83512009-04-01 23:51:29 +0000665 << IList->getSourceRange()
Douglas Gregor849b2432010-03-31 17:46:05 +0000666 << FixItHint::CreateRemoval(IList->getLocStart())
667 << FixItHint::CreateRemoval(IList->getLocEnd());
Steve Naroff0cca7492008-05-01 22:18:59 +0000668}
669
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000670void InitListChecker::CheckListElementTypes(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000671 InitListExpr *IList,
Mike Stump1eb44332009-09-09 15:08:12 +0000672 QualType &DeclType,
Douglas Gregor87f55cf2009-01-22 23:26:18 +0000673 bool SubobjectIsDesignatorContext,
Douglas Gregor4c678342009-01-28 21:54:33 +0000674 unsigned &Index,
675 InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +0000676 unsigned &StructuredIndex,
677 bool TopLevelObject) {
Eli Friedman0c706c22011-09-19 23:17:44 +0000678 if (DeclType->isAnyComplexType() && SubobjectIsDesignatorContext) {
679 // Explicitly braced initializer for complex type can be real+imaginary
680 // parts.
681 CheckComplexType(Entity, IList, DeclType, Index,
682 StructuredList, StructuredIndex);
683 } else if (DeclType->isScalarType()) {
Anders Carlsson46f46592010-01-23 19:55:29 +0000684 CheckScalarType(Entity, IList, DeclType, Index,
685 StructuredList, StructuredIndex);
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000686 } else if (DeclType->isVectorType()) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000687 CheckVectorType(Entity, IList, DeclType, Index,
Anders Carlsson46f46592010-01-23 19:55:29 +0000688 StructuredList, StructuredIndex);
Richard Smith20599392012-07-07 08:35:56 +0000689 } else if (DeclType->isRecordType()) {
690 assert(DeclType->isAggregateType() &&
691 "non-aggregate records should be handed in CheckSubElementType");
692 RecordDecl *RD = DeclType->getAs<RecordType>()->getDecl();
693 CheckStructUnionTypes(Entity, IList, DeclType, RD->field_begin(),
694 SubobjectIsDesignatorContext, Index,
695 StructuredList, StructuredIndex,
696 TopLevelObject);
697 } else if (DeclType->isArrayType()) {
698 llvm::APSInt Zero(
699 SemaRef.Context.getTypeSize(SemaRef.Context.getSizeType()),
700 false);
701 CheckArrayType(Entity, IList, DeclType, Zero,
702 SubobjectIsDesignatorContext, Index,
703 StructuredList, StructuredIndex);
Steve Naroff61353522008-08-10 16:05:48 +0000704 } else if (DeclType->isVoidType() || DeclType->isFunctionType()) {
705 // This type is invalid, issue a diagnostic.
Douglas Gregor4c678342009-01-28 21:54:33 +0000706 ++Index;
Sebastian Redl14b0c192011-09-24 17:48:00 +0000707 if (!VerifyOnly)
708 SemaRef.Diag(IList->getLocStart(), diag::err_illegal_initializer_type)
709 << DeclType;
Eli Friedmand8dc2102008-05-20 05:25:56 +0000710 hadError = true;
Douglas Gregor930d8b52009-01-30 22:09:00 +0000711 } else if (DeclType->isReferenceType()) {
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000712 CheckReferenceType(Entity, IList, DeclType, Index,
713 StructuredList, StructuredIndex);
John McCallc12c5bb2010-05-15 11:32:37 +0000714 } else if (DeclType->isObjCObjectType()) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000715 if (!VerifyOnly)
716 SemaRef.Diag(IList->getLocStart(), diag::err_init_objc_class)
717 << DeclType;
Douglas Gregor4d9e7382010-05-03 18:24:37 +0000718 hadError = true;
Steve Naroff0cca7492008-05-01 22:18:59 +0000719 } else {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000720 if (!VerifyOnly)
721 SemaRef.Diag(IList->getLocStart(), diag::err_illegal_initializer_type)
722 << DeclType;
Douglas Gregor4d9e7382010-05-03 18:24:37 +0000723 hadError = true;
Steve Naroff0cca7492008-05-01 22:18:59 +0000724 }
725}
726
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000727void InitListChecker::CheckSubElementType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000728 InitListExpr *IList,
Mike Stump1eb44332009-09-09 15:08:12 +0000729 QualType ElemType,
Douglas Gregor4c678342009-01-28 21:54:33 +0000730 unsigned &Index,
731 InitListExpr *StructuredList,
732 unsigned &StructuredIndex) {
Douglas Gregor6fbdc6b2009-01-29 00:39:20 +0000733 Expr *expr = IList->getInit(Index);
Eli Friedmanc9c0ea62008-05-19 20:00:43 +0000734 if (InitListExpr *SubInitList = dyn_cast<InitListExpr>(expr)) {
Richard Smith20599392012-07-07 08:35:56 +0000735 if (!ElemType->isRecordType() || ElemType->isAggregateType()) {
736 unsigned newIndex = 0;
737 unsigned newStructuredIndex = 0;
738 InitListExpr *newStructuredList
739 = getStructuredSubobjectInit(IList, Index, ElemType,
740 StructuredList, StructuredIndex,
741 SubInitList->getSourceRange());
742 CheckExplicitInitList(Entity, SubInitList, ElemType, newIndex,
743 newStructuredList, newStructuredIndex);
744 ++StructuredIndex;
745 ++Index;
746 return;
747 }
748 assert(SemaRef.getLangOpts().CPlusPlus &&
749 "non-aggregate records are only possible in C++");
750 // C++ initialization is handled later.
751 }
752
753 if (ElemType->isScalarType()) {
John McCallfef8b342011-02-21 07:57:55 +0000754 return CheckScalarType(Entity, IList, ElemType, Index,
755 StructuredList, StructuredIndex);
Douglas Gregor930d8b52009-01-30 22:09:00 +0000756 } else if (ElemType->isReferenceType()) {
John McCallfef8b342011-02-21 07:57:55 +0000757 return CheckReferenceType(Entity, IList, ElemType, Index,
758 StructuredList, StructuredIndex);
759 }
Anders Carlssond28b4282009-08-27 17:18:13 +0000760
John McCallfef8b342011-02-21 07:57:55 +0000761 if (const ArrayType *arrayType = SemaRef.Context.getAsArrayType(ElemType)) {
762 // arrayType can be incomplete if we're initializing a flexible
763 // array member. There's nothing we can do with the completed
764 // type here, though.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000765
John McCallfef8b342011-02-21 07:57:55 +0000766 if (Expr *Str = IsStringInit(expr, arrayType, SemaRef.Context)) {
Eli Friedman8a5d9292011-09-26 19:09:09 +0000767 if (!VerifyOnly) {
768 CheckStringInit(Str, ElemType, arrayType, SemaRef);
769 UpdateStructuredListElement(StructuredList, StructuredIndex, Str);
770 }
Douglas Gregor930d8b52009-01-30 22:09:00 +0000771 ++Index;
John McCallfef8b342011-02-21 07:57:55 +0000772 return;
Douglas Gregor930d8b52009-01-30 22:09:00 +0000773 }
John McCallfef8b342011-02-21 07:57:55 +0000774
775 // Fall through for subaggregate initialization.
776
David Blaikie4e4d0842012-03-11 07:00:24 +0000777 } else if (SemaRef.getLangOpts().CPlusPlus) {
John McCallfef8b342011-02-21 07:57:55 +0000778 // C++ [dcl.init.aggr]p12:
779 // All implicit type conversions (clause 4) are considered when
Sebastian Redl5d3d41d2011-09-24 17:47:39 +0000780 // initializing the aggregate member with an initializer from
John McCallfef8b342011-02-21 07:57:55 +0000781 // an initializer-list. If the initializer can initialize a
782 // member, the member is initialized. [...]
783
784 // FIXME: Better EqualLoc?
785 InitializationKind Kind =
786 InitializationKind::CreateCopy(expr->getLocStart(), SourceLocation());
787 InitializationSequence Seq(SemaRef, Entity, Kind, &expr, 1);
788
789 if (Seq) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000790 if (!VerifyOnly) {
Richard Smithb6f8d282011-12-20 04:00:21 +0000791 ExprResult Result =
792 Seq.Perform(SemaRef, Entity, Kind, MultiExprArg(&expr, 1));
793 if (Result.isInvalid())
794 hadError = true;
John McCallfef8b342011-02-21 07:57:55 +0000795
Sebastian Redl14b0c192011-09-24 17:48:00 +0000796 UpdateStructuredListElement(StructuredList, StructuredIndex,
Richard Smithb6f8d282011-12-20 04:00:21 +0000797 Result.takeAs<Expr>());
Sebastian Redl14b0c192011-09-24 17:48:00 +0000798 }
John McCallfef8b342011-02-21 07:57:55 +0000799 ++Index;
800 return;
801 }
802
803 // Fall through for subaggregate initialization
804 } else {
805 // C99 6.7.8p13:
806 //
807 // The initializer for a structure or union object that has
808 // automatic storage duration shall be either an initializer
809 // list as described below, or a single expression that has
810 // compatible structure or union type. In the latter case, the
811 // initial value of the object, including unnamed members, is
812 // that of the expression.
John Wiegley429bb272011-04-08 18:41:53 +0000813 ExprResult ExprRes = SemaRef.Owned(expr);
John McCallfef8b342011-02-21 07:57:55 +0000814 if ((ElemType->isRecordType() || ElemType->isVectorType()) &&
Sebastian Redl14b0c192011-09-24 17:48:00 +0000815 SemaRef.CheckSingleAssignmentConstraints(ElemType, ExprRes,
816 !VerifyOnly)
John McCallfef8b342011-02-21 07:57:55 +0000817 == Sema::Compatible) {
John Wiegley429bb272011-04-08 18:41:53 +0000818 if (ExprRes.isInvalid())
819 hadError = true;
820 else {
821 ExprRes = SemaRef.DefaultFunctionArrayLvalueConversion(ExprRes.take());
822 if (ExprRes.isInvalid())
823 hadError = true;
824 }
825 UpdateStructuredListElement(StructuredList, StructuredIndex,
826 ExprRes.takeAs<Expr>());
John McCallfef8b342011-02-21 07:57:55 +0000827 ++Index;
828 return;
829 }
John Wiegley429bb272011-04-08 18:41:53 +0000830 ExprRes.release();
John McCallfef8b342011-02-21 07:57:55 +0000831 // Fall through for subaggregate initialization
832 }
833
834 // C++ [dcl.init.aggr]p12:
835 //
836 // [...] Otherwise, if the member is itself a non-empty
837 // subaggregate, brace elision is assumed and the initializer is
838 // considered for the initialization of the first member of
839 // the subaggregate.
David Blaikie4e4d0842012-03-11 07:00:24 +0000840 if (!SemaRef.getLangOpts().OpenCL &&
Tanya Lattner61b4bc82011-07-15 23:07:01 +0000841 (ElemType->isAggregateType() || ElemType->isVectorType())) {
John McCallfef8b342011-02-21 07:57:55 +0000842 CheckImplicitInitList(Entity, IList, ElemType, Index, StructuredList,
843 StructuredIndex);
844 ++StructuredIndex;
845 } else {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000846 if (!VerifyOnly) {
847 // We cannot initialize this element, so let
848 // PerformCopyInitialization produce the appropriate diagnostic.
849 SemaRef.PerformCopyInitialization(Entity, SourceLocation(),
850 SemaRef.Owned(expr),
851 /*TopLevelOfInitList=*/true);
852 }
John McCallfef8b342011-02-21 07:57:55 +0000853 hadError = true;
854 ++Index;
855 ++StructuredIndex;
Douglas Gregor930d8b52009-01-30 22:09:00 +0000856 }
Eli Friedmanb85f7072008-05-19 19:16:24 +0000857}
858
Eli Friedman0c706c22011-09-19 23:17:44 +0000859void InitListChecker::CheckComplexType(const InitializedEntity &Entity,
860 InitListExpr *IList, QualType DeclType,
861 unsigned &Index,
862 InitListExpr *StructuredList,
863 unsigned &StructuredIndex) {
864 assert(Index == 0 && "Index in explicit init list must be zero");
865
866 // As an extension, clang supports complex initializers, which initialize
867 // a complex number component-wise. When an explicit initializer list for
868 // a complex number contains two two initializers, this extension kicks in:
869 // it exepcts the initializer list to contain two elements convertible to
870 // the element type of the complex type. The first element initializes
871 // the real part, and the second element intitializes the imaginary part.
872
873 if (IList->getNumInits() != 2)
874 return CheckScalarType(Entity, IList, DeclType, Index, StructuredList,
875 StructuredIndex);
876
877 // This is an extension in C. (The builtin _Complex type does not exist
878 // in the C++ standard.)
David Blaikie4e4d0842012-03-11 07:00:24 +0000879 if (!SemaRef.getLangOpts().CPlusPlus && !VerifyOnly)
Eli Friedman0c706c22011-09-19 23:17:44 +0000880 SemaRef.Diag(IList->getLocStart(), diag::ext_complex_component_init)
881 << IList->getSourceRange();
882
883 // Initialize the complex number.
884 QualType elementType = DeclType->getAs<ComplexType>()->getElementType();
885 InitializedEntity ElementEntity =
886 InitializedEntity::InitializeElement(SemaRef.Context, 0, Entity);
887
888 for (unsigned i = 0; i < 2; ++i) {
889 ElementEntity.setElementIndex(Index);
890 CheckSubElementType(ElementEntity, IList, elementType, Index,
891 StructuredList, StructuredIndex);
892 }
893}
894
895
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000896void InitListChecker::CheckScalarType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +0000897 InitListExpr *IList, QualType DeclType,
Douglas Gregor6fbdc6b2009-01-29 00:39:20 +0000898 unsigned &Index,
Douglas Gregor4c678342009-01-28 21:54:33 +0000899 InitListExpr *StructuredList,
900 unsigned &StructuredIndex) {
John McCallb934c2d2010-11-11 00:46:36 +0000901 if (Index >= IList->getNumInits()) {
Richard Smith6b130222011-10-18 21:39:00 +0000902 if (!VerifyOnly)
903 SemaRef.Diag(IList->getLocStart(),
David Blaikie4e4d0842012-03-11 07:00:24 +0000904 SemaRef.getLangOpts().CPlusPlus0x ?
Richard Smith6b130222011-10-18 21:39:00 +0000905 diag::warn_cxx98_compat_empty_scalar_initializer :
906 diag::err_empty_scalar_initializer)
907 << IList->getSourceRange();
David Blaikie4e4d0842012-03-11 07:00:24 +0000908 hadError = !SemaRef.getLangOpts().CPlusPlus0x;
Douglas Gregor4c678342009-01-28 21:54:33 +0000909 ++Index;
910 ++StructuredIndex;
Eli Friedmanbb504d32008-05-19 20:12:18 +0000911 return;
Steve Naroff0cca7492008-05-01 22:18:59 +0000912 }
John McCallb934c2d2010-11-11 00:46:36 +0000913
914 Expr *expr = IList->getInit(Index);
915 if (InitListExpr *SubIList = dyn_cast<InitListExpr>(expr)) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000916 if (!VerifyOnly)
917 SemaRef.Diag(SubIList->getLocStart(),
918 diag::warn_many_braces_around_scalar_init)
919 << SubIList->getSourceRange();
John McCallb934c2d2010-11-11 00:46:36 +0000920
921 CheckScalarType(Entity, SubIList, DeclType, Index, StructuredList,
922 StructuredIndex);
923 return;
924 } else if (isa<DesignatedInitExpr>(expr)) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000925 if (!VerifyOnly)
Daniel Dunbar96a00142012-03-09 18:35:03 +0000926 SemaRef.Diag(expr->getLocStart(),
Sebastian Redl14b0c192011-09-24 17:48:00 +0000927 diag::err_designator_for_scalar_init)
928 << DeclType << expr->getSourceRange();
John McCallb934c2d2010-11-11 00:46:36 +0000929 hadError = true;
930 ++Index;
931 ++StructuredIndex;
932 return;
933 }
934
Sebastian Redl14b0c192011-09-24 17:48:00 +0000935 if (VerifyOnly) {
936 if (!SemaRef.CanPerformCopyInitialization(Entity, SemaRef.Owned(expr)))
937 hadError = true;
938 ++Index;
939 return;
940 }
941
John McCallb934c2d2010-11-11 00:46:36 +0000942 ExprResult Result =
943 SemaRef.PerformCopyInitialization(Entity, expr->getLocStart(),
Jeffrey Yasskin19159132011-07-26 23:20:30 +0000944 SemaRef.Owned(expr),
945 /*TopLevelOfInitList=*/true);
John McCallb934c2d2010-11-11 00:46:36 +0000946
947 Expr *ResultExpr = 0;
948
949 if (Result.isInvalid())
950 hadError = true; // types weren't compatible.
951 else {
952 ResultExpr = Result.takeAs<Expr>();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +0000953
John McCallb934c2d2010-11-11 00:46:36 +0000954 if (ResultExpr != expr) {
955 // The type was promoted, update initializer list.
956 IList->setInit(Index, ResultExpr);
957 }
958 }
959 if (hadError)
960 ++StructuredIndex;
961 else
962 UpdateStructuredListElement(StructuredList, StructuredIndex, ResultExpr);
963 ++Index;
Steve Naroff0cca7492008-05-01 22:18:59 +0000964}
965
Anders Carlsson8ff9e862010-01-23 23:23:01 +0000966void InitListChecker::CheckReferenceType(const InitializedEntity &Entity,
967 InitListExpr *IList, QualType DeclType,
Douglas Gregor930d8b52009-01-30 22:09:00 +0000968 unsigned &Index,
969 InitListExpr *StructuredList,
970 unsigned &StructuredIndex) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000971 if (Index >= IList->getNumInits()) {
Mike Stump390b4cc2009-05-16 07:39:55 +0000972 // FIXME: It would be wonderful if we could point at the actual member. In
973 // general, it would be useful to pass location information down the stack,
974 // so that we know the location (or decl) of the "current object" being
975 // initialized.
Sebastian Redl14b0c192011-09-24 17:48:00 +0000976 if (!VerifyOnly)
977 SemaRef.Diag(IList->getLocStart(),
978 diag::err_init_reference_member_uninitialized)
979 << DeclType
980 << IList->getSourceRange();
Douglas Gregor930d8b52009-01-30 22:09:00 +0000981 hadError = true;
982 ++Index;
983 ++StructuredIndex;
984 return;
985 }
Sebastian Redl14b0c192011-09-24 17:48:00 +0000986
987 Expr *expr = IList->getInit(Index);
David Blaikie4e4d0842012-03-11 07:00:24 +0000988 if (isa<InitListExpr>(expr) && !SemaRef.getLangOpts().CPlusPlus0x) {
Sebastian Redl14b0c192011-09-24 17:48:00 +0000989 if (!VerifyOnly)
990 SemaRef.Diag(IList->getLocStart(), diag::err_init_non_aggr_init_list)
991 << DeclType << IList->getSourceRange();
992 hadError = true;
993 ++Index;
994 ++StructuredIndex;
995 return;
996 }
997
998 if (VerifyOnly) {
999 if (!SemaRef.CanPerformCopyInitialization(Entity, SemaRef.Owned(expr)))
1000 hadError = true;
1001 ++Index;
1002 return;
1003 }
1004
1005 ExprResult Result =
1006 SemaRef.PerformCopyInitialization(Entity, expr->getLocStart(),
1007 SemaRef.Owned(expr),
1008 /*TopLevelOfInitList=*/true);
1009
1010 if (Result.isInvalid())
1011 hadError = true;
1012
1013 expr = Result.takeAs<Expr>();
1014 IList->setInit(Index, expr);
1015
1016 if (hadError)
1017 ++StructuredIndex;
1018 else
1019 UpdateStructuredListElement(StructuredList, StructuredIndex, expr);
1020 ++Index;
Douglas Gregor930d8b52009-01-30 22:09:00 +00001021}
1022
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001023void InitListChecker::CheckVectorType(const InitializedEntity &Entity,
Anders Carlsson46f46592010-01-23 19:55:29 +00001024 InitListExpr *IList, QualType DeclType,
Douglas Gregor4c678342009-01-28 21:54:33 +00001025 unsigned &Index,
1026 InitListExpr *StructuredList,
1027 unsigned &StructuredIndex) {
John McCall20e047a2010-10-30 00:11:39 +00001028 const VectorType *VT = DeclType->getAs<VectorType>();
1029 unsigned maxElements = VT->getNumElements();
1030 unsigned numEltsInit = 0;
1031 QualType elementType = VT->getElementType();
Anders Carlsson46f46592010-01-23 19:55:29 +00001032
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001033 if (Index >= IList->getNumInits()) {
1034 // Make sure the element type can be value-initialized.
1035 if (VerifyOnly)
1036 CheckValueInitializable(
1037 InitializedEntity::InitializeElement(SemaRef.Context, 0, Entity));
1038 return;
1039 }
1040
David Blaikie4e4d0842012-03-11 07:00:24 +00001041 if (!SemaRef.getLangOpts().OpenCL) {
John McCall20e047a2010-10-30 00:11:39 +00001042 // If the initializing element is a vector, try to copy-initialize
1043 // instead of breaking it apart (which is doomed to failure anyway).
1044 Expr *Init = IList->getInit(Index);
1045 if (!isa<InitListExpr>(Init) && Init->getType()->isVectorType()) {
Sebastian Redl14b0c192011-09-24 17:48:00 +00001046 if (VerifyOnly) {
1047 if (!SemaRef.CanPerformCopyInitialization(Entity, SemaRef.Owned(Init)))
1048 hadError = true;
1049 ++Index;
1050 return;
1051 }
1052
John McCall20e047a2010-10-30 00:11:39 +00001053 ExprResult Result =
1054 SemaRef.PerformCopyInitialization(Entity, Init->getLocStart(),
Jeffrey Yasskin19159132011-07-26 23:20:30 +00001055 SemaRef.Owned(Init),
1056 /*TopLevelOfInitList=*/true);
John McCall20e047a2010-10-30 00:11:39 +00001057
1058 Expr *ResultExpr = 0;
1059 if (Result.isInvalid())
1060 hadError = true; // types weren't compatible.
1061 else {
1062 ResultExpr = Result.takeAs<Expr>();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001063
John McCall20e047a2010-10-30 00:11:39 +00001064 if (ResultExpr != Init) {
1065 // The type was promoted, update initializer list.
1066 IList->setInit(Index, ResultExpr);
Nate Begeman2ef13e52009-08-10 23:49:36 +00001067 }
1068 }
John McCall20e047a2010-10-30 00:11:39 +00001069 if (hadError)
1070 ++StructuredIndex;
1071 else
Sebastian Redl14b0c192011-09-24 17:48:00 +00001072 UpdateStructuredListElement(StructuredList, StructuredIndex,
1073 ResultExpr);
John McCall20e047a2010-10-30 00:11:39 +00001074 ++Index;
1075 return;
Steve Naroff0cca7492008-05-01 22:18:59 +00001076 }
Mike Stump1eb44332009-09-09 15:08:12 +00001077
John McCall20e047a2010-10-30 00:11:39 +00001078 InitializedEntity ElementEntity =
1079 InitializedEntity::InitializeElement(SemaRef.Context, 0, Entity);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001080
John McCall20e047a2010-10-30 00:11:39 +00001081 for (unsigned i = 0; i < maxElements; ++i, ++numEltsInit) {
1082 // Don't attempt to go past the end of the init list
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001083 if (Index >= IList->getNumInits()) {
1084 if (VerifyOnly)
1085 CheckValueInitializable(ElementEntity);
John McCall20e047a2010-10-30 00:11:39 +00001086 break;
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001087 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001088
John McCall20e047a2010-10-30 00:11:39 +00001089 ElementEntity.setElementIndex(Index);
1090 CheckSubElementType(ElementEntity, IList, elementType, Index,
1091 StructuredList, StructuredIndex);
1092 }
1093 return;
Steve Naroff0cca7492008-05-01 22:18:59 +00001094 }
John McCall20e047a2010-10-30 00:11:39 +00001095
1096 InitializedEntity ElementEntity =
1097 InitializedEntity::InitializeElement(SemaRef.Context, 0, Entity);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001098
John McCall20e047a2010-10-30 00:11:39 +00001099 // OpenCL initializers allows vectors to be constructed from vectors.
1100 for (unsigned i = 0; i < maxElements; ++i) {
1101 // Don't attempt to go past the end of the init list
1102 if (Index >= IList->getNumInits())
1103 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001104
John McCall20e047a2010-10-30 00:11:39 +00001105 ElementEntity.setElementIndex(Index);
1106
1107 QualType IType = IList->getInit(Index)->getType();
1108 if (!IType->isVectorType()) {
1109 CheckSubElementType(ElementEntity, IList, elementType, Index,
1110 StructuredList, StructuredIndex);
1111 ++numEltsInit;
1112 } else {
1113 QualType VecType;
1114 const VectorType *IVT = IType->getAs<VectorType>();
1115 unsigned numIElts = IVT->getNumElements();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001116
John McCall20e047a2010-10-30 00:11:39 +00001117 if (IType->isExtVectorType())
1118 VecType = SemaRef.Context.getExtVectorType(elementType, numIElts);
1119 else
1120 VecType = SemaRef.Context.getVectorType(elementType, numIElts,
Bob Wilsone86d78c2010-11-10 21:56:12 +00001121 IVT->getVectorKind());
John McCall20e047a2010-10-30 00:11:39 +00001122 CheckSubElementType(ElementEntity, IList, VecType, Index,
1123 StructuredList, StructuredIndex);
1124 numEltsInit += numIElts;
1125 }
1126 }
1127
1128 // OpenCL requires all elements to be initialized.
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001129 if (numEltsInit != maxElements) {
1130 if (!VerifyOnly)
Daniel Dunbar96a00142012-03-09 18:35:03 +00001131 SemaRef.Diag(IList->getLocStart(),
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001132 diag::err_vector_incorrect_num_initializers)
1133 << (numEltsInit < maxElements) << maxElements << numEltsInit;
1134 hadError = true;
1135 }
Steve Naroff0cca7492008-05-01 22:18:59 +00001136}
1137
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001138void InitListChecker::CheckArrayType(const InitializedEntity &Entity,
Anders Carlsson784f6992010-01-23 20:13:41 +00001139 InitListExpr *IList, QualType &DeclType,
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001140 llvm::APSInt elementIndex,
Mike Stump1eb44332009-09-09 15:08:12 +00001141 bool SubobjectIsDesignatorContext,
Douglas Gregor4c678342009-01-28 21:54:33 +00001142 unsigned &Index,
1143 InitListExpr *StructuredList,
1144 unsigned &StructuredIndex) {
John McCallce6c9b72011-02-21 07:22:22 +00001145 const ArrayType *arrayType = SemaRef.Context.getAsArrayType(DeclType);
1146
Steve Naroff0cca7492008-05-01 22:18:59 +00001147 // Check for the special-case of initializing an array with a string.
1148 if (Index < IList->getNumInits()) {
John McCallce6c9b72011-02-21 07:22:22 +00001149 if (Expr *Str = IsStringInit(IList->getInit(Index), arrayType,
Chris Lattner79e079d2009-02-24 23:10:27 +00001150 SemaRef.Context)) {
Douglas Gregor4c678342009-01-28 21:54:33 +00001151 // We place the string literal directly into the resulting
1152 // initializer list. This is the only place where the structure
1153 // of the structured initializer list doesn't match exactly,
1154 // because doing so would involve allocating one character
1155 // constant for each string.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001156 if (!VerifyOnly) {
Eli Friedman8a5d9292011-09-26 19:09:09 +00001157 CheckStringInit(Str, DeclType, arrayType, SemaRef);
Sebastian Redl14b0c192011-09-24 17:48:00 +00001158 UpdateStructuredListElement(StructuredList, StructuredIndex, Str);
1159 StructuredList->resizeInits(SemaRef.Context, StructuredIndex);
1160 }
Steve Naroff0cca7492008-05-01 22:18:59 +00001161 ++Index;
Steve Naroff0cca7492008-05-01 22:18:59 +00001162 return;
1163 }
1164 }
John McCallce6c9b72011-02-21 07:22:22 +00001165 if (const VariableArrayType *VAT = dyn_cast<VariableArrayType>(arrayType)) {
Eli Friedman638e1442008-05-25 13:22:35 +00001166 // Check for VLAs; in standard C it would be possible to check this
1167 // earlier, but I don't know where clang accepts VLAs (gcc accepts
1168 // them in all sorts of strange places).
Sebastian Redl14b0c192011-09-24 17:48:00 +00001169 if (!VerifyOnly)
1170 SemaRef.Diag(VAT->getSizeExpr()->getLocStart(),
1171 diag::err_variable_object_no_init)
1172 << VAT->getSizeExpr()->getSourceRange();
Eli Friedman638e1442008-05-25 13:22:35 +00001173 hadError = true;
Douglas Gregor4c678342009-01-28 21:54:33 +00001174 ++Index;
1175 ++StructuredIndex;
Eli Friedman638e1442008-05-25 13:22:35 +00001176 return;
1177 }
1178
Douglas Gregor05c13a32009-01-22 00:58:24 +00001179 // We might know the maximum number of elements in advance.
Douglas Gregor4c678342009-01-28 21:54:33 +00001180 llvm::APSInt maxElements(elementIndex.getBitWidth(),
1181 elementIndex.isUnsigned());
Douglas Gregor05c13a32009-01-22 00:58:24 +00001182 bool maxElementsKnown = false;
John McCallce6c9b72011-02-21 07:22:22 +00001183 if (const ConstantArrayType *CAT = dyn_cast<ConstantArrayType>(arrayType)) {
Douglas Gregor05c13a32009-01-22 00:58:24 +00001184 maxElements = CAT->getSize();
Jay Foad9f71a8f2010-12-07 08:25:34 +00001185 elementIndex = elementIndex.extOrTrunc(maxElements.getBitWidth());
Douglas Gregore3fa2de2009-01-23 18:58:42 +00001186 elementIndex.setIsUnsigned(maxElements.isUnsigned());
Douglas Gregor05c13a32009-01-22 00:58:24 +00001187 maxElementsKnown = true;
1188 }
1189
John McCallce6c9b72011-02-21 07:22:22 +00001190 QualType elementType = arrayType->getElementType();
Douglas Gregor05c13a32009-01-22 00:58:24 +00001191 while (Index < IList->getNumInits()) {
1192 Expr *Init = IList->getInit(Index);
1193 if (DesignatedInitExpr *DIE = dyn_cast<DesignatedInitExpr>(Init)) {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001194 // If we're not the subobject that matches up with the '{' for
1195 // the designator, we shouldn't be handling the
1196 // designator. Return immediately.
1197 if (!SubobjectIsDesignatorContext)
1198 return;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001199
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001200 // Handle this designated initializer. elementIndex will be
1201 // updated to be the next array element we'll initialize.
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001202 if (CheckDesignatedInitializer(Entity, IList, DIE, 0,
Douglas Gregor4c678342009-01-28 21:54:33 +00001203 DeclType, 0, &elementIndex, Index,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001204 StructuredList, StructuredIndex, true,
1205 false)) {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001206 hadError = true;
1207 continue;
1208 }
1209
Douglas Gregorf6c717c2009-01-23 16:54:12 +00001210 if (elementIndex.getBitWidth() > maxElements.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00001211 maxElements = maxElements.extend(elementIndex.getBitWidth());
Douglas Gregorf6c717c2009-01-23 16:54:12 +00001212 else if (elementIndex.getBitWidth() < maxElements.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00001213 elementIndex = elementIndex.extend(maxElements.getBitWidth());
Douglas Gregore3fa2de2009-01-23 18:58:42 +00001214 elementIndex.setIsUnsigned(maxElements.isUnsigned());
Douglas Gregorf6c717c2009-01-23 16:54:12 +00001215
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001216 // If the array is of incomplete type, keep track of the number of
1217 // elements in the initializer.
1218 if (!maxElementsKnown && elementIndex > maxElements)
1219 maxElements = elementIndex;
1220
Douglas Gregor05c13a32009-01-22 00:58:24 +00001221 continue;
1222 }
1223
1224 // If we know the maximum number of elements, and we've already
1225 // hit it, stop consuming elements in the initializer list.
1226 if (maxElementsKnown && elementIndex == maxElements)
Steve Naroff0cca7492008-05-01 22:18:59 +00001227 break;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001228
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001229 InitializedEntity ElementEntity =
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001230 InitializedEntity::InitializeElement(SemaRef.Context, StructuredIndex,
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001231 Entity);
1232 // Check this element.
1233 CheckSubElementType(ElementEntity, IList, elementType, Index,
1234 StructuredList, StructuredIndex);
Douglas Gregor05c13a32009-01-22 00:58:24 +00001235 ++elementIndex;
1236
1237 // If the array is of incomplete type, keep track of the number of
1238 // elements in the initializer.
1239 if (!maxElementsKnown && elementIndex > maxElements)
1240 maxElements = elementIndex;
Steve Naroff0cca7492008-05-01 22:18:59 +00001241 }
Sebastian Redl14b0c192011-09-24 17:48:00 +00001242 if (!hadError && DeclType->isIncompleteArrayType() && !VerifyOnly) {
Steve Naroff0cca7492008-05-01 22:18:59 +00001243 // If this is an incomplete array type, the actual type needs to
Daniel Dunbar396f0bf2008-08-18 20:28:46 +00001244 // be calculated here.
Douglas Gregore3fa2de2009-01-23 18:58:42 +00001245 llvm::APSInt Zero(maxElements.getBitWidth(), maxElements.isUnsigned());
Douglas Gregor05c13a32009-01-22 00:58:24 +00001246 if (maxElements == Zero) {
Daniel Dunbar396f0bf2008-08-18 20:28:46 +00001247 // Sizing an array implicitly to zero is not allowed by ISO C,
1248 // but is supported by GNU.
Chris Lattner08202542009-02-24 22:50:46 +00001249 SemaRef.Diag(IList->getLocStart(),
Daniel Dunbar396f0bf2008-08-18 20:28:46 +00001250 diag::ext_typecheck_zero_array_size);
Steve Naroff0cca7492008-05-01 22:18:59 +00001251 }
Daniel Dunbar396f0bf2008-08-18 20:28:46 +00001252
Mike Stump1eb44332009-09-09 15:08:12 +00001253 DeclType = SemaRef.Context.getConstantArrayType(elementType, maxElements,
Daniel Dunbar396f0bf2008-08-18 20:28:46 +00001254 ArrayType::Normal, 0);
Steve Naroff0cca7492008-05-01 22:18:59 +00001255 }
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001256 if (!hadError && VerifyOnly) {
1257 // Check if there are any members of the array that get value-initialized.
1258 // If so, check if doing that is possible.
1259 // FIXME: This needs to detect holes left by designated initializers too.
1260 if (maxElementsKnown && elementIndex < maxElements)
1261 CheckValueInitializable(InitializedEntity::InitializeElement(
1262 SemaRef.Context, 0, Entity));
1263 }
Steve Naroff0cca7492008-05-01 22:18:59 +00001264}
1265
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001266bool InitListChecker::CheckFlexibleArrayInit(const InitializedEntity &Entity,
1267 Expr *InitExpr,
1268 FieldDecl *Field,
1269 bool TopLevelObject) {
1270 // Handle GNU flexible array initializers.
1271 unsigned FlexArrayDiag;
1272 if (isa<InitListExpr>(InitExpr) &&
1273 cast<InitListExpr>(InitExpr)->getNumInits() == 0) {
1274 // Empty flexible array init always allowed as an extension
1275 FlexArrayDiag = diag::ext_flexible_array_init;
David Blaikie4e4d0842012-03-11 07:00:24 +00001276 } else if (SemaRef.getLangOpts().CPlusPlus) {
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001277 // Disallow flexible array init in C++; it is not required for gcc
1278 // compatibility, and it needs work to IRGen correctly in general.
1279 FlexArrayDiag = diag::err_flexible_array_init;
1280 } else if (!TopLevelObject) {
1281 // Disallow flexible array init on non-top-level object
1282 FlexArrayDiag = diag::err_flexible_array_init;
1283 } else if (Entity.getKind() != InitializedEntity::EK_Variable) {
1284 // Disallow flexible array init on anything which is not a variable.
1285 FlexArrayDiag = diag::err_flexible_array_init;
1286 } else if (cast<VarDecl>(Entity.getDecl())->hasLocalStorage()) {
1287 // Disallow flexible array init on local variables.
1288 FlexArrayDiag = diag::err_flexible_array_init;
1289 } else {
1290 // Allow other cases.
1291 FlexArrayDiag = diag::ext_flexible_array_init;
1292 }
Sebastian Redl14b0c192011-09-24 17:48:00 +00001293
1294 if (!VerifyOnly) {
Daniel Dunbar96a00142012-03-09 18:35:03 +00001295 SemaRef.Diag(InitExpr->getLocStart(),
Sebastian Redl14b0c192011-09-24 17:48:00 +00001296 FlexArrayDiag)
Daniel Dunbar96a00142012-03-09 18:35:03 +00001297 << InitExpr->getLocStart();
Sebastian Redl14b0c192011-09-24 17:48:00 +00001298 SemaRef.Diag(Field->getLocation(), diag::note_flexible_array_member)
1299 << Field;
1300 }
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001301
1302 return FlexArrayDiag != diag::ext_flexible_array_init;
1303}
1304
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001305void InitListChecker::CheckStructUnionTypes(const InitializedEntity &Entity,
Anders Carlsson2bbae5d2010-01-23 20:20:40 +00001306 InitListExpr *IList,
Mike Stump1eb44332009-09-09 15:08:12 +00001307 QualType DeclType,
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001308 RecordDecl::field_iterator Field,
Mike Stump1eb44332009-09-09 15:08:12 +00001309 bool SubobjectIsDesignatorContext,
Douglas Gregor4c678342009-01-28 21:54:33 +00001310 unsigned &Index,
1311 InitListExpr *StructuredList,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001312 unsigned &StructuredIndex,
1313 bool TopLevelObject) {
Ted Kremenek6217b802009-07-29 21:53:49 +00001314 RecordDecl* structDecl = DeclType->getAs<RecordType>()->getDecl();
Mike Stump1eb44332009-09-09 15:08:12 +00001315
Eli Friedmanb85f7072008-05-19 19:16:24 +00001316 // If the record is invalid, some of it's members are invalid. To avoid
1317 // confusion, we forgo checking the intializer for the entire record.
1318 if (structDecl->isInvalidDecl()) {
1319 hadError = true;
1320 return;
Mike Stump1eb44332009-09-09 15:08:12 +00001321 }
Douglas Gregor3498bdb2009-01-29 17:44:32 +00001322
1323 if (DeclType->isUnionType() && IList->getNumInits() == 0) {
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001324 // Value-initialize the first named member of the union.
1325 RecordDecl *RD = DeclType->getAs<RecordType>()->getDecl();
1326 for (RecordDecl::field_iterator FieldEnd = RD->field_end();
1327 Field != FieldEnd; ++Field) {
1328 if (Field->getDeclName()) {
1329 if (VerifyOnly)
1330 CheckValueInitializable(
David Blaikie581deb32012-06-06 20:45:41 +00001331 InitializedEntity::InitializeMember(*Field, &Entity));
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001332 else
David Blaikie581deb32012-06-06 20:45:41 +00001333 StructuredList->setInitializedFieldInUnion(*Field);
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001334 break;
Douglas Gregor3498bdb2009-01-29 17:44:32 +00001335 }
1336 }
1337 return;
1338 }
1339
Douglas Gregor05c13a32009-01-22 00:58:24 +00001340 // If structDecl is a forward declaration, this loop won't do
1341 // anything except look at designated initializers; That's okay,
1342 // because an error should get printed out elsewhere. It might be
1343 // worthwhile to skip over the rest of the initializer, though.
Ted Kremenek6217b802009-07-29 21:53:49 +00001344 RecordDecl *RD = DeclType->getAs<RecordType>()->getDecl();
Argyrios Kyrtzidis17945a02009-06-30 02:36:12 +00001345 RecordDecl::field_iterator FieldEnd = RD->field_end();
Douglas Gregordfb5e592009-02-12 19:00:39 +00001346 bool InitializedSomething = false;
John McCall80639de2010-03-11 19:32:38 +00001347 bool CheckForMissingFields = true;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001348 while (Index < IList->getNumInits()) {
1349 Expr *Init = IList->getInit(Index);
1350
1351 if (DesignatedInitExpr *DIE = dyn_cast<DesignatedInitExpr>(Init)) {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001352 // If we're not the subobject that matches up with the '{' for
1353 // the designator, we shouldn't be handling the
1354 // designator. Return immediately.
1355 if (!SubobjectIsDesignatorContext)
1356 return;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001357
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001358 // Handle this designated initializer. Field will be updated to
1359 // the next field that we'll be initializing.
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001360 if (CheckDesignatedInitializer(Entity, IList, DIE, 0,
Douglas Gregor4c678342009-01-28 21:54:33 +00001361 DeclType, &Field, 0, Index,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001362 StructuredList, StructuredIndex,
1363 true, TopLevelObject))
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001364 hadError = true;
1365
Douglas Gregordfb5e592009-02-12 19:00:39 +00001366 InitializedSomething = true;
John McCall80639de2010-03-11 19:32:38 +00001367
1368 // Disable check for missing fields when designators are used.
1369 // This matches gcc behaviour.
1370 CheckForMissingFields = false;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001371 continue;
1372 }
1373
1374 if (Field == FieldEnd) {
1375 // We've run out of fields. We're done.
1376 break;
1377 }
1378
Douglas Gregordfb5e592009-02-12 19:00:39 +00001379 // We've already initialized a member of a union. We're done.
1380 if (InitializedSomething && DeclType->isUnionType())
1381 break;
1382
Douglas Gregor44b43212008-12-11 16:49:14 +00001383 // If we've hit the flexible array member at the end, we're done.
1384 if (Field->getType()->isIncompleteArrayType())
1385 break;
1386
Douglas Gregor0bb76892009-01-29 16:53:55 +00001387 if (Field->isUnnamedBitfield()) {
Douglas Gregor4c678342009-01-28 21:54:33 +00001388 // Don't initialize unnamed bitfields, e.g. "int : 20;"
Douglas Gregor05c13a32009-01-22 00:58:24 +00001389 ++Field;
Eli Friedmanb85f7072008-05-19 19:16:24 +00001390 continue;
Steve Naroff0cca7492008-05-01 22:18:59 +00001391 }
Douglas Gregor44b43212008-12-11 16:49:14 +00001392
Douglas Gregor54001c12011-06-29 21:51:31 +00001393 // Make sure we can use this declaration.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001394 bool InvalidUse;
1395 if (VerifyOnly)
David Blaikie581deb32012-06-06 20:45:41 +00001396 InvalidUse = !SemaRef.CanUseDecl(*Field);
Sebastian Redl14b0c192011-09-24 17:48:00 +00001397 else
David Blaikie581deb32012-06-06 20:45:41 +00001398 InvalidUse = SemaRef.DiagnoseUseOfDecl(*Field,
Sebastian Redl14b0c192011-09-24 17:48:00 +00001399 IList->getInit(Index)->getLocStart());
1400 if (InvalidUse) {
Douglas Gregor54001c12011-06-29 21:51:31 +00001401 ++Index;
1402 ++Field;
1403 hadError = true;
1404 continue;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001405 }
Douglas Gregor54001c12011-06-29 21:51:31 +00001406
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001407 InitializedEntity MemberEntity =
David Blaikie581deb32012-06-06 20:45:41 +00001408 InitializedEntity::InitializeMember(*Field, &Entity);
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001409 CheckSubElementType(MemberEntity, IList, Field->getType(), Index,
1410 StructuredList, StructuredIndex);
Douglas Gregordfb5e592009-02-12 19:00:39 +00001411 InitializedSomething = true;
Douglas Gregor0bb76892009-01-29 16:53:55 +00001412
Sebastian Redl14b0c192011-09-24 17:48:00 +00001413 if (DeclType->isUnionType() && !VerifyOnly) {
Douglas Gregor0bb76892009-01-29 16:53:55 +00001414 // Initialize the first field within the union.
David Blaikie581deb32012-06-06 20:45:41 +00001415 StructuredList->setInitializedFieldInUnion(*Field);
Douglas Gregor0bb76892009-01-29 16:53:55 +00001416 }
Douglas Gregor05c13a32009-01-22 00:58:24 +00001417
1418 ++Field;
Steve Naroff0cca7492008-05-01 22:18:59 +00001419 }
Douglas Gregor44b43212008-12-11 16:49:14 +00001420
John McCall80639de2010-03-11 19:32:38 +00001421 // Emit warnings for missing struct field initializers.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001422 if (!VerifyOnly && InitializedSomething && CheckForMissingFields &&
1423 Field != FieldEnd && !Field->getType()->isIncompleteArrayType() &&
1424 !DeclType->isUnionType()) {
John McCall80639de2010-03-11 19:32:38 +00001425 // It is possible we have one or more unnamed bitfields remaining.
1426 // Find first (if any) named field and emit warning.
1427 for (RecordDecl::field_iterator it = Field, end = RD->field_end();
1428 it != end; ++it) {
1429 if (!it->isUnnamedBitfield()) {
1430 SemaRef.Diag(IList->getSourceRange().getEnd(),
1431 diag::warn_missing_field_initializers) << it->getName();
1432 break;
1433 }
1434 }
1435 }
1436
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001437 // Check that any remaining fields can be value-initialized.
1438 if (VerifyOnly && Field != FieldEnd && !DeclType->isUnionType() &&
1439 !Field->getType()->isIncompleteArrayType()) {
1440 // FIXME: Should check for holes left by designated initializers too.
1441 for (; Field != FieldEnd && !hadError; ++Field) {
1442 if (!Field->isUnnamedBitfield())
1443 CheckValueInitializable(
David Blaikie581deb32012-06-06 20:45:41 +00001444 InitializedEntity::InitializeMember(*Field, &Entity));
Sebastian Redl3ff5c862011-10-16 18:19:20 +00001445 }
1446 }
1447
Mike Stump1eb44332009-09-09 15:08:12 +00001448 if (Field == FieldEnd || !Field->getType()->isIncompleteArrayType() ||
Douglas Gregora6457962009-03-20 00:32:56 +00001449 Index >= IList->getNumInits())
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001450 return;
1451
David Blaikie581deb32012-06-06 20:45:41 +00001452 if (CheckFlexibleArrayInit(Entity, IList->getInit(Index), *Field,
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001453 TopLevelObject)) {
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001454 hadError = true;
Douglas Gregora6457962009-03-20 00:32:56 +00001455 ++Index;
1456 return;
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001457 }
1458
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001459 InitializedEntity MemberEntity =
David Blaikie581deb32012-06-06 20:45:41 +00001460 InitializedEntity::InitializeMember(*Field, &Entity);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001461
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001462 if (isa<InitListExpr>(IList->getInit(Index)))
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001463 CheckSubElementType(MemberEntity, IList, Field->getType(), Index,
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001464 StructuredList, StructuredIndex);
1465 else
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001466 CheckImplicitInitList(MemberEntity, IList, Field->getType(), Index,
Anders Carlsson987dc6a2010-01-23 20:47:59 +00001467 StructuredList, StructuredIndex);
Steve Naroff0cca7492008-05-01 22:18:59 +00001468}
Steve Naroff0cca7492008-05-01 22:18:59 +00001469
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001470/// \brief Expand a field designator that refers to a member of an
1471/// anonymous struct or union into a series of field designators that
1472/// refers to the field within the appropriate subobject.
1473///
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001474static void ExpandAnonymousFieldDesignator(Sema &SemaRef,
Mike Stump1eb44332009-09-09 15:08:12 +00001475 DesignatedInitExpr *DIE,
1476 unsigned DesigIdx,
Francois Picheta0e27f02010-12-22 03:46:10 +00001477 IndirectFieldDecl *IndirectField) {
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001478 typedef DesignatedInitExpr::Designator Designator;
1479
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001480 // Build the replacement designators.
Chris Lattner5f9e2722011-07-23 10:55:15 +00001481 SmallVector<Designator, 4> Replacements;
Francois Picheta0e27f02010-12-22 03:46:10 +00001482 for (IndirectFieldDecl::chain_iterator PI = IndirectField->chain_begin(),
1483 PE = IndirectField->chain_end(); PI != PE; ++PI) {
1484 if (PI + 1 == PE)
Mike Stump1eb44332009-09-09 15:08:12 +00001485 Replacements.push_back(Designator((IdentifierInfo *)0,
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001486 DIE->getDesignator(DesigIdx)->getDotLoc(),
1487 DIE->getDesignator(DesigIdx)->getFieldLoc()));
1488 else
1489 Replacements.push_back(Designator((IdentifierInfo *)0, SourceLocation(),
1490 SourceLocation()));
Francois Picheta0e27f02010-12-22 03:46:10 +00001491 assert(isa<FieldDecl>(*PI));
1492 Replacements.back().setField(cast<FieldDecl>(*PI));
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001493 }
1494
1495 // Expand the current designator into the set of replacement
1496 // designators, so we have a full subobject path down to where the
1497 // member of the anonymous struct/union is actually stored.
Douglas Gregor319d57f2010-01-06 23:17:19 +00001498 DIE->ExpandDesignator(SemaRef.Context, DesigIdx, &Replacements[0],
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001499 &Replacements[0] + Replacements.size());
Francois Picheta0e27f02010-12-22 03:46:10 +00001500}
Mike Stump1eb44332009-09-09 15:08:12 +00001501
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001502/// \brief Given an implicit anonymous field, search the IndirectField that
Francois Picheta0e27f02010-12-22 03:46:10 +00001503/// corresponds to FieldName.
1504static IndirectFieldDecl *FindIndirectFieldDesignator(FieldDecl *AnonField,
1505 IdentifierInfo *FieldName) {
1506 assert(AnonField->isAnonymousStructOrUnion());
1507 Decl *NextDecl = AnonField->getNextDeclInContext();
Aaron Ballman3e78b192012-02-09 22:16:56 +00001508 while (IndirectFieldDecl *IF =
1509 dyn_cast_or_null<IndirectFieldDecl>(NextDecl)) {
Francois Picheta0e27f02010-12-22 03:46:10 +00001510 if (FieldName && FieldName == IF->getAnonField()->getIdentifier())
1511 return IF;
1512 NextDecl = NextDecl->getNextDeclInContext();
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001513 }
Francois Picheta0e27f02010-12-22 03:46:10 +00001514 return 0;
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001515}
1516
Sebastian Redl14b0c192011-09-24 17:48:00 +00001517static DesignatedInitExpr *CloneDesignatedInitExpr(Sema &SemaRef,
1518 DesignatedInitExpr *DIE) {
1519 unsigned NumIndexExprs = DIE->getNumSubExprs() - 1;
1520 SmallVector<Expr*, 4> IndexExprs(NumIndexExprs);
1521 for (unsigned I = 0; I < NumIndexExprs; ++I)
1522 IndexExprs[I] = DIE->getSubExpr(I + 1);
1523 return DesignatedInitExpr::Create(SemaRef.Context, DIE->designators_begin(),
1524 DIE->size(), IndexExprs.data(),
1525 NumIndexExprs, DIE->getEqualOrColonLoc(),
1526 DIE->usesGNUSyntax(), DIE->getInit());
1527}
1528
Kaelyn Uhrain425d6312012-01-12 19:27:05 +00001529namespace {
1530
1531// Callback to only accept typo corrections that are for field members of
1532// the given struct or union.
1533class FieldInitializerValidatorCCC : public CorrectionCandidateCallback {
1534 public:
1535 explicit FieldInitializerValidatorCCC(RecordDecl *RD)
1536 : Record(RD) {}
1537
1538 virtual bool ValidateCandidate(const TypoCorrection &candidate) {
1539 FieldDecl *FD = candidate.getCorrectionDeclAs<FieldDecl>();
1540 return FD && FD->getDeclContext()->getRedeclContext()->Equals(Record);
1541 }
1542
1543 private:
1544 RecordDecl *Record;
1545};
1546
1547}
1548
Douglas Gregor05c13a32009-01-22 00:58:24 +00001549/// @brief Check the well-formedness of a C99 designated initializer.
1550///
1551/// Determines whether the designated initializer @p DIE, which
1552/// resides at the given @p Index within the initializer list @p
1553/// IList, is well-formed for a current object of type @p DeclType
1554/// (C99 6.7.8). The actual subobject that this designator refers to
Mike Stump1eb44332009-09-09 15:08:12 +00001555/// within the current subobject is returned in either
Douglas Gregor4c678342009-01-28 21:54:33 +00001556/// @p NextField or @p NextElementIndex (whichever is appropriate).
Douglas Gregor05c13a32009-01-22 00:58:24 +00001557///
1558/// @param IList The initializer list in which this designated
1559/// initializer occurs.
1560///
Douglas Gregor71199712009-04-15 04:56:10 +00001561/// @param DIE The designated initializer expression.
1562///
1563/// @param DesigIdx The index of the current designator.
Douglas Gregor05c13a32009-01-22 00:58:24 +00001564///
Dmitri Gribenko70517ca2012-08-23 17:58:28 +00001565/// @param CurrentObjectType The type of the "current object" (C99 6.7.8p17),
Douglas Gregor05c13a32009-01-22 00:58:24 +00001566/// into which the designation in @p DIE should refer.
1567///
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001568/// @param NextField If non-NULL and the first designator in @p DIE is
1569/// a field, this will be set to the field declaration corresponding
1570/// to the field named by the designator.
Douglas Gregor05c13a32009-01-22 00:58:24 +00001571///
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001572/// @param NextElementIndex If non-NULL and the first designator in @p
1573/// DIE is an array designator or GNU array-range designator, this
1574/// will be set to the last index initialized by this designator.
Douglas Gregor05c13a32009-01-22 00:58:24 +00001575///
1576/// @param Index Index into @p IList where the designated initializer
1577/// @p DIE occurs.
1578///
Douglas Gregor4c678342009-01-28 21:54:33 +00001579/// @param StructuredList The initializer list expression that
1580/// describes all of the subobject initializers in the order they'll
1581/// actually be initialized.
1582///
Douglas Gregor05c13a32009-01-22 00:58:24 +00001583/// @returns true if there was an error, false otherwise.
Mike Stump1eb44332009-09-09 15:08:12 +00001584bool
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001585InitListChecker::CheckDesignatedInitializer(const InitializedEntity &Entity,
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001586 InitListExpr *IList,
Sebastian Redl14b0c192011-09-24 17:48:00 +00001587 DesignatedInitExpr *DIE,
1588 unsigned DesigIdx,
1589 QualType &CurrentObjectType,
1590 RecordDecl::field_iterator *NextField,
1591 llvm::APSInt *NextElementIndex,
1592 unsigned &Index,
1593 InitListExpr *StructuredList,
1594 unsigned &StructuredIndex,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001595 bool FinishSubobjectInit,
1596 bool TopLevelObject) {
Douglas Gregor71199712009-04-15 04:56:10 +00001597 if (DesigIdx == DIE->size()) {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001598 // Check the actual initialization for the designated object type.
1599 bool prevHadError = hadError;
Douglas Gregor6fbdc6b2009-01-29 00:39:20 +00001600
1601 // Temporarily remove the designator expression from the
1602 // initializer list that the child calls see, so that we don't try
1603 // to re-process the designator.
1604 unsigned OldIndex = Index;
1605 IList->setInit(OldIndex, DIE->getInit());
1606
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001607 CheckSubElementType(Entity, IList, CurrentObjectType, Index,
Douglas Gregor4c678342009-01-28 21:54:33 +00001608 StructuredList, StructuredIndex);
Douglas Gregor6fbdc6b2009-01-29 00:39:20 +00001609
1610 // Restore the designated initializer expression in the syntactic
1611 // form of the initializer list.
1612 if (IList->getInit(OldIndex) != DIE->getInit())
1613 DIE->setInit(IList->getInit(OldIndex));
1614 IList->setInit(OldIndex, DIE);
1615
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001616 return hadError && !prevHadError;
Douglas Gregor05c13a32009-01-22 00:58:24 +00001617 }
1618
Douglas Gregor71199712009-04-15 04:56:10 +00001619 DesignatedInitExpr::Designator *D = DIE->getDesignator(DesigIdx);
Sebastian Redl14b0c192011-09-24 17:48:00 +00001620 bool IsFirstDesignator = (DesigIdx == 0);
1621 if (!VerifyOnly) {
1622 assert((IsFirstDesignator || StructuredList) &&
1623 "Need a non-designated initializer list to start from");
1624
1625 // Determine the structural initializer list that corresponds to the
1626 // current subobject.
Benjamin Kramera7894162012-02-23 14:48:40 +00001627 StructuredList = IsFirstDesignator? SyntacticToSemantic.lookup(IList)
Sebastian Redl14b0c192011-09-24 17:48:00 +00001628 : getStructuredSubobjectInit(IList, Index, CurrentObjectType,
1629 StructuredList, StructuredIndex,
1630 SourceRange(D->getStartLocation(),
1631 DIE->getSourceRange().getEnd()));
1632 assert(StructuredList && "Expected a structured initializer list");
1633 }
Douglas Gregor4c678342009-01-28 21:54:33 +00001634
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001635 if (D->isFieldDesignator()) {
1636 // C99 6.7.8p7:
1637 //
1638 // If a designator has the form
1639 //
1640 // . identifier
1641 //
1642 // then the current object (defined below) shall have
1643 // structure or union type and the identifier shall be the
Mike Stump1eb44332009-09-09 15:08:12 +00001644 // name of a member of that type.
Ted Kremenek6217b802009-07-29 21:53:49 +00001645 const RecordType *RT = CurrentObjectType->getAs<RecordType>();
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001646 if (!RT) {
1647 SourceLocation Loc = D->getDotLoc();
1648 if (Loc.isInvalid())
1649 Loc = D->getFieldLoc();
Sebastian Redl14b0c192011-09-24 17:48:00 +00001650 if (!VerifyOnly)
1651 SemaRef.Diag(Loc, diag::err_field_designator_non_aggr)
David Blaikie4e4d0842012-03-11 07:00:24 +00001652 << SemaRef.getLangOpts().CPlusPlus << CurrentObjectType;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001653 ++Index;
1654 return true;
1655 }
1656
Douglas Gregor4c678342009-01-28 21:54:33 +00001657 // Note: we perform a linear search of the fields here, despite
1658 // the fact that we have a faster lookup method, because we always
1659 // need to compute the field's index.
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001660 FieldDecl *KnownField = D->getField();
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001661 IdentifierInfo *FieldName = D->getFieldName();
Douglas Gregor4c678342009-01-28 21:54:33 +00001662 unsigned FieldIndex = 0;
Mike Stump1eb44332009-09-09 15:08:12 +00001663 RecordDecl::field_iterator
Argyrios Kyrtzidis17945a02009-06-30 02:36:12 +00001664 Field = RT->getDecl()->field_begin(),
1665 FieldEnd = RT->getDecl()->field_end();
Douglas Gregor4c678342009-01-28 21:54:33 +00001666 for (; Field != FieldEnd; ++Field) {
1667 if (Field->isUnnamedBitfield())
1668 continue;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001669
Francois Picheta0e27f02010-12-22 03:46:10 +00001670 // If we find a field representing an anonymous field, look in the
1671 // IndirectFieldDecl that follow for the designated initializer.
1672 if (!KnownField && Field->isAnonymousStructOrUnion()) {
1673 if (IndirectFieldDecl *IF =
David Blaikie581deb32012-06-06 20:45:41 +00001674 FindIndirectFieldDesignator(*Field, FieldName)) {
Sebastian Redl14b0c192011-09-24 17:48:00 +00001675 // In verify mode, don't modify the original.
1676 if (VerifyOnly)
1677 DIE = CloneDesignatedInitExpr(SemaRef, DIE);
Francois Picheta0e27f02010-12-22 03:46:10 +00001678 ExpandAnonymousFieldDesignator(SemaRef, DIE, DesigIdx, IF);
1679 D = DIE->getDesignator(DesigIdx);
1680 break;
1681 }
1682 }
David Blaikie581deb32012-06-06 20:45:41 +00001683 if (KnownField && KnownField == *Field)
Douglas Gregor022d13d2010-10-08 20:44:28 +00001684 break;
1685 if (FieldName && FieldName == Field->getIdentifier())
Douglas Gregor4c678342009-01-28 21:54:33 +00001686 break;
1687
1688 ++FieldIndex;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001689 }
1690
Douglas Gregor4c678342009-01-28 21:54:33 +00001691 if (Field == FieldEnd) {
Benjamin Kramera41ee492011-09-25 02:41:26 +00001692 if (VerifyOnly) {
1693 ++Index;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001694 return true; // No typo correction when just trying this out.
Benjamin Kramera41ee492011-09-25 02:41:26 +00001695 }
Sebastian Redl14b0c192011-09-24 17:48:00 +00001696
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001697 // There was no normal field in the struct with the designated
1698 // name. Perform another lookup for this name, which may find
1699 // something that we can't designate (e.g., a member function),
1700 // may find nothing, or may find a member of an anonymous
Mike Stump1eb44332009-09-09 15:08:12 +00001701 // struct/union.
Argyrios Kyrtzidis17945a02009-06-30 02:36:12 +00001702 DeclContext::lookup_result Lookup = RT->getDecl()->lookup(FieldName);
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001703 FieldDecl *ReplacementField = 0;
Douglas Gregor4c678342009-01-28 21:54:33 +00001704 if (Lookup.first == Lookup.second) {
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001705 // Name lookup didn't find anything. Determine whether this
1706 // was a typo for another field name.
Kaelyn Uhrain425d6312012-01-12 19:27:05 +00001707 FieldInitializerValidatorCCC Validator(RT->getDecl());
Douglas Gregord8bba9c2011-06-28 16:20:02 +00001708 TypoCorrection Corrected = SemaRef.CorrectTypo(
1709 DeclarationNameInfo(FieldName, D->getFieldLoc()),
Kaelyn Uhrain16e46dd2012-01-31 23:49:25 +00001710 Sema::LookupMemberName, /*Scope=*/0, /*SS=*/0, Validator,
Kaelyn Uhrain425d6312012-01-12 19:27:05 +00001711 RT->getDecl());
1712 if (Corrected) {
Douglas Gregord8bba9c2011-06-28 16:20:02 +00001713 std::string CorrectedStr(
David Blaikie4e4d0842012-03-11 07:00:24 +00001714 Corrected.getAsString(SemaRef.getLangOpts()));
Douglas Gregord8bba9c2011-06-28 16:20:02 +00001715 std::string CorrectedQuotedStr(
David Blaikie4e4d0842012-03-11 07:00:24 +00001716 Corrected.getQuoted(SemaRef.getLangOpts()));
Kaelyn Uhrain425d6312012-01-12 19:27:05 +00001717 ReplacementField = Corrected.getCorrectionDeclAs<FieldDecl>();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001718 SemaRef.Diag(D->getFieldLoc(),
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001719 diag::err_field_designator_unknown_suggest)
Douglas Gregord8bba9c2011-06-28 16:20:02 +00001720 << FieldName << CurrentObjectType << CorrectedQuotedStr
1721 << FixItHint::CreateReplacement(D->getFieldLoc(), CorrectedStr);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001722 SemaRef.Diag(ReplacementField->getLocation(),
Douglas Gregord8bba9c2011-06-28 16:20:02 +00001723 diag::note_previous_decl) << CorrectedQuotedStr;
Benjamin Kramera41ee492011-09-25 02:41:26 +00001724 hadError = true;
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001725 } else {
1726 SemaRef.Diag(D->getFieldLoc(), diag::err_field_designator_unknown)
1727 << FieldName << CurrentObjectType;
1728 ++Index;
1729 return true;
1730 }
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001731 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001732
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001733 if (!ReplacementField) {
Douglas Gregor4c678342009-01-28 21:54:33 +00001734 // Name lookup found something, but it wasn't a field.
Chris Lattner08202542009-02-24 22:50:46 +00001735 SemaRef.Diag(D->getFieldLoc(), diag::err_field_designator_nonfield)
Douglas Gregor4c678342009-01-28 21:54:33 +00001736 << FieldName;
Mike Stump1eb44332009-09-09 15:08:12 +00001737 SemaRef.Diag((*Lookup.first)->getLocation(),
Douglas Gregor4c678342009-01-28 21:54:33 +00001738 diag::note_field_designator_found);
Eli Friedmanba79fc22009-04-16 17:49:48 +00001739 ++Index;
1740 return true;
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001741 }
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001742
Francois Picheta0e27f02010-12-22 03:46:10 +00001743 if (!KnownField) {
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001744 // The replacement field comes from typo correction; find it
1745 // in the list of fields.
1746 FieldIndex = 0;
1747 Field = RT->getDecl()->field_begin();
1748 for (; Field != FieldEnd; ++Field) {
1749 if (Field->isUnnamedBitfield())
1750 continue;
1751
David Blaikie581deb32012-06-06 20:45:41 +00001752 if (ReplacementField == *Field ||
Douglas Gregorc171e3b2010-01-01 00:03:05 +00001753 Field->getIdentifier() == ReplacementField->getIdentifier())
1754 break;
1755
1756 ++FieldIndex;
1757 }
1758 }
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001759 }
Douglas Gregor4c678342009-01-28 21:54:33 +00001760
1761 // All of the fields of a union are located at the same place in
1762 // the initializer list.
Douglas Gregor0bb76892009-01-29 16:53:55 +00001763 if (RT->getDecl()->isUnion()) {
Douglas Gregor4c678342009-01-28 21:54:33 +00001764 FieldIndex = 0;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001765 if (!VerifyOnly)
David Blaikie581deb32012-06-06 20:45:41 +00001766 StructuredList->setInitializedFieldInUnion(*Field);
Douglas Gregor0bb76892009-01-29 16:53:55 +00001767 }
Douglas Gregor4c678342009-01-28 21:54:33 +00001768
Douglas Gregor54001c12011-06-29 21:51:31 +00001769 // Make sure we can use this declaration.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001770 bool InvalidUse;
1771 if (VerifyOnly)
David Blaikie581deb32012-06-06 20:45:41 +00001772 InvalidUse = !SemaRef.CanUseDecl(*Field);
Sebastian Redl14b0c192011-09-24 17:48:00 +00001773 else
David Blaikie581deb32012-06-06 20:45:41 +00001774 InvalidUse = SemaRef.DiagnoseUseOfDecl(*Field, D->getFieldLoc());
Sebastian Redl14b0c192011-09-24 17:48:00 +00001775 if (InvalidUse) {
Douglas Gregor54001c12011-06-29 21:51:31 +00001776 ++Index;
1777 return true;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001778 }
Douglas Gregor54001c12011-06-29 21:51:31 +00001779
Sebastian Redl14b0c192011-09-24 17:48:00 +00001780 if (!VerifyOnly) {
1781 // Update the designator with the field declaration.
David Blaikie581deb32012-06-06 20:45:41 +00001782 D->setField(*Field);
Mike Stump1eb44332009-09-09 15:08:12 +00001783
Sebastian Redl14b0c192011-09-24 17:48:00 +00001784 // Make sure that our non-designated initializer list has space
1785 // for a subobject corresponding to this field.
1786 if (FieldIndex >= StructuredList->getNumInits())
1787 StructuredList->resizeInits(SemaRef.Context, FieldIndex + 1);
1788 }
Douglas Gregor4c678342009-01-28 21:54:33 +00001789
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001790 // This designator names a flexible array member.
1791 if (Field->getType()->isIncompleteArrayType()) {
1792 bool Invalid = false;
Douglas Gregor71199712009-04-15 04:56:10 +00001793 if ((DesigIdx + 1) != DIE->size()) {
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001794 // We can't designate an object within the flexible array
1795 // member (because GCC doesn't allow it).
Sebastian Redl14b0c192011-09-24 17:48:00 +00001796 if (!VerifyOnly) {
1797 DesignatedInitExpr::Designator *NextD
1798 = DIE->getDesignator(DesigIdx + 1);
1799 SemaRef.Diag(NextD->getStartLocation(),
1800 diag::err_designator_into_flexible_array_member)
1801 << SourceRange(NextD->getStartLocation(),
1802 DIE->getSourceRange().getEnd());
1803 SemaRef.Diag(Field->getLocation(), diag::note_flexible_array_member)
David Blaikie581deb32012-06-06 20:45:41 +00001804 << *Field;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001805 }
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001806 Invalid = true;
1807 }
1808
Chris Lattner9046c222010-10-10 17:49:49 +00001809 if (!hadError && !isa<InitListExpr>(DIE->getInit()) &&
1810 !isa<StringLiteral>(DIE->getInit())) {
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001811 // The initializer is not an initializer list.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001812 if (!VerifyOnly) {
Daniel Dunbar96a00142012-03-09 18:35:03 +00001813 SemaRef.Diag(DIE->getInit()->getLocStart(),
Sebastian Redl14b0c192011-09-24 17:48:00 +00001814 diag::err_flexible_array_init_needs_braces)
1815 << DIE->getInit()->getSourceRange();
1816 SemaRef.Diag(Field->getLocation(), diag::note_flexible_array_member)
David Blaikie581deb32012-06-06 20:45:41 +00001817 << *Field;
Sebastian Redl14b0c192011-09-24 17:48:00 +00001818 }
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001819 Invalid = true;
1820 }
1821
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001822 // Check GNU flexible array initializer.
David Blaikie581deb32012-06-06 20:45:41 +00001823 if (!Invalid && CheckFlexibleArrayInit(Entity, DIE->getInit(), *Field,
Eli Friedmanf40fd6b2011-08-23 22:24:57 +00001824 TopLevelObject))
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001825 Invalid = true;
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001826
1827 if (Invalid) {
1828 ++Index;
1829 return true;
1830 }
1831
1832 // Initialize the array.
1833 bool prevHadError = hadError;
1834 unsigned newStructuredIndex = FieldIndex;
1835 unsigned OldIndex = Index;
1836 IList->setInit(Index, DIE->getInit());
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001837
1838 InitializedEntity MemberEntity =
David Blaikie581deb32012-06-06 20:45:41 +00001839 InitializedEntity::InitializeMember(*Field, &Entity);
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001840 CheckSubElementType(MemberEntity, IList, Field->getType(), Index,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001841 StructuredList, newStructuredIndex);
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001842
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001843 IList->setInit(OldIndex, DIE);
1844 if (hadError && !prevHadError) {
1845 ++Field;
1846 ++FieldIndex;
1847 if (NextField)
1848 *NextField = Field;
1849 StructuredIndex = FieldIndex;
1850 return true;
1851 }
1852 } else {
1853 // Recurse to check later designated subobjects.
David Blaikie262bc182012-04-30 02:36:29 +00001854 QualType FieldType = Field->getType();
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001855 unsigned newStructuredIndex = FieldIndex;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001856
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001857 InitializedEntity MemberEntity =
David Blaikie581deb32012-06-06 20:45:41 +00001858 InitializedEntity::InitializeMember(*Field, &Entity);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001859 if (CheckDesignatedInitializer(MemberEntity, IList, DIE, DesigIdx + 1,
1860 FieldType, 0, 0, Index,
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001861 StructuredList, newStructuredIndex,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00001862 true, false))
1863 return true;
1864 }
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001865
1866 // Find the position of the next field to be initialized in this
1867 // subobject.
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001868 ++Field;
Douglas Gregor4c678342009-01-28 21:54:33 +00001869 ++FieldIndex;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001870
1871 // If this the first designator, our caller will continue checking
1872 // the rest of this struct/class/union subobject.
1873 if (IsFirstDesignator) {
1874 if (NextField)
1875 *NextField = Field;
Douglas Gregor4c678342009-01-28 21:54:33 +00001876 StructuredIndex = FieldIndex;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001877 return false;
1878 }
1879
Douglas Gregor34e79462009-01-28 23:36:17 +00001880 if (!FinishSubobjectInit)
1881 return false;
1882
Douglas Gregorffb4b6e2009-04-15 06:41:24 +00001883 // We've already initialized something in the union; we're done.
1884 if (RT->getDecl()->isUnion())
1885 return hadError;
1886
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001887 // Check the remaining fields within this class/struct/union subobject.
1888 bool prevHadError = hadError;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001889
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001890 CheckStructUnionTypes(Entity, IList, CurrentObjectType, Field, false, Index,
Douglas Gregor4c678342009-01-28 21:54:33 +00001891 StructuredList, FieldIndex);
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001892 return hadError && !prevHadError;
1893 }
1894
1895 // C99 6.7.8p6:
1896 //
1897 // If a designator has the form
1898 //
1899 // [ constant-expression ]
1900 //
1901 // then the current object (defined below) shall have array
1902 // type and the expression shall be an integer constant
1903 // expression. If the array is of unknown size, any
1904 // nonnegative value is valid.
1905 //
1906 // Additionally, cope with the GNU extension that permits
1907 // designators of the form
1908 //
1909 // [ constant-expression ... constant-expression ]
Chris Lattner08202542009-02-24 22:50:46 +00001910 const ArrayType *AT = SemaRef.Context.getAsArrayType(CurrentObjectType);
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001911 if (!AT) {
Sebastian Redl14b0c192011-09-24 17:48:00 +00001912 if (!VerifyOnly)
1913 SemaRef.Diag(D->getLBracketLoc(), diag::err_array_designator_non_array)
1914 << CurrentObjectType;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001915 ++Index;
1916 return true;
1917 }
1918
1919 Expr *IndexExpr = 0;
Douglas Gregor34e79462009-01-28 23:36:17 +00001920 llvm::APSInt DesignatedStartIndex, DesignatedEndIndex;
1921 if (D->isArrayDesignator()) {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001922 IndexExpr = DIE->getArrayIndex(*D);
Richard Smitha6b8b2c2011-10-10 18:28:20 +00001923 DesignatedStartIndex = IndexExpr->EvaluateKnownConstInt(SemaRef.Context);
Douglas Gregor34e79462009-01-28 23:36:17 +00001924 DesignatedEndIndex = DesignatedStartIndex;
1925 } else {
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001926 assert(D->isArrayRangeDesignator() && "Need array-range designator");
Douglas Gregor34e79462009-01-28 23:36:17 +00001927
Mike Stump1eb44332009-09-09 15:08:12 +00001928 DesignatedStartIndex =
Richard Smitha6b8b2c2011-10-10 18:28:20 +00001929 DIE->getArrayRangeStart(*D)->EvaluateKnownConstInt(SemaRef.Context);
Mike Stump1eb44332009-09-09 15:08:12 +00001930 DesignatedEndIndex =
Richard Smitha6b8b2c2011-10-10 18:28:20 +00001931 DIE->getArrayRangeEnd(*D)->EvaluateKnownConstInt(SemaRef.Context);
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001932 IndexExpr = DIE->getArrayRangeEnd(*D);
Douglas Gregor34e79462009-01-28 23:36:17 +00001933
Chris Lattnere0fd8322011-02-19 22:28:58 +00001934 // Codegen can't handle evaluating array range designators that have side
1935 // effects, because we replicate the AST value for each initialized element.
1936 // As such, set the sawArrayRangeDesignator() bit if we initialize multiple
1937 // elements with something that has a side effect, so codegen can emit an
1938 // "error unsupported" error instead of miscompiling the app.
1939 if (DesignatedStartIndex.getZExtValue()!=DesignatedEndIndex.getZExtValue()&&
Sebastian Redl14b0c192011-09-24 17:48:00 +00001940 DIE->getInit()->HasSideEffects(SemaRef.Context) && !VerifyOnly)
Douglas Gregora9c87802009-01-29 19:42:23 +00001941 FullyStructuredList->sawArrayRangeDesignator();
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001942 }
1943
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001944 if (isa<ConstantArrayType>(AT)) {
1945 llvm::APSInt MaxElements(cast<ConstantArrayType>(AT)->getSize(), false);
Jay Foad9f71a8f2010-12-07 08:25:34 +00001946 DesignatedStartIndex
1947 = DesignatedStartIndex.extOrTrunc(MaxElements.getBitWidth());
Douglas Gregor34e79462009-01-28 23:36:17 +00001948 DesignatedStartIndex.setIsUnsigned(MaxElements.isUnsigned());
Jay Foad9f71a8f2010-12-07 08:25:34 +00001949 DesignatedEndIndex
1950 = DesignatedEndIndex.extOrTrunc(MaxElements.getBitWidth());
Douglas Gregor34e79462009-01-28 23:36:17 +00001951 DesignatedEndIndex.setIsUnsigned(MaxElements.isUnsigned());
1952 if (DesignatedEndIndex >= MaxElements) {
Eli Friedmana4e20e12011-09-26 18:53:43 +00001953 if (!VerifyOnly)
Daniel Dunbar96a00142012-03-09 18:35:03 +00001954 SemaRef.Diag(IndexExpr->getLocStart(),
Sebastian Redl14b0c192011-09-24 17:48:00 +00001955 diag::err_array_designator_too_large)
1956 << DesignatedEndIndex.toString(10) << MaxElements.toString(10)
1957 << IndexExpr->getSourceRange();
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001958 ++Index;
1959 return true;
1960 }
Douglas Gregor34e79462009-01-28 23:36:17 +00001961 } else {
1962 // Make sure the bit-widths and signedness match.
1963 if (DesignatedStartIndex.getBitWidth() > DesignatedEndIndex.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00001964 DesignatedEndIndex
1965 = DesignatedEndIndex.extend(DesignatedStartIndex.getBitWidth());
Chris Lattner3bf68932009-04-25 21:59:05 +00001966 else if (DesignatedStartIndex.getBitWidth() <
1967 DesignatedEndIndex.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00001968 DesignatedStartIndex
1969 = DesignatedStartIndex.extend(DesignatedEndIndex.getBitWidth());
Douglas Gregor34e79462009-01-28 23:36:17 +00001970 DesignatedStartIndex.setIsUnsigned(true);
1971 DesignatedEndIndex.setIsUnsigned(true);
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001972 }
Mike Stump1eb44332009-09-09 15:08:12 +00001973
Douglas Gregor4c678342009-01-28 21:54:33 +00001974 // Make sure that our non-designated initializer list has space
1975 // for a subobject corresponding to this array element.
Sebastian Redl14b0c192011-09-24 17:48:00 +00001976 if (!VerifyOnly &&
1977 DesignatedEndIndex.getZExtValue() >= StructuredList->getNumInits())
Mike Stump1eb44332009-09-09 15:08:12 +00001978 StructuredList->resizeInits(SemaRef.Context,
Douglas Gregor34e79462009-01-28 23:36:17 +00001979 DesignatedEndIndex.getZExtValue() + 1);
Douglas Gregor4c678342009-01-28 21:54:33 +00001980
Douglas Gregor34e79462009-01-28 23:36:17 +00001981 // Repeatedly perform subobject initializations in the range
1982 // [DesignatedStartIndex, DesignatedEndIndex].
Douglas Gregor87f55cf2009-01-22 23:26:18 +00001983
Douglas Gregor34e79462009-01-28 23:36:17 +00001984 // Move to the next designator
1985 unsigned ElementIndex = DesignatedStartIndex.getZExtValue();
1986 unsigned OldIndex = Index;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001987
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001988 InitializedEntity ElementEntity =
Anders Carlsson8ff9e862010-01-23 23:23:01 +00001989 InitializedEntity::InitializeElement(SemaRef.Context, 0, Entity);
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001990
Douglas Gregor34e79462009-01-28 23:36:17 +00001991 while (DesignatedStartIndex <= DesignatedEndIndex) {
1992 // Recurse to check later designated subobjects.
1993 QualType ElementType = AT->getElementType();
1994 Index = OldIndex;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001995
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001996 ElementEntity.setElementIndex(ElementIndex);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00001997 if (CheckDesignatedInitializer(ElementEntity, IList, DIE, DesigIdx + 1,
1998 ElementType, 0, 0, Index,
Anders Carlsson9a8a70e2010-01-23 22:49:02 +00001999 StructuredList, ElementIndex,
Douglas Gregoreeb15d42009-02-04 22:46:25 +00002000 (DesignatedStartIndex == DesignatedEndIndex),
2001 false))
Douglas Gregor34e79462009-01-28 23:36:17 +00002002 return true;
2003
2004 // Move to the next index in the array that we'll be initializing.
2005 ++DesignatedStartIndex;
2006 ElementIndex = DesignatedStartIndex.getZExtValue();
2007 }
Douglas Gregor87f55cf2009-01-22 23:26:18 +00002008
2009 // If this the first designator, our caller will continue checking
2010 // the rest of this array subobject.
2011 if (IsFirstDesignator) {
2012 if (NextElementIndex)
Douglas Gregor34e79462009-01-28 23:36:17 +00002013 *NextElementIndex = DesignatedStartIndex;
Douglas Gregor4c678342009-01-28 21:54:33 +00002014 StructuredIndex = ElementIndex;
Douglas Gregor87f55cf2009-01-22 23:26:18 +00002015 return false;
2016 }
Mike Stump1eb44332009-09-09 15:08:12 +00002017
Douglas Gregor34e79462009-01-28 23:36:17 +00002018 if (!FinishSubobjectInit)
2019 return false;
2020
Douglas Gregor87f55cf2009-01-22 23:26:18 +00002021 // Check the remaining elements within this array subobject.
Douglas Gregor05c13a32009-01-22 00:58:24 +00002022 bool prevHadError = hadError;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002023 CheckArrayType(Entity, IList, CurrentObjectType, DesignatedStartIndex,
Anders Carlsson784f6992010-01-23 20:13:41 +00002024 /*SubobjectIsDesignatorContext=*/false, Index,
Douglas Gregor4c678342009-01-28 21:54:33 +00002025 StructuredList, ElementIndex);
Mike Stump1eb44332009-09-09 15:08:12 +00002026 return hadError && !prevHadError;
Douglas Gregor05c13a32009-01-22 00:58:24 +00002027}
2028
Douglas Gregor4c678342009-01-28 21:54:33 +00002029// Get the structured initializer list for a subobject of type
2030// @p CurrentObjectType.
2031InitListExpr *
2032InitListChecker::getStructuredSubobjectInit(InitListExpr *IList, unsigned Index,
2033 QualType CurrentObjectType,
2034 InitListExpr *StructuredList,
2035 unsigned StructuredIndex,
2036 SourceRange InitRange) {
Sebastian Redl14b0c192011-09-24 17:48:00 +00002037 if (VerifyOnly)
2038 return 0; // No structured list in verification-only mode.
Douglas Gregor4c678342009-01-28 21:54:33 +00002039 Expr *ExistingInit = 0;
2040 if (!StructuredList)
Benjamin Kramera7894162012-02-23 14:48:40 +00002041 ExistingInit = SyntacticToSemantic.lookup(IList);
Douglas Gregor4c678342009-01-28 21:54:33 +00002042 else if (StructuredIndex < StructuredList->getNumInits())
2043 ExistingInit = StructuredList->getInit(StructuredIndex);
Mike Stump1eb44332009-09-09 15:08:12 +00002044
Douglas Gregor4c678342009-01-28 21:54:33 +00002045 if (InitListExpr *Result = dyn_cast_or_null<InitListExpr>(ExistingInit))
2046 return Result;
2047
2048 if (ExistingInit) {
2049 // We are creating an initializer list that initializes the
2050 // subobjects of the current object, but there was already an
2051 // initialization that completely initialized the current
2052 // subobject, e.g., by a compound literal:
Mike Stump1eb44332009-09-09 15:08:12 +00002053 //
Douglas Gregor4c678342009-01-28 21:54:33 +00002054 // struct X { int a, b; };
2055 // struct X xs[] = { [0] = (struct X) { 1, 2 }, [0].b = 3 };
Mike Stump1eb44332009-09-09 15:08:12 +00002056 //
Douglas Gregor4c678342009-01-28 21:54:33 +00002057 // Here, xs[0].a == 0 and xs[0].b == 3, since the second,
2058 // designated initializer re-initializes the whole
2059 // subobject [0], overwriting previous initializers.
Mike Stump1eb44332009-09-09 15:08:12 +00002060 SemaRef.Diag(InitRange.getBegin(),
Douglas Gregored8a93d2009-03-01 17:12:46 +00002061 diag::warn_subobject_initializer_overrides)
Douglas Gregor4c678342009-01-28 21:54:33 +00002062 << InitRange;
Daniel Dunbar96a00142012-03-09 18:35:03 +00002063 SemaRef.Diag(ExistingInit->getLocStart(),
Douglas Gregor4c678342009-01-28 21:54:33 +00002064 diag::note_previous_initializer)
Douglas Gregor54f07282009-01-28 23:43:32 +00002065 << /*FIXME:has side effects=*/0
Douglas Gregor4c678342009-01-28 21:54:33 +00002066 << ExistingInit->getSourceRange();
2067 }
2068
Mike Stump1eb44332009-09-09 15:08:12 +00002069 InitListExpr *Result
Ted Kremenek709210f2010-04-13 23:39:13 +00002070 = new (SemaRef.Context) InitListExpr(SemaRef.Context,
2071 InitRange.getBegin(), 0, 0,
Ted Kremenekba7bc552010-02-19 01:50:18 +00002072 InitRange.getEnd());
Douglas Gregored8a93d2009-03-01 17:12:46 +00002073
Eli Friedman5c89c392012-02-23 02:25:10 +00002074 QualType ResultType = CurrentObjectType;
2075 if (!ResultType->isArrayType())
2076 ResultType = ResultType.getNonLValueExprType(SemaRef.Context);
2077 Result->setType(ResultType);
Douglas Gregor4c678342009-01-28 21:54:33 +00002078
Douglas Gregorfa219202009-03-20 23:58:33 +00002079 // Pre-allocate storage for the structured initializer list.
2080 unsigned NumElements = 0;
Douglas Gregor08457732009-03-21 18:13:52 +00002081 unsigned NumInits = 0;
Argyrios Kyrtzidisf8b17712011-04-28 18:53:55 +00002082 bool GotNumInits = false;
2083 if (!StructuredList) {
Douglas Gregor08457732009-03-21 18:13:52 +00002084 NumInits = IList->getNumInits();
Argyrios Kyrtzidisf8b17712011-04-28 18:53:55 +00002085 GotNumInits = true;
2086 } else if (Index < IList->getNumInits()) {
2087 if (InitListExpr *SubList = dyn_cast<InitListExpr>(IList->getInit(Index))) {
Douglas Gregor08457732009-03-21 18:13:52 +00002088 NumInits = SubList->getNumInits();
Argyrios Kyrtzidisf8b17712011-04-28 18:53:55 +00002089 GotNumInits = true;
2090 }
Douglas Gregor08457732009-03-21 18:13:52 +00002091 }
2092
Mike Stump1eb44332009-09-09 15:08:12 +00002093 if (const ArrayType *AType
Douglas Gregorfa219202009-03-20 23:58:33 +00002094 = SemaRef.Context.getAsArrayType(CurrentObjectType)) {
2095 if (const ConstantArrayType *CAType = dyn_cast<ConstantArrayType>(AType)) {
2096 NumElements = CAType->getSize().getZExtValue();
2097 // Simple heuristic so that we don't allocate a very large
2098 // initializer with many empty entries at the end.
Argyrios Kyrtzidisf8b17712011-04-28 18:53:55 +00002099 if (GotNumInits && NumElements > NumInits)
Douglas Gregorfa219202009-03-20 23:58:33 +00002100 NumElements = 0;
2101 }
John McCall183700f2009-09-21 23:43:11 +00002102 } else if (const VectorType *VType = CurrentObjectType->getAs<VectorType>())
Douglas Gregorfa219202009-03-20 23:58:33 +00002103 NumElements = VType->getNumElements();
Ted Kremenek6217b802009-07-29 21:53:49 +00002104 else if (const RecordType *RType = CurrentObjectType->getAs<RecordType>()) {
Douglas Gregorfa219202009-03-20 23:58:33 +00002105 RecordDecl *RDecl = RType->getDecl();
2106 if (RDecl->isUnion())
2107 NumElements = 1;
2108 else
Mike Stump1eb44332009-09-09 15:08:12 +00002109 NumElements = std::distance(RDecl->field_begin(),
Argyrios Kyrtzidis17945a02009-06-30 02:36:12 +00002110 RDecl->field_end());
Douglas Gregorfa219202009-03-20 23:58:33 +00002111 }
2112
Ted Kremenek709210f2010-04-13 23:39:13 +00002113 Result->reserveInits(SemaRef.Context, NumElements);
Douglas Gregorfa219202009-03-20 23:58:33 +00002114
Douglas Gregor4c678342009-01-28 21:54:33 +00002115 // Link this new initializer list into the structured initializer
2116 // lists.
2117 if (StructuredList)
Ted Kremenek709210f2010-04-13 23:39:13 +00002118 StructuredList->updateInit(SemaRef.Context, StructuredIndex, Result);
Douglas Gregor4c678342009-01-28 21:54:33 +00002119 else {
2120 Result->setSyntacticForm(IList);
2121 SyntacticToSemantic[IList] = Result;
2122 }
2123
2124 return Result;
2125}
2126
2127/// Update the initializer at index @p StructuredIndex within the
2128/// structured initializer list to the value @p expr.
2129void InitListChecker::UpdateStructuredListElement(InitListExpr *StructuredList,
2130 unsigned &StructuredIndex,
2131 Expr *expr) {
2132 // No structured initializer list to update
2133 if (!StructuredList)
2134 return;
2135
Ted Kremenek709210f2010-04-13 23:39:13 +00002136 if (Expr *PrevInit = StructuredList->updateInit(SemaRef.Context,
2137 StructuredIndex, expr)) {
Douglas Gregor4c678342009-01-28 21:54:33 +00002138 // This initializer overwrites a previous initializer. Warn.
Daniel Dunbar96a00142012-03-09 18:35:03 +00002139 SemaRef.Diag(expr->getLocStart(),
Douglas Gregor4c678342009-01-28 21:54:33 +00002140 diag::warn_initializer_overrides)
2141 << expr->getSourceRange();
Daniel Dunbar96a00142012-03-09 18:35:03 +00002142 SemaRef.Diag(PrevInit->getLocStart(),
Douglas Gregor4c678342009-01-28 21:54:33 +00002143 diag::note_previous_initializer)
Douglas Gregor54f07282009-01-28 23:43:32 +00002144 << /*FIXME:has side effects=*/0
Douglas Gregor4c678342009-01-28 21:54:33 +00002145 << PrevInit->getSourceRange();
2146 }
Mike Stump1eb44332009-09-09 15:08:12 +00002147
Douglas Gregor4c678342009-01-28 21:54:33 +00002148 ++StructuredIndex;
2149}
2150
Douglas Gregor05c13a32009-01-22 00:58:24 +00002151/// Check that the given Index expression is a valid array designator
Richard Smith282e7e62012-02-04 09:53:13 +00002152/// value. This is essentially just a wrapper around
Chris Lattner3bf68932009-04-25 21:59:05 +00002153/// VerifyIntegerConstantExpression that also checks for negative values
Douglas Gregor05c13a32009-01-22 00:58:24 +00002154/// and produces a reasonable diagnostic if there is a
Richard Smith282e7e62012-02-04 09:53:13 +00002155/// failure. Returns the index expression, possibly with an implicit cast
2156/// added, on success. If everything went okay, Value will receive the
2157/// value of the constant expression.
2158static ExprResult
Chris Lattner3bf68932009-04-25 21:59:05 +00002159CheckArrayDesignatorExpr(Sema &S, Expr *Index, llvm::APSInt &Value) {
Daniel Dunbar96a00142012-03-09 18:35:03 +00002160 SourceLocation Loc = Index->getLocStart();
Douglas Gregor05c13a32009-01-22 00:58:24 +00002161
2162 // Make sure this is an integer constant expression.
Richard Smith282e7e62012-02-04 09:53:13 +00002163 ExprResult Result = S.VerifyIntegerConstantExpression(Index, &Value);
2164 if (Result.isInvalid())
2165 return Result;
Douglas Gregor05c13a32009-01-22 00:58:24 +00002166
Chris Lattner3bf68932009-04-25 21:59:05 +00002167 if (Value.isSigned() && Value.isNegative())
2168 return S.Diag(Loc, diag::err_array_designator_negative)
Douglas Gregor05c13a32009-01-22 00:58:24 +00002169 << Value.toString(10) << Index->getSourceRange();
2170
Douglas Gregor53d3d8e2009-01-23 21:04:18 +00002171 Value.setIsUnsigned(true);
Richard Smith282e7e62012-02-04 09:53:13 +00002172 return Result;
Douglas Gregor05c13a32009-01-22 00:58:24 +00002173}
2174
John McCall60d7b3a2010-08-24 06:29:42 +00002175ExprResult Sema::ActOnDesignatedInitializer(Designation &Desig,
Nick Lewycky7663f392010-11-20 01:29:55 +00002176 SourceLocation Loc,
2177 bool GNUSyntax,
2178 ExprResult Init) {
Douglas Gregor05c13a32009-01-22 00:58:24 +00002179 typedef DesignatedInitExpr::Designator ASTDesignator;
2180
2181 bool Invalid = false;
Chris Lattner5f9e2722011-07-23 10:55:15 +00002182 SmallVector<ASTDesignator, 32> Designators;
2183 SmallVector<Expr *, 32> InitExpressions;
Douglas Gregor05c13a32009-01-22 00:58:24 +00002184
2185 // Build designators and check array designator expressions.
2186 for (unsigned Idx = 0; Idx < Desig.getNumDesignators(); ++Idx) {
2187 const Designator &D = Desig.getDesignator(Idx);
2188 switch (D.getKind()) {
2189 case Designator::FieldDesignator:
Mike Stump1eb44332009-09-09 15:08:12 +00002190 Designators.push_back(ASTDesignator(D.getField(), D.getDotLoc(),
Douglas Gregor05c13a32009-01-22 00:58:24 +00002191 D.getFieldLoc()));
2192 break;
2193
2194 case Designator::ArrayDesignator: {
2195 Expr *Index = static_cast<Expr *>(D.getArrayIndex());
2196 llvm::APSInt IndexValue;
Richard Smith282e7e62012-02-04 09:53:13 +00002197 if (!Index->isTypeDependent() && !Index->isValueDependent())
2198 Index = CheckArrayDesignatorExpr(*this, Index, IndexValue).take();
2199 if (!Index)
Douglas Gregor05c13a32009-01-22 00:58:24 +00002200 Invalid = true;
2201 else {
2202 Designators.push_back(ASTDesignator(InitExpressions.size(),
Mike Stump1eb44332009-09-09 15:08:12 +00002203 D.getLBracketLoc(),
Douglas Gregor05c13a32009-01-22 00:58:24 +00002204 D.getRBracketLoc()));
2205 InitExpressions.push_back(Index);
2206 }
2207 break;
2208 }
2209
2210 case Designator::ArrayRangeDesignator: {
2211 Expr *StartIndex = static_cast<Expr *>(D.getArrayRangeStart());
2212 Expr *EndIndex = static_cast<Expr *>(D.getArrayRangeEnd());
2213 llvm::APSInt StartValue;
2214 llvm::APSInt EndValue;
Douglas Gregor9ea62762009-05-21 23:17:49 +00002215 bool StartDependent = StartIndex->isTypeDependent() ||
2216 StartIndex->isValueDependent();
2217 bool EndDependent = EndIndex->isTypeDependent() ||
2218 EndIndex->isValueDependent();
Richard Smith282e7e62012-02-04 09:53:13 +00002219 if (!StartDependent)
2220 StartIndex =
2221 CheckArrayDesignatorExpr(*this, StartIndex, StartValue).take();
2222 if (!EndDependent)
2223 EndIndex = CheckArrayDesignatorExpr(*this, EndIndex, EndValue).take();
2224
2225 if (!StartIndex || !EndIndex)
Douglas Gregor05c13a32009-01-22 00:58:24 +00002226 Invalid = true;
Douglas Gregord6f584f2009-01-23 22:22:29 +00002227 else {
2228 // Make sure we're comparing values with the same bit width.
Douglas Gregor9ea62762009-05-21 23:17:49 +00002229 if (StartDependent || EndDependent) {
2230 // Nothing to compute.
2231 } else if (StartValue.getBitWidth() > EndValue.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00002232 EndValue = EndValue.extend(StartValue.getBitWidth());
Douglas Gregord6f584f2009-01-23 22:22:29 +00002233 else if (StartValue.getBitWidth() < EndValue.getBitWidth())
Jay Foad9f71a8f2010-12-07 08:25:34 +00002234 StartValue = StartValue.extend(EndValue.getBitWidth());
Douglas Gregord6f584f2009-01-23 22:22:29 +00002235
Douglas Gregorc4bb7bf2009-05-21 23:30:39 +00002236 if (!StartDependent && !EndDependent && EndValue < StartValue) {
Douglas Gregord6f584f2009-01-23 22:22:29 +00002237 Diag(D.getEllipsisLoc(), diag::err_array_designator_empty_range)
Mike Stump1eb44332009-09-09 15:08:12 +00002238 << StartValue.toString(10) << EndValue.toString(10)
Douglas Gregord6f584f2009-01-23 22:22:29 +00002239 << StartIndex->getSourceRange() << EndIndex->getSourceRange();
2240 Invalid = true;
2241 } else {
2242 Designators.push_back(ASTDesignator(InitExpressions.size(),
Mike Stump1eb44332009-09-09 15:08:12 +00002243 D.getLBracketLoc(),
Douglas Gregord6f584f2009-01-23 22:22:29 +00002244 D.getEllipsisLoc(),
2245 D.getRBracketLoc()));
2246 InitExpressions.push_back(StartIndex);
2247 InitExpressions.push_back(EndIndex);
2248 }
Douglas Gregor05c13a32009-01-22 00:58:24 +00002249 }
2250 break;
2251 }
2252 }
2253 }
2254
2255 if (Invalid || Init.isInvalid())
2256 return ExprError();
2257
2258 // Clear out the expressions within the designation.
2259 Desig.ClearExprs(*this);
2260
2261 DesignatedInitExpr *DIE
Jay Foadbeaaccd2009-05-21 09:52:38 +00002262 = DesignatedInitExpr::Create(Context,
2263 Designators.data(), Designators.size(),
2264 InitExpressions.data(), InitExpressions.size(),
Anders Carlssone9146f22009-05-01 19:49:17 +00002265 Loc, GNUSyntax, Init.takeAs<Expr>());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002266
David Blaikie4e4d0842012-03-11 07:00:24 +00002267 if (!getLangOpts().C99)
Douglas Gregor2d75bbd2011-01-16 16:13:16 +00002268 Diag(DIE->getLocStart(), diag::ext_designated_init)
2269 << DIE->getSourceRange();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002270
Douglas Gregor05c13a32009-01-22 00:58:24 +00002271 return Owned(DIE);
2272}
Douglas Gregorc34ee5e2009-01-29 00:45:39 +00002273
Douglas Gregor20093b42009-12-09 23:02:17 +00002274//===----------------------------------------------------------------------===//
2275// Initialization entity
2276//===----------------------------------------------------------------------===//
2277
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002278InitializedEntity::InitializedEntity(ASTContext &Context, unsigned Index,
Douglas Gregorcb57fb92009-12-16 06:35:08 +00002279 const InitializedEntity &Parent)
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002280 : Parent(&Parent), Index(Index)
Douglas Gregorcb57fb92009-12-16 06:35:08 +00002281{
Anders Carlssond3d824d2010-01-23 04:34:47 +00002282 if (const ArrayType *AT = Context.getAsArrayType(Parent.getType())) {
2283 Kind = EK_ArrayElement;
Douglas Gregord6542d82009-12-22 15:35:07 +00002284 Type = AT->getElementType();
Eli Friedman0c706c22011-09-19 23:17:44 +00002285 } else if (const VectorType *VT = Parent.getType()->getAs<VectorType>()) {
Anders Carlssond3d824d2010-01-23 04:34:47 +00002286 Kind = EK_VectorElement;
Eli Friedman0c706c22011-09-19 23:17:44 +00002287 Type = VT->getElementType();
2288 } else {
2289 const ComplexType *CT = Parent.getType()->getAs<ComplexType>();
2290 assert(CT && "Unexpected type");
2291 Kind = EK_ComplexElement;
2292 Type = CT->getElementType();
Anders Carlssond3d824d2010-01-23 04:34:47 +00002293 }
Douglas Gregor20093b42009-12-09 23:02:17 +00002294}
2295
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002296InitializedEntity InitializedEntity::InitializeBase(ASTContext &Context,
Anders Carlsson711f34a2010-04-21 19:52:01 +00002297 CXXBaseSpecifier *Base,
2298 bool IsInheritedVirtualBase)
Douglas Gregor20093b42009-12-09 23:02:17 +00002299{
2300 InitializedEntity Result;
2301 Result.Kind = EK_Base;
Anders Carlsson711f34a2010-04-21 19:52:01 +00002302 Result.Base = reinterpret_cast<uintptr_t>(Base);
2303 if (IsInheritedVirtualBase)
2304 Result.Base |= 0x01;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002305
Douglas Gregord6542d82009-12-22 15:35:07 +00002306 Result.Type = Base->getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00002307 return Result;
2308}
2309
Douglas Gregor99a2e602009-12-16 01:38:02 +00002310DeclarationName InitializedEntity::getName() const {
2311 switch (getKind()) {
John McCallf85e1932011-06-15 23:02:42 +00002312 case EK_Parameter: {
2313 ParmVarDecl *D = reinterpret_cast<ParmVarDecl*>(Parameter & ~0x1);
2314 return (D ? D->getDeclName() : DeclarationName());
2315 }
Douglas Gregora188ff22009-12-22 16:09:06 +00002316
2317 case EK_Variable:
Douglas Gregor99a2e602009-12-16 01:38:02 +00002318 case EK_Member:
2319 return VariableOrMember->getDeclName();
2320
Douglas Gregor47736542012-02-15 16:57:26 +00002321 case EK_LambdaCapture:
2322 return Capture.Var->getDeclName();
2323
Douglas Gregor99a2e602009-12-16 01:38:02 +00002324 case EK_Result:
2325 case EK_Exception:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00002326 case EK_New:
Douglas Gregor99a2e602009-12-16 01:38:02 +00002327 case EK_Temporary:
2328 case EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00002329 case EK_Delegating:
Anders Carlssond3d824d2010-01-23 04:34:47 +00002330 case EK_ArrayElement:
2331 case EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00002332 case EK_ComplexElement:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00002333 case EK_BlockElement:
Douglas Gregor99a2e602009-12-16 01:38:02 +00002334 return DeclarationName();
2335 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002336
David Blaikie7530c032012-01-17 06:56:22 +00002337 llvm_unreachable("Invalid EntityKind!");
Douglas Gregor99a2e602009-12-16 01:38:02 +00002338}
2339
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00002340DeclaratorDecl *InitializedEntity::getDecl() const {
2341 switch (getKind()) {
2342 case EK_Variable:
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00002343 case EK_Member:
2344 return VariableOrMember;
2345
John McCallf85e1932011-06-15 23:02:42 +00002346 case EK_Parameter:
2347 return reinterpret_cast<ParmVarDecl*>(Parameter & ~0x1);
2348
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00002349 case EK_Result:
2350 case EK_Exception:
2351 case EK_New:
2352 case EK_Temporary:
2353 case EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00002354 case EK_Delegating:
Anders Carlssond3d824d2010-01-23 04:34:47 +00002355 case EK_ArrayElement:
2356 case EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00002357 case EK_ComplexElement:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00002358 case EK_BlockElement:
Douglas Gregor47736542012-02-15 16:57:26 +00002359 case EK_LambdaCapture:
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00002360 return 0;
2361 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002362
David Blaikie7530c032012-01-17 06:56:22 +00002363 llvm_unreachable("Invalid EntityKind!");
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00002364}
2365
Douglas Gregor3c9034c2010-05-15 00:13:29 +00002366bool InitializedEntity::allowsNRVO() const {
2367 switch (getKind()) {
2368 case EK_Result:
2369 case EK_Exception:
2370 return LocAndNRVO.NRVO;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002371
Douglas Gregor3c9034c2010-05-15 00:13:29 +00002372 case EK_Variable:
2373 case EK_Parameter:
2374 case EK_Member:
2375 case EK_New:
2376 case EK_Temporary:
2377 case EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00002378 case EK_Delegating:
Douglas Gregor3c9034c2010-05-15 00:13:29 +00002379 case EK_ArrayElement:
2380 case EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00002381 case EK_ComplexElement:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00002382 case EK_BlockElement:
Douglas Gregor47736542012-02-15 16:57:26 +00002383 case EK_LambdaCapture:
Douglas Gregor3c9034c2010-05-15 00:13:29 +00002384 break;
2385 }
2386
2387 return false;
2388}
2389
Douglas Gregor20093b42009-12-09 23:02:17 +00002390//===----------------------------------------------------------------------===//
2391// Initialization sequence
2392//===----------------------------------------------------------------------===//
2393
2394void InitializationSequence::Step::Destroy() {
2395 switch (Kind) {
2396 case SK_ResolveAddressOfOverloadedFunction:
2397 case SK_CastDerivedToBaseRValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00002398 case SK_CastDerivedToBaseXValue:
Douglas Gregor20093b42009-12-09 23:02:17 +00002399 case SK_CastDerivedToBaseLValue:
2400 case SK_BindReference:
2401 case SK_BindReferenceToTemporary:
Douglas Gregor523d46a2010-04-18 07:40:54 +00002402 case SK_ExtraneousCopyToTemporary:
Douglas Gregor20093b42009-12-09 23:02:17 +00002403 case SK_UserConversion:
2404 case SK_QualificationConversionRValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00002405 case SK_QualificationConversionXValue:
Douglas Gregor20093b42009-12-09 23:02:17 +00002406 case SK_QualificationConversionLValue:
Douglas Gregord87b61f2009-12-10 17:56:55 +00002407 case SK_ListInitialization:
Sebastian Redl8713d4e2011-09-24 17:47:52 +00002408 case SK_ListConstructorCall:
Sebastian Redl13dc8f92011-11-27 16:50:07 +00002409 case SK_UnwrapInitList:
2410 case SK_RewrapInitList:
Douglas Gregor51c56d62009-12-14 20:49:26 +00002411 case SK_ConstructorInitialization:
Douglas Gregor71d17402009-12-15 00:01:57 +00002412 case SK_ZeroInitialization:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00002413 case SK_CAssignment:
Eli Friedmancfdc81a2009-12-19 08:11:05 +00002414 case SK_StringInit:
Douglas Gregor569c3162010-08-07 11:51:51 +00002415 case SK_ObjCObjectConversion:
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00002416 case SK_ArrayInit:
Richard Smith0f163e92012-02-15 22:38:09 +00002417 case SK_ParenthesizedArrayInit:
John McCallf85e1932011-06-15 23:02:42 +00002418 case SK_PassByIndirectCopyRestore:
2419 case SK_PassByIndirectRestore:
2420 case SK_ProduceObjCObject:
Sebastian Redl2b916b82012-01-17 22:49:42 +00002421 case SK_StdInitializerList:
Douglas Gregor20093b42009-12-09 23:02:17 +00002422 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002423
Douglas Gregor20093b42009-12-09 23:02:17 +00002424 case SK_ConversionSequence:
2425 delete ICS;
2426 }
2427}
2428
Douglas Gregorb70cf442010-03-26 20:14:36 +00002429bool InitializationSequence::isDirectReferenceBinding() const {
Sebastian Redl3b802322011-07-14 19:07:55 +00002430 return !Steps.empty() && Steps.back().Kind == SK_BindReference;
Douglas Gregorb70cf442010-03-26 20:14:36 +00002431}
2432
2433bool InitializationSequence::isAmbiguous() const {
Sebastian Redld695d6b2011-06-05 13:59:05 +00002434 if (!Failed())
Douglas Gregorb70cf442010-03-26 20:14:36 +00002435 return false;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002436
Douglas Gregorb70cf442010-03-26 20:14:36 +00002437 switch (getFailureKind()) {
2438 case FK_TooManyInitsForReference:
2439 case FK_ArrayNeedsInitList:
2440 case FK_ArrayNeedsInitListOrStringLiteral:
2441 case FK_AddressOfOverloadFailed: // FIXME: Could do better
2442 case FK_NonConstLValueReferenceBindingToTemporary:
2443 case FK_NonConstLValueReferenceBindingToUnrelated:
2444 case FK_RValueReferenceBindingToLValue:
2445 case FK_ReferenceInitDropsQualifiers:
2446 case FK_ReferenceInitFailed:
2447 case FK_ConversionFailed:
John Wiegley429bb272011-04-08 18:41:53 +00002448 case FK_ConversionFromPropertyFailed:
Douglas Gregorb70cf442010-03-26 20:14:36 +00002449 case FK_TooManyInitsForScalar:
2450 case FK_ReferenceBindingToInitList:
2451 case FK_InitListBadDestinationType:
2452 case FK_DefaultInitOfConst:
Douglas Gregor72a43bb2010-05-20 22:12:02 +00002453 case FK_Incomplete:
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00002454 case FK_ArrayTypeMismatch:
2455 case FK_NonConstantArrayInit:
Sebastian Redl8713d4e2011-09-24 17:47:52 +00002456 case FK_ListInitializationFailed:
John McCall73076432012-01-05 00:13:19 +00002457 case FK_VariableLengthArrayHasInitializer:
John McCall5acb0c92011-10-17 18:40:02 +00002458 case FK_PlaceholderType:
Sebastian Redl2b916b82012-01-17 22:49:42 +00002459 case FK_InitListElementCopyFailure:
Sebastian Redl70e24fc2012-04-01 19:54:59 +00002460 case FK_ExplicitConstructor:
Douglas Gregorb70cf442010-03-26 20:14:36 +00002461 return false;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002462
Douglas Gregorb70cf442010-03-26 20:14:36 +00002463 case FK_ReferenceInitOverloadFailed:
2464 case FK_UserConversionOverloadFailed:
2465 case FK_ConstructorOverloadFailed:
Sebastian Redlcf15cef2011-12-22 18:58:38 +00002466 case FK_ListConstructorOverloadFailed:
Douglas Gregorb70cf442010-03-26 20:14:36 +00002467 return FailedOverloadResult == OR_Ambiguous;
2468 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002469
David Blaikie7530c032012-01-17 06:56:22 +00002470 llvm_unreachable("Invalid EntityKind!");
Douglas Gregorb70cf442010-03-26 20:14:36 +00002471}
2472
Douglas Gregord6e44a32010-04-16 22:09:46 +00002473bool InitializationSequence::isConstructorInitialization() const {
2474 return !Steps.empty() && Steps.back().Kind == SK_ConstructorInitialization;
2475}
2476
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002477void
2478InitializationSequence
2479::AddAddressOverloadResolutionStep(FunctionDecl *Function,
2480 DeclAccessPair Found,
2481 bool HadMultipleCandidates) {
Douglas Gregor20093b42009-12-09 23:02:17 +00002482 Step S;
2483 S.Kind = SK_ResolveAddressOfOverloadedFunction;
2484 S.Type = Function->getType();
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002485 S.Function.HadMultipleCandidates = HadMultipleCandidates;
John McCall9aa472c2010-03-19 07:35:19 +00002486 S.Function.Function = Function;
John McCall6bb80172010-03-30 21:47:33 +00002487 S.Function.FoundDecl = Found;
Douglas Gregor20093b42009-12-09 23:02:17 +00002488 Steps.push_back(S);
2489}
2490
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002491void InitializationSequence::AddDerivedToBaseCastStep(QualType BaseType,
John McCall5baba9d2010-08-25 10:28:54 +00002492 ExprValueKind VK) {
Douglas Gregor20093b42009-12-09 23:02:17 +00002493 Step S;
John McCall5baba9d2010-08-25 10:28:54 +00002494 switch (VK) {
2495 case VK_RValue: S.Kind = SK_CastDerivedToBaseRValue; break;
2496 case VK_XValue: S.Kind = SK_CastDerivedToBaseXValue; break;
2497 case VK_LValue: S.Kind = SK_CastDerivedToBaseLValue; break;
Sebastian Redl906082e2010-07-20 04:20:21 +00002498 }
Douglas Gregor20093b42009-12-09 23:02:17 +00002499 S.Type = BaseType;
2500 Steps.push_back(S);
2501}
2502
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002503void InitializationSequence::AddReferenceBindingStep(QualType T,
Douglas Gregor20093b42009-12-09 23:02:17 +00002504 bool BindingTemporary) {
2505 Step S;
2506 S.Kind = BindingTemporary? SK_BindReferenceToTemporary : SK_BindReference;
2507 S.Type = T;
2508 Steps.push_back(S);
2509}
2510
Douglas Gregor523d46a2010-04-18 07:40:54 +00002511void InitializationSequence::AddExtraneousCopyToTemporary(QualType T) {
2512 Step S;
2513 S.Kind = SK_ExtraneousCopyToTemporary;
2514 S.Type = T;
2515 Steps.push_back(S);
2516}
2517
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002518void
2519InitializationSequence::AddUserConversionStep(FunctionDecl *Function,
2520 DeclAccessPair FoundDecl,
2521 QualType T,
2522 bool HadMultipleCandidates) {
Douglas Gregor20093b42009-12-09 23:02:17 +00002523 Step S;
2524 S.Kind = SK_UserConversion;
Eli Friedman03981012009-12-11 02:42:07 +00002525 S.Type = T;
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002526 S.Function.HadMultipleCandidates = HadMultipleCandidates;
John McCall9aa472c2010-03-19 07:35:19 +00002527 S.Function.Function = Function;
2528 S.Function.FoundDecl = FoundDecl;
Douglas Gregor20093b42009-12-09 23:02:17 +00002529 Steps.push_back(S);
2530}
2531
2532void InitializationSequence::AddQualificationConversionStep(QualType Ty,
John McCall5baba9d2010-08-25 10:28:54 +00002533 ExprValueKind VK) {
Douglas Gregor20093b42009-12-09 23:02:17 +00002534 Step S;
John McCall38a4ffe2010-08-26 16:36:35 +00002535 S.Kind = SK_QualificationConversionRValue; // work around a gcc warning
John McCall5baba9d2010-08-25 10:28:54 +00002536 switch (VK) {
2537 case VK_RValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00002538 S.Kind = SK_QualificationConversionRValue;
2539 break;
John McCall5baba9d2010-08-25 10:28:54 +00002540 case VK_XValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00002541 S.Kind = SK_QualificationConversionXValue;
2542 break;
John McCall5baba9d2010-08-25 10:28:54 +00002543 case VK_LValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00002544 S.Kind = SK_QualificationConversionLValue;
2545 break;
Sebastian Redl906082e2010-07-20 04:20:21 +00002546 }
Douglas Gregor20093b42009-12-09 23:02:17 +00002547 S.Type = Ty;
2548 Steps.push_back(S);
2549}
2550
2551void InitializationSequence::AddConversionSequenceStep(
2552 const ImplicitConversionSequence &ICS,
2553 QualType T) {
2554 Step S;
2555 S.Kind = SK_ConversionSequence;
2556 S.Type = T;
2557 S.ICS = new ImplicitConversionSequence(ICS);
2558 Steps.push_back(S);
2559}
2560
Douglas Gregord87b61f2009-12-10 17:56:55 +00002561void InitializationSequence::AddListInitializationStep(QualType T) {
2562 Step S;
2563 S.Kind = SK_ListInitialization;
2564 S.Type = T;
2565 Steps.push_back(S);
2566}
2567
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002568void
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002569InitializationSequence
2570::AddConstructorInitializationStep(CXXConstructorDecl *Constructor,
2571 AccessSpecifier Access,
2572 QualType T,
Sebastian Redl10f04a62011-12-22 14:44:04 +00002573 bool HadMultipleCandidates,
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002574 bool FromInitList, bool AsInitList) {
Douglas Gregor51c56d62009-12-14 20:49:26 +00002575 Step S;
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002576 S.Kind = FromInitList && !AsInitList ? SK_ListConstructorCall
2577 : SK_ConstructorInitialization;
Douglas Gregor51c56d62009-12-14 20:49:26 +00002578 S.Type = T;
Abramo Bagnara22c107b2011-11-19 11:44:21 +00002579 S.Function.HadMultipleCandidates = HadMultipleCandidates;
John McCall9aa472c2010-03-19 07:35:19 +00002580 S.Function.Function = Constructor;
2581 S.Function.FoundDecl = DeclAccessPair::make(Constructor, Access);
Douglas Gregor51c56d62009-12-14 20:49:26 +00002582 Steps.push_back(S);
2583}
2584
Douglas Gregor71d17402009-12-15 00:01:57 +00002585void InitializationSequence::AddZeroInitializationStep(QualType T) {
2586 Step S;
2587 S.Kind = SK_ZeroInitialization;
2588 S.Type = T;
2589 Steps.push_back(S);
2590}
2591
Douglas Gregor18ef5e22009-12-18 05:02:21 +00002592void InitializationSequence::AddCAssignmentStep(QualType T) {
2593 Step S;
2594 S.Kind = SK_CAssignment;
2595 S.Type = T;
2596 Steps.push_back(S);
2597}
2598
Eli Friedmancfdc81a2009-12-19 08:11:05 +00002599void InitializationSequence::AddStringInitStep(QualType T) {
2600 Step S;
2601 S.Kind = SK_StringInit;
2602 S.Type = T;
2603 Steps.push_back(S);
2604}
2605
Douglas Gregor569c3162010-08-07 11:51:51 +00002606void InitializationSequence::AddObjCObjectConversionStep(QualType T) {
2607 Step S;
2608 S.Kind = SK_ObjCObjectConversion;
2609 S.Type = T;
2610 Steps.push_back(S);
2611}
2612
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00002613void InitializationSequence::AddArrayInitStep(QualType T) {
2614 Step S;
2615 S.Kind = SK_ArrayInit;
2616 S.Type = T;
2617 Steps.push_back(S);
2618}
2619
Richard Smith0f163e92012-02-15 22:38:09 +00002620void InitializationSequence::AddParenthesizedArrayInitStep(QualType T) {
2621 Step S;
2622 S.Kind = SK_ParenthesizedArrayInit;
2623 S.Type = T;
2624 Steps.push_back(S);
2625}
2626
John McCallf85e1932011-06-15 23:02:42 +00002627void InitializationSequence::AddPassByIndirectCopyRestoreStep(QualType type,
2628 bool shouldCopy) {
2629 Step s;
2630 s.Kind = (shouldCopy ? SK_PassByIndirectCopyRestore
2631 : SK_PassByIndirectRestore);
2632 s.Type = type;
2633 Steps.push_back(s);
2634}
2635
2636void InitializationSequence::AddProduceObjCObjectStep(QualType T) {
2637 Step S;
2638 S.Kind = SK_ProduceObjCObject;
2639 S.Type = T;
2640 Steps.push_back(S);
2641}
2642
Sebastian Redl2b916b82012-01-17 22:49:42 +00002643void InitializationSequence::AddStdInitializerListConstructionStep(QualType T) {
2644 Step S;
2645 S.Kind = SK_StdInitializerList;
2646 S.Type = T;
2647 Steps.push_back(S);
2648}
2649
Sebastian Redl13dc8f92011-11-27 16:50:07 +00002650void InitializationSequence::RewrapReferenceInitList(QualType T,
2651 InitListExpr *Syntactic) {
2652 assert(Syntactic->getNumInits() == 1 &&
2653 "Can only rewrap trivial init lists.");
2654 Step S;
2655 S.Kind = SK_UnwrapInitList;
2656 S.Type = Syntactic->getInit(0)->getType();
2657 Steps.insert(Steps.begin(), S);
2658
2659 S.Kind = SK_RewrapInitList;
2660 S.Type = T;
2661 S.WrappingSyntacticList = Syntactic;
2662 Steps.push_back(S);
2663}
2664
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00002665void InitializationSequence::SetOverloadFailure(FailureKind Failure,
Douglas Gregor20093b42009-12-09 23:02:17 +00002666 OverloadingResult Result) {
Sebastian Redl7491c492011-06-05 13:59:11 +00002667 setSequenceKind(FailedSequence);
Douglas Gregor20093b42009-12-09 23:02:17 +00002668 this->Failure = Failure;
2669 this->FailedOverloadResult = Result;
2670}
2671
2672//===----------------------------------------------------------------------===//
2673// Attempt initialization
2674//===----------------------------------------------------------------------===//
2675
John McCallf85e1932011-06-15 23:02:42 +00002676static void MaybeProduceObjCObject(Sema &S,
2677 InitializationSequence &Sequence,
2678 const InitializedEntity &Entity) {
David Blaikie4e4d0842012-03-11 07:00:24 +00002679 if (!S.getLangOpts().ObjCAutoRefCount) return;
John McCallf85e1932011-06-15 23:02:42 +00002680
2681 /// When initializing a parameter, produce the value if it's marked
2682 /// __attribute__((ns_consumed)).
2683 if (Entity.getKind() == InitializedEntity::EK_Parameter) {
2684 if (!Entity.isParameterConsumed())
2685 return;
2686
2687 assert(Entity.getType()->isObjCRetainableType() &&
2688 "consuming an object of unretainable type?");
2689 Sequence.AddProduceObjCObjectStep(Entity.getType());
2690
2691 /// When initializing a return value, if the return type is a
2692 /// retainable type, then returns need to immediately retain the
2693 /// object. If an autorelease is required, it will be done at the
2694 /// last instant.
2695 } else if (Entity.getKind() == InitializedEntity::EK_Result) {
2696 if (!Entity.getType()->isObjCRetainableType())
2697 return;
2698
2699 Sequence.AddProduceObjCObjectStep(Entity.getType());
2700 }
2701}
2702
Richard Smithf4bb8d02012-07-05 08:39:21 +00002703/// \brief When initializing from init list via constructor, handle
2704/// initialization of an object of type std::initializer_list<T>.
Sebastian Redl10f04a62011-12-22 14:44:04 +00002705///
Richard Smithf4bb8d02012-07-05 08:39:21 +00002706/// \return true if we have handled initialization of an object of type
2707/// std::initializer_list<T>, false otherwise.
2708static bool TryInitializerListConstruction(Sema &S,
2709 InitListExpr *List,
2710 QualType DestType,
2711 InitializationSequence &Sequence) {
2712 QualType E;
2713 if (!S.isStdInitializerList(DestType, &E))
Richard Smith1d0c9a82012-02-14 21:14:13 +00002714 return false;
2715
Richard Smithf4bb8d02012-07-05 08:39:21 +00002716 // Check that each individual element can be copy-constructed. But since we
2717 // have no place to store further information, we'll recalculate everything
2718 // later.
2719 InitializedEntity HiddenArray = InitializedEntity::InitializeTemporary(
2720 S.Context.getConstantArrayType(E,
2721 llvm::APInt(S.Context.getTypeSize(S.Context.getSizeType()),
2722 List->getNumInits()),
2723 ArrayType::Normal, 0));
2724 InitializedEntity Element = InitializedEntity::InitializeElement(S.Context,
2725 0, HiddenArray);
2726 for (unsigned i = 0, n = List->getNumInits(); i < n; ++i) {
2727 Element.setElementIndex(i);
2728 if (!S.CanPerformCopyInitialization(Element, List->getInit(i))) {
2729 Sequence.SetFailed(
2730 InitializationSequence::FK_InitListElementCopyFailure);
Sebastian Redl10f04a62011-12-22 14:44:04 +00002731 return true;
2732 }
2733 }
Richard Smithf4bb8d02012-07-05 08:39:21 +00002734 Sequence.AddStdInitializerListConstructionStep(DestType);
2735 return true;
Sebastian Redl10f04a62011-12-22 14:44:04 +00002736}
2737
Sebastian Redl96715b22012-02-04 21:27:39 +00002738static OverloadingResult
2739ResolveConstructorOverload(Sema &S, SourceLocation DeclLoc,
2740 Expr **Args, unsigned NumArgs,
2741 OverloadCandidateSet &CandidateSet,
2742 DeclContext::lookup_iterator Con,
2743 DeclContext::lookup_iterator ConEnd,
2744 OverloadCandidateSet::iterator &Best,
2745 bool CopyInitializing, bool AllowExplicit,
Sebastian Redl51ad9cd2012-02-29 12:47:43 +00002746 bool OnlyListConstructors, bool InitListSyntax) {
Sebastian Redl96715b22012-02-04 21:27:39 +00002747 CandidateSet.clear();
2748
2749 for (; Con != ConEnd; ++Con) {
2750 NamedDecl *D = *Con;
2751 DeclAccessPair FoundDecl = DeclAccessPair::make(D, D->getAccess());
2752 bool SuppressUserConversions = false;
2753
2754 // Find the constructor (which may be a template).
2755 CXXConstructorDecl *Constructor = 0;
2756 FunctionTemplateDecl *ConstructorTmpl = dyn_cast<FunctionTemplateDecl>(D);
2757 if (ConstructorTmpl)
2758 Constructor = cast<CXXConstructorDecl>(
2759 ConstructorTmpl->getTemplatedDecl());
2760 else {
2761 Constructor = cast<CXXConstructorDecl>(D);
2762
2763 // If we're performing copy initialization using a copy constructor, we
Sebastian Redl51ad9cd2012-02-29 12:47:43 +00002764 // suppress user-defined conversions on the arguments. We do the same for
2765 // move constructors.
2766 if ((CopyInitializing || (InitListSyntax && NumArgs == 1)) &&
2767 Constructor->isCopyOrMoveConstructor())
Sebastian Redl96715b22012-02-04 21:27:39 +00002768 SuppressUserConversions = true;
2769 }
2770
2771 if (!Constructor->isInvalidDecl() &&
2772 (AllowExplicit || !Constructor->isExplicit()) &&
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002773 (!OnlyListConstructors || S.isInitListConstructor(Constructor))) {
Sebastian Redl96715b22012-02-04 21:27:39 +00002774 if (ConstructorTmpl)
2775 S.AddTemplateOverloadCandidate(ConstructorTmpl, FoundDecl,
2776 /*ExplicitArgs*/ 0,
Sebastian Redl51ad9cd2012-02-29 12:47:43 +00002777 llvm::makeArrayRef(Args, NumArgs),
2778 CandidateSet, SuppressUserConversions);
Douglas Gregored878af2012-02-24 23:56:31 +00002779 else {
2780 // C++ [over.match.copy]p1:
2781 // - When initializing a temporary to be bound to the first parameter
2782 // of a constructor that takes a reference to possibly cv-qualified
2783 // T as its first argument, called with a single argument in the
2784 // context of direct-initialization, explicit conversion functions
2785 // are also considered.
2786 bool AllowExplicitConv = AllowExplicit && !CopyInitializing &&
2787 NumArgs == 1 &&
2788 Constructor->isCopyOrMoveConstructor();
Sebastian Redl96715b22012-02-04 21:27:39 +00002789 S.AddOverloadCandidate(Constructor, FoundDecl,
Ahmed Charles13a140c2012-02-25 11:00:22 +00002790 llvm::makeArrayRef(Args, NumArgs), CandidateSet,
Douglas Gregored878af2012-02-24 23:56:31 +00002791 SuppressUserConversions,
2792 /*PartialOverloading=*/false,
2793 /*AllowExplicit=*/AllowExplicitConv);
2794 }
Sebastian Redl96715b22012-02-04 21:27:39 +00002795 }
2796 }
2797
2798 // Perform overload resolution and return the result.
2799 return CandidateSet.BestViableFunction(S, DeclLoc, Best);
2800}
2801
Sebastian Redl10f04a62011-12-22 14:44:04 +00002802/// \brief Attempt initialization by constructor (C++ [dcl.init]), which
2803/// enumerates the constructors of the initialized entity and performs overload
2804/// resolution to select the best.
Sebastian Redl08ae3692012-02-04 21:27:33 +00002805/// If InitListSyntax is true, this is list-initialization of a non-aggregate
Sebastian Redl10f04a62011-12-22 14:44:04 +00002806/// class type.
2807static void TryConstructorInitialization(Sema &S,
2808 const InitializedEntity &Entity,
2809 const InitializationKind &Kind,
2810 Expr **Args, unsigned NumArgs,
2811 QualType DestType,
2812 InitializationSequence &Sequence,
Sebastian Redl08ae3692012-02-04 21:27:33 +00002813 bool InitListSyntax = false) {
2814 assert((!InitListSyntax || (NumArgs == 1 && isa<InitListExpr>(Args[0]))) &&
2815 "InitListSyntax must come with a single initializer list argument.");
2816
Sebastian Redl10f04a62011-12-22 14:44:04 +00002817 // Check constructor arguments for self reference.
2818 if (DeclaratorDecl *DD = Entity.getDecl())
2819 // Parameters arguments are occassionially constructed with itself,
2820 // for instance, in recursive functions. Skip them.
2821 if (!isa<ParmVarDecl>(DD))
2822 for (unsigned i = 0; i < NumArgs; ++i)
2823 S.CheckSelfReference(DD, Args[i]);
2824
Sebastian Redl10f04a62011-12-22 14:44:04 +00002825 // The type we're constructing needs to be complete.
2826 if (S.RequireCompleteType(Kind.getLocation(), DestType, 0)) {
Douglas Gregor69a30b82012-04-10 20:43:46 +00002827 Sequence.setIncompleteTypeFailure(DestType);
Sebastian Redl96715b22012-02-04 21:27:39 +00002828 return;
Sebastian Redl10f04a62011-12-22 14:44:04 +00002829 }
2830
2831 const RecordType *DestRecordType = DestType->getAs<RecordType>();
2832 assert(DestRecordType && "Constructor initialization requires record type");
2833 CXXRecordDecl *DestRecordDecl
2834 = cast<CXXRecordDecl>(DestRecordType->getDecl());
2835
Sebastian Redl96715b22012-02-04 21:27:39 +00002836 // Build the candidate set directly in the initialization sequence
2837 // structure, so that it will persist if we fail.
2838 OverloadCandidateSet &CandidateSet = Sequence.getFailedCandidateSet();
2839
2840 // Determine whether we are allowed to call explicit constructors or
2841 // explicit conversion operators.
Sebastian Redl70e24fc2012-04-01 19:54:59 +00002842 bool AllowExplicit = Kind.AllowExplicit() || InitListSyntax;
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002843 bool CopyInitialization = Kind.getKind() == InitializationKind::IK_Copy;
Sebastian Redl08ae3692012-02-04 21:27:33 +00002844
Sebastian Redl10f04a62011-12-22 14:44:04 +00002845 // - Otherwise, if T is a class type, constructors are considered. The
2846 // applicable constructors are enumerated, and the best one is chosen
2847 // through overload resolution.
Sebastian Redl96715b22012-02-04 21:27:39 +00002848 DeclContext::lookup_iterator ConStart, ConEnd;
2849 llvm::tie(ConStart, ConEnd) = S.LookupConstructors(DestRecordDecl);
Sebastian Redl10f04a62011-12-22 14:44:04 +00002850
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002851 OverloadingResult Result = OR_No_Viable_Function;
Sebastian Redl10f04a62011-12-22 14:44:04 +00002852 OverloadCandidateSet::iterator Best;
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002853 bool AsInitializerList = false;
2854
2855 // C++11 [over.match.list]p1:
2856 // When objects of non-aggregate type T are list-initialized, overload
2857 // resolution selects the constructor in two phases:
2858 // - Initially, the candidate functions are the initializer-list
2859 // constructors of the class T and the argument list consists of the
2860 // initializer list as a single argument.
2861 if (InitListSyntax) {
Richard Smithf4bb8d02012-07-05 08:39:21 +00002862 InitListExpr *ILE = cast<InitListExpr>(Args[0]);
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002863 AsInitializerList = true;
Richard Smithf4bb8d02012-07-05 08:39:21 +00002864
2865 // If the initializer list has no elements and T has a default constructor,
2866 // the first phase is omitted.
2867 if (ILE->getNumInits() != 0 ||
2868 (!DestRecordDecl->hasDeclaredDefaultConstructor() &&
2869 !DestRecordDecl->needsImplicitDefaultConstructor()))
2870 Result = ResolveConstructorOverload(S, Kind.getLocation(), Args, NumArgs,
2871 CandidateSet, ConStart, ConEnd, Best,
2872 CopyInitialization, AllowExplicit,
2873 /*OnlyListConstructor=*/true,
2874 InitListSyntax);
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002875
2876 // Time to unwrap the init list.
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002877 Args = ILE->getInits();
2878 NumArgs = ILE->getNumInits();
2879 }
2880
2881 // C++11 [over.match.list]p1:
2882 // - If no viable initializer-list constructor is found, overload resolution
2883 // is performed again, where the candidate functions are all the
Richard Smithf4bb8d02012-07-05 08:39:21 +00002884 // constructors of the class T and the argument list consists of the
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002885 // elements of the initializer list.
2886 if (Result == OR_No_Viable_Function) {
2887 AsInitializerList = false;
2888 Result = ResolveConstructorOverload(S, Kind.getLocation(), Args, NumArgs,
2889 CandidateSet, ConStart, ConEnd, Best,
2890 CopyInitialization, AllowExplicit,
Sebastian Redl51ad9cd2012-02-29 12:47:43 +00002891 /*OnlyListConstructors=*/false,
2892 InitListSyntax);
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002893 }
2894 if (Result) {
Sebastian Redl08ae3692012-02-04 21:27:33 +00002895 Sequence.SetOverloadFailure(InitListSyntax ?
Sebastian Redlcf15cef2011-12-22 18:58:38 +00002896 InitializationSequence::FK_ListConstructorOverloadFailed :
2897 InitializationSequence::FK_ConstructorOverloadFailed,
Sebastian Redl10f04a62011-12-22 14:44:04 +00002898 Result);
2899 return;
2900 }
2901
Richard Smithf4bb8d02012-07-05 08:39:21 +00002902 // C++11 [dcl.init]p6:
Sebastian Redl10f04a62011-12-22 14:44:04 +00002903 // If a program calls for the default initialization of an object
2904 // of a const-qualified type T, T shall be a class type with a
2905 // user-provided default constructor.
2906 if (Kind.getKind() == InitializationKind::IK_Default &&
2907 Entity.getType().isConstQualified() &&
Aaron Ballman51217812012-07-31 22:40:31 +00002908 !cast<CXXConstructorDecl>(Best->Function)->isUserProvided()) {
Sebastian Redl10f04a62011-12-22 14:44:04 +00002909 Sequence.SetFailed(InitializationSequence::FK_DefaultInitOfConst);
2910 return;
2911 }
2912
Sebastian Redl70e24fc2012-04-01 19:54:59 +00002913 // C++11 [over.match.list]p1:
2914 // In copy-list-initialization, if an explicit constructor is chosen, the
2915 // initializer is ill-formed.
2916 CXXConstructorDecl *CtorDecl = cast<CXXConstructorDecl>(Best->Function);
2917 if (InitListSyntax && !Kind.AllowExplicit() && CtorDecl->isExplicit()) {
2918 Sequence.SetFailed(InitializationSequence::FK_ExplicitConstructor);
2919 return;
2920 }
2921
Sebastian Redl10f04a62011-12-22 14:44:04 +00002922 // Add the constructor initialization step. Any cv-qualification conversion is
2923 // subsumed by the initialization.
2924 bool HadMultipleCandidates = (CandidateSet.size() > 1);
Sebastian Redl10f04a62011-12-22 14:44:04 +00002925 Sequence.AddConstructorInitializationStep(CtorDecl,
2926 Best->FoundDecl.getAccess(),
2927 DestType, HadMultipleCandidates,
Sebastian Redl6cd03db2012-02-04 21:27:47 +00002928 InitListSyntax, AsInitializerList);
Sebastian Redl10f04a62011-12-22 14:44:04 +00002929}
2930
Sebastian Redl13dc8f92011-11-27 16:50:07 +00002931static bool
2932ResolveOverloadedFunctionForReferenceBinding(Sema &S,
2933 Expr *Initializer,
2934 QualType &SourceType,
2935 QualType &UnqualifiedSourceType,
2936 QualType UnqualifiedTargetType,
2937 InitializationSequence &Sequence) {
2938 if (S.Context.getCanonicalType(UnqualifiedSourceType) ==
2939 S.Context.OverloadTy) {
2940 DeclAccessPair Found;
2941 bool HadMultipleCandidates = false;
2942 if (FunctionDecl *Fn
2943 = S.ResolveAddressOfOverloadedFunction(Initializer,
2944 UnqualifiedTargetType,
2945 false, Found,
2946 &HadMultipleCandidates)) {
2947 Sequence.AddAddressOverloadResolutionStep(Fn, Found,
2948 HadMultipleCandidates);
2949 SourceType = Fn->getType();
2950 UnqualifiedSourceType = SourceType.getUnqualifiedType();
2951 } else if (!UnqualifiedTargetType->isRecordType()) {
2952 Sequence.SetFailed(InitializationSequence::FK_AddressOfOverloadFailed);
2953 return true;
2954 }
2955 }
2956 return false;
2957}
2958
2959static void TryReferenceInitializationCore(Sema &S,
2960 const InitializedEntity &Entity,
2961 const InitializationKind &Kind,
2962 Expr *Initializer,
2963 QualType cv1T1, QualType T1,
2964 Qualifiers T1Quals,
2965 QualType cv2T2, QualType T2,
2966 Qualifiers T2Quals,
2967 InitializationSequence &Sequence);
2968
Richard Smithf4bb8d02012-07-05 08:39:21 +00002969static void TryValueInitialization(Sema &S,
2970 const InitializedEntity &Entity,
2971 const InitializationKind &Kind,
2972 InitializationSequence &Sequence,
2973 InitListExpr *InitList = 0);
2974
Sebastian Redl13dc8f92011-11-27 16:50:07 +00002975static void TryListInitialization(Sema &S,
2976 const InitializedEntity &Entity,
2977 const InitializationKind &Kind,
2978 InitListExpr *InitList,
2979 InitializationSequence &Sequence);
2980
2981/// \brief Attempt list initialization of a reference.
2982static void TryReferenceListInitialization(Sema &S,
2983 const InitializedEntity &Entity,
2984 const InitializationKind &Kind,
2985 InitListExpr *InitList,
2986 InitializationSequence &Sequence)
2987{
2988 // First, catch C++03 where this isn't possible.
David Blaikie4e4d0842012-03-11 07:00:24 +00002989 if (!S.getLangOpts().CPlusPlus0x) {
Sebastian Redl13dc8f92011-11-27 16:50:07 +00002990 Sequence.SetFailed(InitializationSequence::FK_ReferenceBindingToInitList);
2991 return;
2992 }
2993
2994 QualType DestType = Entity.getType();
2995 QualType cv1T1 = DestType->getAs<ReferenceType>()->getPointeeType();
2996 Qualifiers T1Quals;
2997 QualType T1 = S.Context.getUnqualifiedArrayType(cv1T1, T1Quals);
2998
2999 // Reference initialization via an initializer list works thus:
3000 // If the initializer list consists of a single element that is
3001 // reference-related to the referenced type, bind directly to that element
3002 // (possibly creating temporaries).
3003 // Otherwise, initialize a temporary with the initializer list and
3004 // bind to that.
3005 if (InitList->getNumInits() == 1) {
3006 Expr *Initializer = InitList->getInit(0);
3007 QualType cv2T2 = Initializer->getType();
3008 Qualifiers T2Quals;
3009 QualType T2 = S.Context.getUnqualifiedArrayType(cv2T2, T2Quals);
3010
3011 // If this fails, creating a temporary wouldn't work either.
3012 if (ResolveOverloadedFunctionForReferenceBinding(S, Initializer, cv2T2, T2,
3013 T1, Sequence))
3014 return;
3015
3016 SourceLocation DeclLoc = Initializer->getLocStart();
3017 bool dummy1, dummy2, dummy3;
3018 Sema::ReferenceCompareResult RefRelationship
3019 = S.CompareReferenceRelationship(DeclLoc, cv1T1, cv2T2, dummy1,
3020 dummy2, dummy3);
3021 if (RefRelationship >= Sema::Ref_Related) {
3022 // Try to bind the reference here.
3023 TryReferenceInitializationCore(S, Entity, Kind, Initializer, cv1T1, T1,
3024 T1Quals, cv2T2, T2, T2Quals, Sequence);
3025 if (Sequence)
3026 Sequence.RewrapReferenceInitList(cv1T1, InitList);
3027 return;
3028 }
3029 }
3030
3031 // Not reference-related. Create a temporary and bind to that.
3032 InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(cv1T1);
3033
3034 TryListInitialization(S, TempEntity, Kind, InitList, Sequence);
3035 if (Sequence) {
3036 if (DestType->isRValueReferenceType() ||
3037 (T1Quals.hasConst() && !T1Quals.hasVolatile()))
3038 Sequence.AddReferenceBindingStep(cv1T1, /*bindingTemporary=*/true);
3039 else
3040 Sequence.SetFailed(
3041 InitializationSequence::FK_NonConstLValueReferenceBindingToTemporary);
3042 }
3043}
3044
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003045/// \brief Attempt list initialization (C++0x [dcl.init.list])
3046static void TryListInitialization(Sema &S,
3047 const InitializedEntity &Entity,
3048 const InitializationKind &Kind,
3049 InitListExpr *InitList,
3050 InitializationSequence &Sequence) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003051 QualType DestType = Entity.getType();
3052
Sebastian Redl14b0c192011-09-24 17:48:00 +00003053 // C++ doesn't allow scalar initialization with more than one argument.
3054 // But C99 complex numbers are scalars and it makes sense there.
David Blaikie4e4d0842012-03-11 07:00:24 +00003055 if (S.getLangOpts().CPlusPlus && DestType->isScalarType() &&
Sebastian Redl14b0c192011-09-24 17:48:00 +00003056 !DestType->isAnyComplexType() && InitList->getNumInits() > 1) {
3057 Sequence.SetFailed(InitializationSequence::FK_TooManyInitsForScalar);
3058 return;
3059 }
Sebastian Redl14b0c192011-09-24 17:48:00 +00003060 if (DestType->isReferenceType()) {
Sebastian Redl13dc8f92011-11-27 16:50:07 +00003061 TryReferenceListInitialization(S, Entity, Kind, InitList, Sequence);
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003062 return;
Sebastian Redl14b0c192011-09-24 17:48:00 +00003063 }
Sebastian Redld2231c92012-02-19 12:27:43 +00003064 if (DestType->isRecordType()) {
Douglas Gregord10099e2012-05-04 16:32:21 +00003065 if (S.RequireCompleteType(InitList->getLocStart(), DestType, 0)) {
Douglas Gregor69a30b82012-04-10 20:43:46 +00003066 Sequence.setIncompleteTypeFailure(DestType);
Sebastian Redld2231c92012-02-19 12:27:43 +00003067 return;
3068 }
3069
Richard Smithf4bb8d02012-07-05 08:39:21 +00003070 // C++11 [dcl.init.list]p3:
3071 // - If T is an aggregate, aggregate initialization is performed.
Sebastian Redld2231c92012-02-19 12:27:43 +00003072 if (!DestType->isAggregateType()) {
David Blaikie4e4d0842012-03-11 07:00:24 +00003073 if (S.getLangOpts().CPlusPlus0x) {
Richard Smithf4bb8d02012-07-05 08:39:21 +00003074 // - Otherwise, if the initializer list has no elements and T is a
3075 // class type with a default constructor, the object is
3076 // value-initialized.
3077 if (InitList->getNumInits() == 0) {
3078 CXXRecordDecl *RD = DestType->getAsCXXRecordDecl();
3079 if (RD->hasDeclaredDefaultConstructor() ||
3080 RD->needsImplicitDefaultConstructor()) {
3081 TryValueInitialization(S, Entity, Kind, Sequence, InitList);
3082 return;
3083 }
3084 }
3085
3086 // - Otherwise, if T is a specialization of std::initializer_list<E>,
3087 // an initializer_list object constructed [...]
3088 if (TryInitializerListConstruction(S, InitList, DestType, Sequence))
3089 return;
3090
3091 // - Otherwise, if T is a class type, constructors are considered.
Sebastian Redld2231c92012-02-19 12:27:43 +00003092 Expr *Arg = InitList;
Richard Smithf4bb8d02012-07-05 08:39:21 +00003093 TryConstructorInitialization(S, Entity, Kind, &Arg, 1, DestType,
3094 Sequence, /*InitListSyntax*/true);
Sebastian Redld2231c92012-02-19 12:27:43 +00003095 } else
3096 Sequence.SetFailed(
3097 InitializationSequence::FK_InitListBadDestinationType);
3098 return;
3099 }
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003100 }
3101
Sebastian Redl14b0c192011-09-24 17:48:00 +00003102 InitListChecker CheckInitList(S, Entity, InitList,
Sebastian Redlc2235182011-10-16 18:19:28 +00003103 DestType, /*VerifyOnly=*/true,
Sebastian Redl168319c2012-02-12 16:37:24 +00003104 Kind.getKind() != InitializationKind::IK_DirectList ||
David Blaikie4e4d0842012-03-11 07:00:24 +00003105 !S.getLangOpts().CPlusPlus0x);
Sebastian Redl14b0c192011-09-24 17:48:00 +00003106 if (CheckInitList.HadError()) {
3107 Sequence.SetFailed(InitializationSequence::FK_ListInitializationFailed);
3108 return;
3109 }
3110
3111 // Add the list initialization step with the built init list.
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003112 Sequence.AddListInitializationStep(DestType);
3113}
Douglas Gregor20093b42009-12-09 23:02:17 +00003114
3115/// \brief Try a reference initialization that involves calling a conversion
3116/// function.
Douglas Gregor20093b42009-12-09 23:02:17 +00003117static OverloadingResult TryRefInitWithConversionFunction(Sema &S,
3118 const InitializedEntity &Entity,
3119 const InitializationKind &Kind,
Douglas Gregored878af2012-02-24 23:56:31 +00003120 Expr *Initializer,
3121 bool AllowRValues,
Douglas Gregor20093b42009-12-09 23:02:17 +00003122 InitializationSequence &Sequence) {
Douglas Gregord6542d82009-12-22 15:35:07 +00003123 QualType DestType = Entity.getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00003124 QualType cv1T1 = DestType->getAs<ReferenceType>()->getPointeeType();
3125 QualType T1 = cv1T1.getUnqualifiedType();
3126 QualType cv2T2 = Initializer->getType();
3127 QualType T2 = cv2T2.getUnqualifiedType();
3128
3129 bool DerivedToBase;
Douglas Gregor569c3162010-08-07 11:51:51 +00003130 bool ObjCConversion;
John McCallf85e1932011-06-15 23:02:42 +00003131 bool ObjCLifetimeConversion;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003132 assert(!S.CompareReferenceRelationship(Initializer->getLocStart(),
Douglas Gregor569c3162010-08-07 11:51:51 +00003133 T1, T2, DerivedToBase,
John McCallf85e1932011-06-15 23:02:42 +00003134 ObjCConversion,
3135 ObjCLifetimeConversion) &&
Douglas Gregor20093b42009-12-09 23:02:17 +00003136 "Must have incompatible references when binding via conversion");
Chandler Carruth60cfcec2009-12-13 01:37:04 +00003137 (void)DerivedToBase;
Douglas Gregor569c3162010-08-07 11:51:51 +00003138 (void)ObjCConversion;
John McCallf85e1932011-06-15 23:02:42 +00003139 (void)ObjCLifetimeConversion;
3140
Douglas Gregor20093b42009-12-09 23:02:17 +00003141 // Build the candidate set directly in the initialization sequence
3142 // structure, so that it will persist if we fail.
3143 OverloadCandidateSet &CandidateSet = Sequence.getFailedCandidateSet();
3144 CandidateSet.clear();
3145
3146 // Determine whether we are allowed to call explicit constructors or
3147 // explicit conversion operators.
Sebastian Redl168319c2012-02-12 16:37:24 +00003148 bool AllowExplicit = Kind.AllowExplicit();
Douglas Gregored878af2012-02-24 23:56:31 +00003149 bool AllowExplicitConvs = Kind.allowExplicitConversionFunctions();
3150
Douglas Gregor20093b42009-12-09 23:02:17 +00003151 const RecordType *T1RecordType = 0;
Douglas Gregor6b6d01f2010-05-07 19:42:26 +00003152 if (AllowRValues && (T1RecordType = T1->getAs<RecordType>()) &&
3153 !S.RequireCompleteType(Kind.getLocation(), T1, 0)) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003154 // The type we're converting to is a class type. Enumerate its constructors
3155 // to see if there is a suitable conversion.
3156 CXXRecordDecl *T1RecordDecl = cast<CXXRecordDecl>(T1RecordType->getDecl());
John McCall572fc622010-08-17 07:23:57 +00003157
Douglas Gregor20093b42009-12-09 23:02:17 +00003158 DeclContext::lookup_iterator Con, ConEnd;
Douglas Gregore5eee5a2010-07-02 23:12:18 +00003159 for (llvm::tie(Con, ConEnd) = S.LookupConstructors(T1RecordDecl);
Douglas Gregor20093b42009-12-09 23:02:17 +00003160 Con != ConEnd; ++Con) {
John McCall9aa472c2010-03-19 07:35:19 +00003161 NamedDecl *D = *Con;
3162 DeclAccessPair FoundDecl = DeclAccessPair::make(D, D->getAccess());
3163
Douglas Gregor20093b42009-12-09 23:02:17 +00003164 // Find the constructor (which may be a template).
3165 CXXConstructorDecl *Constructor = 0;
John McCall9aa472c2010-03-19 07:35:19 +00003166 FunctionTemplateDecl *ConstructorTmpl = dyn_cast<FunctionTemplateDecl>(D);
Douglas Gregor20093b42009-12-09 23:02:17 +00003167 if (ConstructorTmpl)
3168 Constructor = cast<CXXConstructorDecl>(
3169 ConstructorTmpl->getTemplatedDecl());
3170 else
John McCall9aa472c2010-03-19 07:35:19 +00003171 Constructor = cast<CXXConstructorDecl>(D);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003172
Douglas Gregor20093b42009-12-09 23:02:17 +00003173 if (!Constructor->isInvalidDecl() &&
3174 Constructor->isConvertingConstructor(AllowExplicit)) {
3175 if (ConstructorTmpl)
John McCall9aa472c2010-03-19 07:35:19 +00003176 S.AddTemplateOverloadCandidate(ConstructorTmpl, FoundDecl,
John McCall86820f52010-01-26 01:37:31 +00003177 /*ExplicitArgs*/ 0,
Ahmed Charles13a140c2012-02-25 11:00:22 +00003178 Initializer, CandidateSet,
Argyrios Kyrtzidisb72db892010-10-05 03:05:30 +00003179 /*SuppressUserConversions=*/true);
Douglas Gregor20093b42009-12-09 23:02:17 +00003180 else
John McCall9aa472c2010-03-19 07:35:19 +00003181 S.AddOverloadCandidate(Constructor, FoundDecl,
Ahmed Charles13a140c2012-02-25 11:00:22 +00003182 Initializer, CandidateSet,
Argyrios Kyrtzidisb72db892010-10-05 03:05:30 +00003183 /*SuppressUserConversions=*/true);
Douglas Gregor20093b42009-12-09 23:02:17 +00003184 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003185 }
Douglas Gregor20093b42009-12-09 23:02:17 +00003186 }
John McCall572fc622010-08-17 07:23:57 +00003187 if (T1RecordType && T1RecordType->getDecl()->isInvalidDecl())
3188 return OR_No_Viable_Function;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003189
Douglas Gregor6b6d01f2010-05-07 19:42:26 +00003190 const RecordType *T2RecordType = 0;
3191 if ((T2RecordType = T2->getAs<RecordType>()) &&
3192 !S.RequireCompleteType(Kind.getLocation(), T2, 0)) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003193 // The type we're converting from is a class type, enumerate its conversion
3194 // functions.
3195 CXXRecordDecl *T2RecordDecl = cast<CXXRecordDecl>(T2RecordType->getDecl());
3196
John McCalleec51cf2010-01-20 00:46:10 +00003197 const UnresolvedSetImpl *Conversions
Douglas Gregor20093b42009-12-09 23:02:17 +00003198 = T2RecordDecl->getVisibleConversionFunctions();
John McCalleec51cf2010-01-20 00:46:10 +00003199 for (UnresolvedSetImpl::const_iterator I = Conversions->begin(),
3200 E = Conversions->end(); I != E; ++I) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003201 NamedDecl *D = *I;
3202 CXXRecordDecl *ActingDC = cast<CXXRecordDecl>(D->getDeclContext());
3203 if (isa<UsingShadowDecl>(D))
3204 D = cast<UsingShadowDecl>(D)->getTargetDecl();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003205
Douglas Gregor20093b42009-12-09 23:02:17 +00003206 FunctionTemplateDecl *ConvTemplate = dyn_cast<FunctionTemplateDecl>(D);
3207 CXXConversionDecl *Conv;
3208 if (ConvTemplate)
3209 Conv = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl());
3210 else
Sebastian Redl4680bf22010-06-30 18:13:39 +00003211 Conv = cast<CXXConversionDecl>(D);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003212
Douglas Gregor20093b42009-12-09 23:02:17 +00003213 // If the conversion function doesn't return a reference type,
3214 // it can't be considered for this conversion unless we're allowed to
3215 // consider rvalues.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003216 // FIXME: Do we need to make sure that we only consider conversion
3217 // candidates with reference-compatible results? That might be needed to
Douglas Gregor20093b42009-12-09 23:02:17 +00003218 // break recursion.
Douglas Gregored878af2012-02-24 23:56:31 +00003219 if ((AllowExplicitConvs || !Conv->isExplicit()) &&
Douglas Gregor20093b42009-12-09 23:02:17 +00003220 (AllowRValues || Conv->getConversionType()->isLValueReferenceType())){
3221 if (ConvTemplate)
John McCall9aa472c2010-03-19 07:35:19 +00003222 S.AddTemplateConversionCandidate(ConvTemplate, I.getPair(),
John McCall86820f52010-01-26 01:37:31 +00003223 ActingDC, Initializer,
Douglas Gregor564cb062011-01-21 00:27:08 +00003224 DestType, CandidateSet);
Douglas Gregor20093b42009-12-09 23:02:17 +00003225 else
John McCall9aa472c2010-03-19 07:35:19 +00003226 S.AddConversionCandidate(Conv, I.getPair(), ActingDC,
Douglas Gregor564cb062011-01-21 00:27:08 +00003227 Initializer, DestType, CandidateSet);
Douglas Gregor20093b42009-12-09 23:02:17 +00003228 }
3229 }
3230 }
John McCall572fc622010-08-17 07:23:57 +00003231 if (T2RecordType && T2RecordType->getDecl()->isInvalidDecl())
3232 return OR_No_Viable_Function;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003233
Douglas Gregor20093b42009-12-09 23:02:17 +00003234 SourceLocation DeclLoc = Initializer->getLocStart();
3235
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003236 // Perform overload resolution. If it fails, return the failed result.
Douglas Gregor20093b42009-12-09 23:02:17 +00003237 OverloadCandidateSet::iterator Best;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003238 if (OverloadingResult Result
Douglas Gregor8fcc5162010-09-12 08:07:23 +00003239 = CandidateSet.BestViableFunction(S, DeclLoc, Best, true))
Douglas Gregor20093b42009-12-09 23:02:17 +00003240 return Result;
Eli Friedman03981012009-12-11 02:42:07 +00003241
Douglas Gregor20093b42009-12-09 23:02:17 +00003242 FunctionDecl *Function = Best->Function;
Eli Friedman03981012009-12-11 02:42:07 +00003243
Chandler Carruth25ca4212011-02-25 19:41:05 +00003244 // This is the overload that will actually be used for the initialization, so
3245 // mark it as used.
Eli Friedman5f2987c2012-02-02 03:46:19 +00003246 S.MarkFunctionReferenced(DeclLoc, Function);
Chandler Carruth25ca4212011-02-25 19:41:05 +00003247
Eli Friedman03981012009-12-11 02:42:07 +00003248 // Compute the returned type of the conversion.
Douglas Gregor20093b42009-12-09 23:02:17 +00003249 if (isa<CXXConversionDecl>(Function))
3250 T2 = Function->getResultType();
3251 else
3252 T2 = cv1T1;
Eli Friedman03981012009-12-11 02:42:07 +00003253
3254 // Add the user-defined conversion step.
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003255 bool HadMultipleCandidates = (CandidateSet.size() > 1);
John McCall9aa472c2010-03-19 07:35:19 +00003256 Sequence.AddUserConversionStep(Function, Best->FoundDecl,
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003257 T2.getNonLValueExprType(S.Context),
3258 HadMultipleCandidates);
Eli Friedman03981012009-12-11 02:42:07 +00003259
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003260 // Determine whether we need to perform derived-to-base or
Eli Friedman03981012009-12-11 02:42:07 +00003261 // cv-qualification adjustments.
John McCall5baba9d2010-08-25 10:28:54 +00003262 ExprValueKind VK = VK_RValue;
Sebastian Redl906082e2010-07-20 04:20:21 +00003263 if (T2->isLValueReferenceType())
John McCall5baba9d2010-08-25 10:28:54 +00003264 VK = VK_LValue;
Sebastian Redl906082e2010-07-20 04:20:21 +00003265 else if (const RValueReferenceType *RRef = T2->getAs<RValueReferenceType>())
John McCall5baba9d2010-08-25 10:28:54 +00003266 VK = RRef->getPointeeType()->isFunctionType() ? VK_LValue : VK_XValue;
Sebastian Redl906082e2010-07-20 04:20:21 +00003267
Douglas Gregor20093b42009-12-09 23:02:17 +00003268 bool NewDerivedToBase = false;
Douglas Gregor569c3162010-08-07 11:51:51 +00003269 bool NewObjCConversion = false;
John McCallf85e1932011-06-15 23:02:42 +00003270 bool NewObjCLifetimeConversion = false;
Douglas Gregor20093b42009-12-09 23:02:17 +00003271 Sema::ReferenceCompareResult NewRefRelationship
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003272 = S.CompareReferenceRelationship(DeclLoc, T1,
Douglas Gregor63982352010-07-13 18:40:04 +00003273 T2.getNonLValueExprType(S.Context),
John McCallf85e1932011-06-15 23:02:42 +00003274 NewDerivedToBase, NewObjCConversion,
3275 NewObjCLifetimeConversion);
Douglas Gregora1a9f032010-03-07 23:17:44 +00003276 if (NewRefRelationship == Sema::Ref_Incompatible) {
3277 // If the type we've converted to is not reference-related to the
3278 // type we're looking for, then there is another conversion step
3279 // we need to perform to produce a temporary of the right type
3280 // that we'll be binding to.
3281 ImplicitConversionSequence ICS;
3282 ICS.setStandard();
3283 ICS.Standard = Best->FinalConversion;
3284 T2 = ICS.Standard.getToType(2);
3285 Sequence.AddConversionSequenceStep(ICS, T2);
3286 } else if (NewDerivedToBase)
Douglas Gregor20093b42009-12-09 23:02:17 +00003287 Sequence.AddDerivedToBaseCastStep(
3288 S.Context.getQualifiedType(T1,
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003289 T2.getNonReferenceType().getQualifiers()),
John McCall5baba9d2010-08-25 10:28:54 +00003290 VK);
Douglas Gregor569c3162010-08-07 11:51:51 +00003291 else if (NewObjCConversion)
3292 Sequence.AddObjCObjectConversionStep(
3293 S.Context.getQualifiedType(T1,
3294 T2.getNonReferenceType().getQualifiers()));
3295
Douglas Gregor20093b42009-12-09 23:02:17 +00003296 if (cv1T1.getQualifiers() != T2.getNonReferenceType().getQualifiers())
John McCall5baba9d2010-08-25 10:28:54 +00003297 Sequence.AddQualificationConversionStep(cv1T1, VK);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003298
Douglas Gregor20093b42009-12-09 23:02:17 +00003299 Sequence.AddReferenceBindingStep(cv1T1, !T2->isReferenceType());
3300 return OR_Success;
3301}
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003302
Richard Smith83da2e72011-10-19 16:55:56 +00003303static void CheckCXX98CompatAccessibleCopy(Sema &S,
3304 const InitializedEntity &Entity,
3305 Expr *CurInitExpr);
3306
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003307/// \brief Attempt reference initialization (C++0x [dcl.init.ref])
3308static void TryReferenceInitialization(Sema &S,
Douglas Gregor20093b42009-12-09 23:02:17 +00003309 const InitializedEntity &Entity,
3310 const InitializationKind &Kind,
3311 Expr *Initializer,
3312 InitializationSequence &Sequence) {
Douglas Gregord6542d82009-12-22 15:35:07 +00003313 QualType DestType = Entity.getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00003314 QualType cv1T1 = DestType->getAs<ReferenceType>()->getPointeeType();
Chandler Carruth5535c382010-01-12 20:32:25 +00003315 Qualifiers T1Quals;
3316 QualType T1 = S.Context.getUnqualifiedArrayType(cv1T1, T1Quals);
Douglas Gregor20093b42009-12-09 23:02:17 +00003317 QualType cv2T2 = Initializer->getType();
Chandler Carruth5535c382010-01-12 20:32:25 +00003318 Qualifiers T2Quals;
3319 QualType T2 = S.Context.getUnqualifiedArrayType(cv2T2, T2Quals);
Sebastian Redl4680bf22010-06-30 18:13:39 +00003320
Douglas Gregor20093b42009-12-09 23:02:17 +00003321 // If the initializer is the address of an overloaded function, try
3322 // to resolve the overloaded function. If all goes well, T2 is the
3323 // type of the resulting function.
Sebastian Redl13dc8f92011-11-27 16:50:07 +00003324 if (ResolveOverloadedFunctionForReferenceBinding(S, Initializer, cv2T2, T2,
3325 T1, Sequence))
3326 return;
Sebastian Redl4680bf22010-06-30 18:13:39 +00003327
Sebastian Redl13dc8f92011-11-27 16:50:07 +00003328 // Delegate everything else to a subfunction.
3329 TryReferenceInitializationCore(S, Entity, Kind, Initializer, cv1T1, T1,
3330 T1Quals, cv2T2, T2, T2Quals, Sequence);
3331}
3332
3333/// \brief Reference initialization without resolving overloaded functions.
3334static void TryReferenceInitializationCore(Sema &S,
3335 const InitializedEntity &Entity,
3336 const InitializationKind &Kind,
3337 Expr *Initializer,
3338 QualType cv1T1, QualType T1,
3339 Qualifiers T1Quals,
3340 QualType cv2T2, QualType T2,
3341 Qualifiers T2Quals,
3342 InitializationSequence &Sequence) {
3343 QualType DestType = Entity.getType();
3344 SourceLocation DeclLoc = Initializer->getLocStart();
Douglas Gregor20093b42009-12-09 23:02:17 +00003345 // Compute some basic properties of the types and the initializer.
3346 bool isLValueRef = DestType->isLValueReferenceType();
3347 bool isRValueRef = !isLValueRef;
3348 bool DerivedToBase = false;
Douglas Gregor569c3162010-08-07 11:51:51 +00003349 bool ObjCConversion = false;
John McCallf85e1932011-06-15 23:02:42 +00003350 bool ObjCLifetimeConversion = false;
Sebastian Redl4680bf22010-06-30 18:13:39 +00003351 Expr::Classification InitCategory = Initializer->Classify(S.Context);
Douglas Gregor20093b42009-12-09 23:02:17 +00003352 Sema::ReferenceCompareResult RefRelationship
Douglas Gregor569c3162010-08-07 11:51:51 +00003353 = S.CompareReferenceRelationship(DeclLoc, cv1T1, cv2T2, DerivedToBase,
John McCallf85e1932011-06-15 23:02:42 +00003354 ObjCConversion, ObjCLifetimeConversion);
Sebastian Redl4680bf22010-06-30 18:13:39 +00003355
Douglas Gregor20093b42009-12-09 23:02:17 +00003356 // C++0x [dcl.init.ref]p5:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003357 // A reference to type "cv1 T1" is initialized by an expression of type
Douglas Gregor20093b42009-12-09 23:02:17 +00003358 // "cv2 T2" as follows:
3359 //
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003360 // - If the reference is an lvalue reference and the initializer
Douglas Gregor20093b42009-12-09 23:02:17 +00003361 // expression
Sebastian Redl4680bf22010-06-30 18:13:39 +00003362 // Note the analogous bullet points for rvlaue refs to functions. Because
3363 // there are no function rvalues in C++, rvalue refs to functions are treated
3364 // like lvalue refs.
Douglas Gregor20093b42009-12-09 23:02:17 +00003365 OverloadingResult ConvOvlResult = OR_Success;
Sebastian Redl4680bf22010-06-30 18:13:39 +00003366 bool T1Function = T1->isFunctionType();
3367 if (isLValueRef || T1Function) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003368 if (InitCategory.isLValue() &&
Douglas Gregor14d0aee2011-01-27 00:58:17 +00003369 (RefRelationship >= Sema::Ref_Compatible_With_Added_Qualification ||
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003370 (Kind.isCStyleOrFunctionalCast() &&
Douglas Gregor14d0aee2011-01-27 00:58:17 +00003371 RefRelationship == Sema::Ref_Related))) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003372 // - is an lvalue (but is not a bit-field), and "cv1 T1" is
Douglas Gregor20093b42009-12-09 23:02:17 +00003373 // reference-compatible with "cv2 T2," or
3374 //
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003375 // Per C++ [over.best.ics]p2, we don't diagnose whether the lvalue is a
Douglas Gregor20093b42009-12-09 23:02:17 +00003376 // bit-field when we're determining whether the reference initialization
Douglas Gregorde4b1d82010-01-29 19:14:02 +00003377 // can occur. However, we do pay attention to whether it is a bit-field
3378 // to decide whether we're actually binding to a temporary created from
3379 // the bit-field.
Douglas Gregor20093b42009-12-09 23:02:17 +00003380 if (DerivedToBase)
3381 Sequence.AddDerivedToBaseCastStep(
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003382 S.Context.getQualifiedType(T1, T2Quals),
John McCall5baba9d2010-08-25 10:28:54 +00003383 VK_LValue);
Douglas Gregor569c3162010-08-07 11:51:51 +00003384 else if (ObjCConversion)
3385 Sequence.AddObjCObjectConversionStep(
3386 S.Context.getQualifiedType(T1, T2Quals));
3387
Chandler Carruth5535c382010-01-12 20:32:25 +00003388 if (T1Quals != T2Quals)
John McCall5baba9d2010-08-25 10:28:54 +00003389 Sequence.AddQualificationConversionStep(cv1T1, VK_LValue);
Douglas Gregorde4b1d82010-01-29 19:14:02 +00003390 bool BindingTemporary = T1Quals.hasConst() && !T1Quals.hasVolatile() &&
Anders Carlsson09380262010-01-31 17:18:49 +00003391 (Initializer->getBitField() || Initializer->refersToVectorElement());
Douglas Gregorde4b1d82010-01-29 19:14:02 +00003392 Sequence.AddReferenceBindingStep(cv1T1, BindingTemporary);
Douglas Gregor20093b42009-12-09 23:02:17 +00003393 return;
3394 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003395
3396 // - has a class type (i.e., T2 is a class type), where T1 is not
3397 // reference-related to T2, and can be implicitly converted to an
3398 // lvalue of type "cv3 T3," where "cv1 T1" is reference-compatible
3399 // with "cv3 T3" (this conversion is selected by enumerating the
Douglas Gregor20093b42009-12-09 23:02:17 +00003400 // applicable conversion functions (13.3.1.6) and choosing the best
3401 // one through overload resolution (13.3)),
Sebastian Redl4680bf22010-06-30 18:13:39 +00003402 // If we have an rvalue ref to function type here, the rhs must be
3403 // an rvalue.
3404 if (RefRelationship == Sema::Ref_Incompatible && T2->isRecordType() &&
3405 (isLValueRef || InitCategory.isRValue())) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003406 ConvOvlResult = TryRefInitWithConversionFunction(S, Entity, Kind,
Douglas Gregor20093b42009-12-09 23:02:17 +00003407 Initializer,
Sebastian Redl4680bf22010-06-30 18:13:39 +00003408 /*AllowRValues=*/isRValueRef,
Douglas Gregor20093b42009-12-09 23:02:17 +00003409 Sequence);
3410 if (ConvOvlResult == OR_Success)
3411 return;
John McCall1d318332010-01-12 00:44:57 +00003412 if (ConvOvlResult != OR_No_Viable_Function) {
3413 Sequence.SetOverloadFailure(
3414 InitializationSequence::FK_ReferenceInitOverloadFailed,
3415 ConvOvlResult);
3416 }
Douglas Gregor20093b42009-12-09 23:02:17 +00003417 }
3418 }
Sebastian Redl4680bf22010-06-30 18:13:39 +00003419
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003420 // - Otherwise, the reference shall be an lvalue reference to a
Douglas Gregor20093b42009-12-09 23:02:17 +00003421 // non-volatile const type (i.e., cv1 shall be const), or the reference
Douglas Gregor69d83162011-01-20 16:08:06 +00003422 // shall be an rvalue reference.
Douglas Gregorb2855ad2011-01-21 00:52:42 +00003423 if (isLValueRef && !(T1Quals.hasConst() && !T1Quals.hasVolatile())) {
Douglas Gregor3afb9772010-11-08 15:20:28 +00003424 if (S.Context.getCanonicalType(T2) == S.Context.OverloadTy)
3425 Sequence.SetFailed(InitializationSequence::FK_AddressOfOverloadFailed);
3426 else if (ConvOvlResult && !Sequence.getFailedCandidateSet().empty())
Douglas Gregor20093b42009-12-09 23:02:17 +00003427 Sequence.SetOverloadFailure(
3428 InitializationSequence::FK_ReferenceInitOverloadFailed,
3429 ConvOvlResult);
Douglas Gregorb2855ad2011-01-21 00:52:42 +00003430 else
Sebastian Redl4680bf22010-06-30 18:13:39 +00003431 Sequence.SetFailed(InitCategory.isLValue()
Douglas Gregor20093b42009-12-09 23:02:17 +00003432 ? (RefRelationship == Sema::Ref_Related
3433 ? InitializationSequence::FK_ReferenceInitDropsQualifiers
3434 : InitializationSequence::FK_NonConstLValueReferenceBindingToUnrelated)
3435 : InitializationSequence::FK_NonConstLValueReferenceBindingToTemporary);
Sebastian Redl4680bf22010-06-30 18:13:39 +00003436
Douglas Gregor20093b42009-12-09 23:02:17 +00003437 return;
3438 }
Sebastian Redl4680bf22010-06-30 18:13:39 +00003439
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003440 // - If the initializer expression
3441 // - is an xvalue, class prvalue, array prvalue, or function lvalue and
3442 // "cv1 T1" is reference-compatible with "cv2 T2"
3443 // Note: functions are handled below.
3444 if (!T1Function &&
Douglas Gregor14d0aee2011-01-27 00:58:17 +00003445 (RefRelationship >= Sema::Ref_Compatible_With_Added_Qualification ||
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003446 (Kind.isCStyleOrFunctionalCast() &&
Douglas Gregor14d0aee2011-01-27 00:58:17 +00003447 RefRelationship == Sema::Ref_Related)) &&
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003448 (InitCategory.isXValue() ||
3449 (InitCategory.isPRValue() && T2->isRecordType()) ||
3450 (InitCategory.isPRValue() && T2->isArrayType()))) {
3451 ExprValueKind ValueKind = InitCategory.isXValue()? VK_XValue : VK_RValue;
3452 if (InitCategory.isPRValue() && T2->isRecordType()) {
Douglas Gregor523d46a2010-04-18 07:40:54 +00003453 // The corresponding bullet in C++03 [dcl.init.ref]p5 gives the
3454 // compiler the freedom to perform a copy here or bind to the
3455 // object, while C++0x requires that we bind directly to the
3456 // object. Hence, we always bind to the object without making an
3457 // extra copy. However, in C++03 requires that we check for the
3458 // presence of a suitable copy constructor:
3459 //
3460 // The constructor that would be used to make the copy shall
3461 // be callable whether or not the copy is actually done.
David Blaikie4e4d0842012-03-11 07:00:24 +00003462 if (!S.getLangOpts().CPlusPlus0x && !S.getLangOpts().MicrosoftExt)
Douglas Gregor523d46a2010-04-18 07:40:54 +00003463 Sequence.AddExtraneousCopyToTemporary(cv2T2);
David Blaikie4e4d0842012-03-11 07:00:24 +00003464 else if (S.getLangOpts().CPlusPlus0x)
Richard Smith83da2e72011-10-19 16:55:56 +00003465 CheckCXX98CompatAccessibleCopy(S, Entity, Initializer);
Douglas Gregor20093b42009-12-09 23:02:17 +00003466 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003467
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003468 if (DerivedToBase)
3469 Sequence.AddDerivedToBaseCastStep(S.Context.getQualifiedType(T1, T2Quals),
3470 ValueKind);
3471 else if (ObjCConversion)
3472 Sequence.AddObjCObjectConversionStep(
3473 S.Context.getQualifiedType(T1, T2Quals));
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003474
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003475 if (T1Quals != T2Quals)
3476 Sequence.AddQualificationConversionStep(cv1T1, ValueKind);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003477 Sequence.AddReferenceBindingStep(cv1T1,
Peter Collingbourne65bfd682011-11-13 00:51:30 +00003478 /*bindingTemporary=*/InitCategory.isPRValue());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003479 return;
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003480 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003481
3482 // - has a class type (i.e., T2 is a class type), where T1 is not
3483 // reference-related to T2, and can be implicitly converted to an
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003484 // xvalue, class prvalue, or function lvalue of type "cv3 T3",
3485 // where "cv1 T1" is reference-compatible with "cv3 T3",
Douglas Gregorc5db24d2011-01-20 16:44:54 +00003486 if (T2->isRecordType()) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003487 if (RefRelationship == Sema::Ref_Incompatible) {
3488 ConvOvlResult = TryRefInitWithConversionFunction(S, Entity,
3489 Kind, Initializer,
3490 /*AllowRValues=*/true,
3491 Sequence);
3492 if (ConvOvlResult)
3493 Sequence.SetOverloadFailure(
3494 InitializationSequence::FK_ReferenceInitOverloadFailed,
3495 ConvOvlResult);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003496
Douglas Gregor20093b42009-12-09 23:02:17 +00003497 return;
3498 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003499
Douglas Gregor20093b42009-12-09 23:02:17 +00003500 Sequence.SetFailed(InitializationSequence::FK_ReferenceInitDropsQualifiers);
3501 return;
3502 }
NAKAMURA Takumi00995302011-01-27 07:09:49 +00003503
3504 // - Otherwise, a temporary of type "cv1 T1" is created and initialized
Douglas Gregor20093b42009-12-09 23:02:17 +00003505 // from the initializer expression using the rules for a non-reference
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003506 // copy initialization (8.5). The reference is then bound to the
Douglas Gregor20093b42009-12-09 23:02:17 +00003507 // temporary. [...]
John McCall369371c2010-06-04 02:29:22 +00003508
Douglas Gregor20093b42009-12-09 23:02:17 +00003509 // Determine whether we are allowed to call explicit constructors or
3510 // explicit conversion operators.
Sebastian Redl168319c2012-02-12 16:37:24 +00003511 bool AllowExplicit = Kind.AllowExplicit();
John McCall369371c2010-06-04 02:29:22 +00003512
3513 InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(cv1T1);
3514
John McCallf85e1932011-06-15 23:02:42 +00003515 ImplicitConversionSequence ICS
3516 = S.TryImplicitConversion(Initializer, TempEntity.getType(),
John McCall369371c2010-06-04 02:29:22 +00003517 /*SuppressUserConversions*/ false,
3518 AllowExplicit,
Douglas Gregor14d0aee2011-01-27 00:58:17 +00003519 /*FIXME:InOverloadResolution=*/false,
John McCallf85e1932011-06-15 23:02:42 +00003520 /*CStyle=*/Kind.isCStyleOrFunctionalCast(),
3521 /*AllowObjCWritebackConversion=*/false);
3522
3523 if (ICS.isBad()) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003524 // FIXME: Use the conversion function set stored in ICS to turn
3525 // this into an overloading ambiguity diagnostic. However, we need
3526 // to keep that set as an OverloadCandidateSet rather than as some
3527 // other kind of set.
Douglas Gregor18ef5e22009-12-18 05:02:21 +00003528 if (ConvOvlResult && !Sequence.getFailedCandidateSet().empty())
3529 Sequence.SetOverloadFailure(
3530 InitializationSequence::FK_ReferenceInitOverloadFailed,
3531 ConvOvlResult);
Douglas Gregor3afb9772010-11-08 15:20:28 +00003532 else if (S.Context.getCanonicalType(T2) == S.Context.OverloadTy)
3533 Sequence.SetFailed(InitializationSequence::FK_AddressOfOverloadFailed);
Douglas Gregor18ef5e22009-12-18 05:02:21 +00003534 else
3535 Sequence.SetFailed(InitializationSequence::FK_ReferenceInitFailed);
Douglas Gregor20093b42009-12-09 23:02:17 +00003536 return;
John McCallf85e1932011-06-15 23:02:42 +00003537 } else {
3538 Sequence.AddConversionSequenceStep(ICS, TempEntity.getType());
Douglas Gregor20093b42009-12-09 23:02:17 +00003539 }
3540
3541 // [...] If T1 is reference-related to T2, cv1 must be the
3542 // same cv-qualification as, or greater cv-qualification
3543 // than, cv2; otherwise, the program is ill-formed.
Chandler Carruth5535c382010-01-12 20:32:25 +00003544 unsigned T1CVRQuals = T1Quals.getCVRQualifiers();
3545 unsigned T2CVRQuals = T2Quals.getCVRQualifiers();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003546 if (RefRelationship == Sema::Ref_Related &&
Chandler Carruth5535c382010-01-12 20:32:25 +00003547 (T1CVRQuals | T2CVRQuals) != T1CVRQuals) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003548 Sequence.SetFailed(InitializationSequence::FK_ReferenceInitDropsQualifiers);
3549 return;
3550 }
3551
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003552 // [...] If T1 is reference-related to T2 and the reference is an rvalue
Douglas Gregorb2855ad2011-01-21 00:52:42 +00003553 // reference, the initializer expression shall not be an lvalue.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003554 if (RefRelationship >= Sema::Ref_Related && !isLValueRef &&
Douglas Gregorb2855ad2011-01-21 00:52:42 +00003555 InitCategory.isLValue()) {
3556 Sequence.SetFailed(
3557 InitializationSequence::FK_RValueReferenceBindingToLValue);
3558 return;
3559 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003560
Douglas Gregor20093b42009-12-09 23:02:17 +00003561 Sequence.AddReferenceBindingStep(cv1T1, /*bindingTemporary=*/true);
3562 return;
3563}
3564
3565/// \brief Attempt character array initialization from a string literal
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003566/// (C++ [dcl.init.string], C99 6.7.8).
3567static void TryStringLiteralInitialization(Sema &S,
Douglas Gregor20093b42009-12-09 23:02:17 +00003568 const InitializedEntity &Entity,
3569 const InitializationKind &Kind,
3570 Expr *Initializer,
3571 InitializationSequence &Sequence) {
Douglas Gregord6542d82009-12-22 15:35:07 +00003572 Sequence.AddStringInitStep(Entity.getType());
Douglas Gregor20093b42009-12-09 23:02:17 +00003573}
3574
Douglas Gregor71d17402009-12-15 00:01:57 +00003575/// \brief Attempt value initialization (C++ [dcl.init]p7).
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003576static void TryValueInitialization(Sema &S,
Douglas Gregor71d17402009-12-15 00:01:57 +00003577 const InitializedEntity &Entity,
3578 const InitializationKind &Kind,
Richard Smithf4bb8d02012-07-05 08:39:21 +00003579 InitializationSequence &Sequence,
3580 InitListExpr *InitList) {
3581 assert((!InitList || InitList->getNumInits() == 0) &&
3582 "Shouldn't use value-init for non-empty init lists");
3583
Richard Smith1d0c9a82012-02-14 21:14:13 +00003584 // C++98 [dcl.init]p5, C++11 [dcl.init]p7:
Douglas Gregor71d17402009-12-15 00:01:57 +00003585 //
3586 // To value-initialize an object of type T means:
Douglas Gregord6542d82009-12-22 15:35:07 +00003587 QualType T = Entity.getType();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003588
Douglas Gregor71d17402009-12-15 00:01:57 +00003589 // -- if T is an array type, then each element is value-initialized;
Richard Smith1d0c9a82012-02-14 21:14:13 +00003590 T = S.Context.getBaseElementType(T);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003591
Douglas Gregor71d17402009-12-15 00:01:57 +00003592 if (const RecordType *RT = T->getAs<RecordType>()) {
3593 if (CXXRecordDecl *ClassDecl = dyn_cast<CXXRecordDecl>(RT->getDecl())) {
Richard Smithf4bb8d02012-07-05 08:39:21 +00003594 bool NeedZeroInitialization = true;
David Blaikie4e4d0842012-03-11 07:00:24 +00003595 if (!S.getLangOpts().CPlusPlus0x) {
Richard Smithf4bb8d02012-07-05 08:39:21 +00003596 // C++98:
3597 // -- if T is a class type (clause 9) with a user-declared constructor
3598 // (12.1), then the default constructor for T is called (and the
3599 // initialization is ill-formed if T has no accessible default
3600 // constructor);
Richard Smith1d0c9a82012-02-14 21:14:13 +00003601 if (ClassDecl->hasUserDeclaredConstructor())
Richard Smithf4bb8d02012-07-05 08:39:21 +00003602 NeedZeroInitialization = false;
Richard Smith1d0c9a82012-02-14 21:14:13 +00003603 } else {
3604 // C++11:
3605 // -- if T is a class type (clause 9) with either no default constructor
3606 // (12.1 [class.ctor]) or a default constructor that is user-provided
3607 // or deleted, then the object is default-initialized;
3608 CXXConstructorDecl *CD = S.LookupDefaultConstructor(ClassDecl);
3609 if (!CD || !CD->getCanonicalDecl()->isDefaulted() || CD->isDeleted())
Richard Smithf4bb8d02012-07-05 08:39:21 +00003610 NeedZeroInitialization = false;
Richard Smith1d0c9a82012-02-14 21:14:13 +00003611 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003612
Richard Smith1d0c9a82012-02-14 21:14:13 +00003613 // -- if T is a (possibly cv-qualified) non-union class type without a
3614 // user-provided or deleted default constructor, then the object is
3615 // zero-initialized and, if T has a non-trivial default constructor,
3616 // default-initialized;
Richard Smithd079abf2012-05-07 01:07:30 +00003617 // FIXME: The 'non-union' here is a defect (not yet assigned an issue
3618 // number). Update the quotation when the defect is resolved.
Richard Smithf4bb8d02012-07-05 08:39:21 +00003619 if (NeedZeroInitialization)
3620 Sequence.AddZeroInitializationStep(Entity.getType());
3621
3622 // If this is list-value-initialization, pass the empty init list on when
3623 // building the constructor call. This affects the semantics of a few
3624 // things (such as whether an explicit default constructor can be called).
3625 Expr *InitListAsExpr = InitList;
3626 Expr **Args = InitList ? &InitListAsExpr : 0;
3627 unsigned NumArgs = InitList ? 1 : 0;
3628 bool InitListSyntax = InitList;
3629
3630 return TryConstructorInitialization(S, Entity, Kind, Args, NumArgs, T,
3631 Sequence, InitListSyntax);
Douglas Gregor71d17402009-12-15 00:01:57 +00003632 }
3633 }
3634
Douglas Gregord6542d82009-12-22 15:35:07 +00003635 Sequence.AddZeroInitializationStep(Entity.getType());
Douglas Gregor71d17402009-12-15 00:01:57 +00003636}
3637
Douglas Gregor99a2e602009-12-16 01:38:02 +00003638/// \brief Attempt default initialization (C++ [dcl.init]p6).
3639static void TryDefaultInitialization(Sema &S,
3640 const InitializedEntity &Entity,
3641 const InitializationKind &Kind,
3642 InitializationSequence &Sequence) {
3643 assert(Kind.getKind() == InitializationKind::IK_Default);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003644
Douglas Gregor99a2e602009-12-16 01:38:02 +00003645 // C++ [dcl.init]p6:
3646 // To default-initialize an object of type T means:
3647 // - if T is an array type, each element is default-initialized;
John McCallf85e1932011-06-15 23:02:42 +00003648 QualType DestType = S.Context.getBaseElementType(Entity.getType());
3649
Douglas Gregor99a2e602009-12-16 01:38:02 +00003650 // - if T is a (possibly cv-qualified) class type (Clause 9), the default
3651 // constructor for T is called (and the initialization is ill-formed if
3652 // T has no accessible default constructor);
David Blaikie4e4d0842012-03-11 07:00:24 +00003653 if (DestType->isRecordType() && S.getLangOpts().CPlusPlus) {
Chandler Carruth4e6fbce2010-08-23 07:55:51 +00003654 TryConstructorInitialization(S, Entity, Kind, 0, 0, DestType, Sequence);
3655 return;
Douglas Gregor99a2e602009-12-16 01:38:02 +00003656 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003657
Douglas Gregor99a2e602009-12-16 01:38:02 +00003658 // - otherwise, no initialization is performed.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003659
Douglas Gregor99a2e602009-12-16 01:38:02 +00003660 // If a program calls for the default initialization of an object of
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003661 // a const-qualified type T, T shall be a class type with a user-provided
Douglas Gregor99a2e602009-12-16 01:38:02 +00003662 // default constructor.
David Blaikie4e4d0842012-03-11 07:00:24 +00003663 if (DestType.isConstQualified() && S.getLangOpts().CPlusPlus) {
Douglas Gregor99a2e602009-12-16 01:38:02 +00003664 Sequence.SetFailed(InitializationSequence::FK_DefaultInitOfConst);
John McCallf85e1932011-06-15 23:02:42 +00003665 return;
3666 }
3667
3668 // If the destination type has a lifetime property, zero-initialize it.
3669 if (DestType.getQualifiers().hasObjCLifetime()) {
3670 Sequence.AddZeroInitializationStep(Entity.getType());
3671 return;
3672 }
Douglas Gregor99a2e602009-12-16 01:38:02 +00003673}
3674
Douglas Gregor20093b42009-12-09 23:02:17 +00003675/// \brief Attempt a user-defined conversion between two types (C++ [dcl.init]),
3676/// which enumerates all conversion functions and performs overload resolution
3677/// to select the best.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003678static void TryUserDefinedConversion(Sema &S,
Douglas Gregor20093b42009-12-09 23:02:17 +00003679 const InitializedEntity &Entity,
3680 const InitializationKind &Kind,
3681 Expr *Initializer,
3682 InitializationSequence &Sequence) {
Douglas Gregord6542d82009-12-22 15:35:07 +00003683 QualType DestType = Entity.getType();
Douglas Gregor4a520a22009-12-14 17:27:33 +00003684 assert(!DestType->isReferenceType() && "References are handled elsewhere");
3685 QualType SourceType = Initializer->getType();
3686 assert((DestType->isRecordType() || SourceType->isRecordType()) &&
3687 "Must have a class type to perform a user-defined conversion");
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003688
Douglas Gregor4a520a22009-12-14 17:27:33 +00003689 // Build the candidate set directly in the initialization sequence
3690 // structure, so that it will persist if we fail.
3691 OverloadCandidateSet &CandidateSet = Sequence.getFailedCandidateSet();
3692 CandidateSet.clear();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003693
Douglas Gregor4a520a22009-12-14 17:27:33 +00003694 // Determine whether we are allowed to call explicit constructors or
3695 // explicit conversion operators.
Sebastian Redl168319c2012-02-12 16:37:24 +00003696 bool AllowExplicit = Kind.AllowExplicit();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003697
Douglas Gregor4a520a22009-12-14 17:27:33 +00003698 if (const RecordType *DestRecordType = DestType->getAs<RecordType>()) {
3699 // The type we're converting to is a class type. Enumerate its constructors
3700 // to see if there is a suitable conversion.
3701 CXXRecordDecl *DestRecordDecl
3702 = cast<CXXRecordDecl>(DestRecordType->getDecl());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003703
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003704 // Try to complete the type we're converting to.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003705 if (!S.RequireCompleteType(Kind.getLocation(), DestType, 0)) {
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003706 DeclContext::lookup_iterator Con, ConEnd;
Douglas Gregore5eee5a2010-07-02 23:12:18 +00003707 for (llvm::tie(Con, ConEnd) = S.LookupConstructors(DestRecordDecl);
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003708 Con != ConEnd; ++Con) {
3709 NamedDecl *D = *Con;
3710 DeclAccessPair FoundDecl = DeclAccessPair::make(D, D->getAccess());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003711
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003712 // Find the constructor (which may be a template).
3713 CXXConstructorDecl *Constructor = 0;
3714 FunctionTemplateDecl *ConstructorTmpl
3715 = dyn_cast<FunctionTemplateDecl>(D);
Douglas Gregor4a520a22009-12-14 17:27:33 +00003716 if (ConstructorTmpl)
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003717 Constructor = cast<CXXConstructorDecl>(
3718 ConstructorTmpl->getTemplatedDecl());
Douglas Gregor4712c022010-07-01 03:43:00 +00003719 else
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003720 Constructor = cast<CXXConstructorDecl>(D);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003721
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003722 if (!Constructor->isInvalidDecl() &&
3723 Constructor->isConvertingConstructor(AllowExplicit)) {
3724 if (ConstructorTmpl)
3725 S.AddTemplateOverloadCandidate(ConstructorTmpl, FoundDecl,
3726 /*ExplicitArgs*/ 0,
Ahmed Charles13a140c2012-02-25 11:00:22 +00003727 Initializer, CandidateSet,
Douglas Gregor4712c022010-07-01 03:43:00 +00003728 /*SuppressUserConversions=*/true);
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003729 else
3730 S.AddOverloadCandidate(Constructor, FoundDecl,
Ahmed Charles13a140c2012-02-25 11:00:22 +00003731 Initializer, CandidateSet,
Douglas Gregor4712c022010-07-01 03:43:00 +00003732 /*SuppressUserConversions=*/true);
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003733 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003734 }
Douglas Gregor087fb7d2010-04-26 14:36:57 +00003735 }
Douglas Gregor4a520a22009-12-14 17:27:33 +00003736 }
Eli Friedmancfdc81a2009-12-19 08:11:05 +00003737
3738 SourceLocation DeclLoc = Initializer->getLocStart();
3739
Douglas Gregor4a520a22009-12-14 17:27:33 +00003740 if (const RecordType *SourceRecordType = SourceType->getAs<RecordType>()) {
3741 // The type we're converting from is a class type, enumerate its conversion
3742 // functions.
Eli Friedmancfdc81a2009-12-19 08:11:05 +00003743
Eli Friedman33c2da92009-12-20 22:12:03 +00003744 // We can only enumerate the conversion functions for a complete type; if
3745 // the type isn't complete, simply skip this step.
3746 if (!S.RequireCompleteType(DeclLoc, SourceType, 0)) {
3747 CXXRecordDecl *SourceRecordDecl
3748 = cast<CXXRecordDecl>(SourceRecordType->getDecl());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003749
John McCalleec51cf2010-01-20 00:46:10 +00003750 const UnresolvedSetImpl *Conversions
Eli Friedman33c2da92009-12-20 22:12:03 +00003751 = SourceRecordDecl->getVisibleConversionFunctions();
John McCalleec51cf2010-01-20 00:46:10 +00003752 for (UnresolvedSetImpl::const_iterator I = Conversions->begin(),
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003753 E = Conversions->end();
Eli Friedman33c2da92009-12-20 22:12:03 +00003754 I != E; ++I) {
3755 NamedDecl *D = *I;
3756 CXXRecordDecl *ActingDC = cast<CXXRecordDecl>(D->getDeclContext());
3757 if (isa<UsingShadowDecl>(D))
3758 D = cast<UsingShadowDecl>(D)->getTargetDecl();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003759
Eli Friedman33c2da92009-12-20 22:12:03 +00003760 FunctionTemplateDecl *ConvTemplate = dyn_cast<FunctionTemplateDecl>(D);
3761 CXXConversionDecl *Conv;
Douglas Gregor4a520a22009-12-14 17:27:33 +00003762 if (ConvTemplate)
Eli Friedman33c2da92009-12-20 22:12:03 +00003763 Conv = cast<CXXConversionDecl>(ConvTemplate->getTemplatedDecl());
Douglas Gregor4a520a22009-12-14 17:27:33 +00003764 else
John McCall32daa422010-03-31 01:36:47 +00003765 Conv = cast<CXXConversionDecl>(D);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003766
Eli Friedman33c2da92009-12-20 22:12:03 +00003767 if (AllowExplicit || !Conv->isExplicit()) {
3768 if (ConvTemplate)
John McCall9aa472c2010-03-19 07:35:19 +00003769 S.AddTemplateConversionCandidate(ConvTemplate, I.getPair(),
John McCall86820f52010-01-26 01:37:31 +00003770 ActingDC, Initializer, DestType,
Eli Friedman33c2da92009-12-20 22:12:03 +00003771 CandidateSet);
3772 else
John McCall9aa472c2010-03-19 07:35:19 +00003773 S.AddConversionCandidate(Conv, I.getPair(), ActingDC,
John McCall86820f52010-01-26 01:37:31 +00003774 Initializer, DestType, CandidateSet);
Eli Friedman33c2da92009-12-20 22:12:03 +00003775 }
Douglas Gregor4a520a22009-12-14 17:27:33 +00003776 }
3777 }
3778 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003779
3780 // Perform overload resolution. If it fails, return the failed result.
Douglas Gregor4a520a22009-12-14 17:27:33 +00003781 OverloadCandidateSet::iterator Best;
John McCall1d318332010-01-12 00:44:57 +00003782 if (OverloadingResult Result
Douglas Gregor8fcc5162010-09-12 08:07:23 +00003783 = CandidateSet.BestViableFunction(S, DeclLoc, Best, true)) {
Douglas Gregor4a520a22009-12-14 17:27:33 +00003784 Sequence.SetOverloadFailure(
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003785 InitializationSequence::FK_UserConversionOverloadFailed,
Douglas Gregor4a520a22009-12-14 17:27:33 +00003786 Result);
3787 return;
3788 }
John McCall1d318332010-01-12 00:44:57 +00003789
Douglas Gregor4a520a22009-12-14 17:27:33 +00003790 FunctionDecl *Function = Best->Function;
Eli Friedman5f2987c2012-02-02 03:46:19 +00003791 S.MarkFunctionReferenced(DeclLoc, Function);
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003792 bool HadMultipleCandidates = (CandidateSet.size() > 1);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003793
Douglas Gregor4a520a22009-12-14 17:27:33 +00003794 if (isa<CXXConstructorDecl>(Function)) {
3795 // Add the user-defined conversion step. Any cv-qualification conversion is
Richard Smithf2e4dfc2012-02-11 19:22:50 +00003796 // subsumed by the initialization. Per DR5, the created temporary is of the
3797 // cv-unqualified type of the destination.
3798 Sequence.AddUserConversionStep(Function, Best->FoundDecl,
3799 DestType.getUnqualifiedType(),
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003800 HadMultipleCandidates);
Douglas Gregor4a520a22009-12-14 17:27:33 +00003801 return;
3802 }
3803
3804 // Add the user-defined conversion step that calls the conversion function.
Douglas Gregor5291c3c2010-07-13 08:18:22 +00003805 QualType ConvType = Function->getCallResultType();
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00003806 if (ConvType->getAs<RecordType>()) {
Richard Smithf2e4dfc2012-02-11 19:22:50 +00003807 // If we're converting to a class type, there may be an copy of
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00003808 // the resulting temporary object (possible to create an object of
3809 // a base class type). That copy is not a separate conversion, so
3810 // we just make a note of the actual destination type (possibly a
3811 // base class of the type returned by the conversion function) and
3812 // let the user-defined conversion step handle the conversion.
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003813 Sequence.AddUserConversionStep(Function, Best->FoundDecl, DestType,
3814 HadMultipleCandidates);
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00003815 return;
3816 }
Douglas Gregor4a520a22009-12-14 17:27:33 +00003817
Abramo Bagnara22c107b2011-11-19 11:44:21 +00003818 Sequence.AddUserConversionStep(Function, Best->FoundDecl, ConvType,
3819 HadMultipleCandidates);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003820
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00003821 // If the conversion following the call to the conversion function
3822 // is interesting, add it as a separate step.
Douglas Gregor4a520a22009-12-14 17:27:33 +00003823 if (Best->FinalConversion.First || Best->FinalConversion.Second ||
3824 Best->FinalConversion.Third) {
3825 ImplicitConversionSequence ICS;
John McCall1d318332010-01-12 00:44:57 +00003826 ICS.setStandard();
Douglas Gregor4a520a22009-12-14 17:27:33 +00003827 ICS.Standard = Best->FinalConversion;
3828 Sequence.AddConversionSequenceStep(ICS, DestType);
3829 }
Douglas Gregor20093b42009-12-09 23:02:17 +00003830}
3831
John McCallf85e1932011-06-15 23:02:42 +00003832/// The non-zero enum values here are indexes into diagnostic alternatives.
3833enum InvalidICRKind { IIK_okay, IIK_nonlocal, IIK_nonscalar };
3834
3835/// Determines whether this expression is an acceptable ICR source.
John McCallc03fa492011-06-27 23:59:58 +00003836static InvalidICRKind isInvalidICRSource(ASTContext &C, Expr *e,
3837 bool isAddressOf) {
John McCallf85e1932011-06-15 23:02:42 +00003838 // Skip parens.
3839 e = e->IgnoreParens();
3840
3841 // Skip address-of nodes.
3842 if (UnaryOperator *op = dyn_cast<UnaryOperator>(e)) {
3843 if (op->getOpcode() == UO_AddrOf)
John McCallc03fa492011-06-27 23:59:58 +00003844 return isInvalidICRSource(C, op->getSubExpr(), /*addressof*/ true);
John McCallf85e1932011-06-15 23:02:42 +00003845
3846 // Skip certain casts.
John McCallc03fa492011-06-27 23:59:58 +00003847 } else if (CastExpr *ce = dyn_cast<CastExpr>(e)) {
3848 switch (ce->getCastKind()) {
John McCallf85e1932011-06-15 23:02:42 +00003849 case CK_Dependent:
3850 case CK_BitCast:
3851 case CK_LValueBitCast:
John McCallf85e1932011-06-15 23:02:42 +00003852 case CK_NoOp:
John McCallc03fa492011-06-27 23:59:58 +00003853 return isInvalidICRSource(C, ce->getSubExpr(), isAddressOf);
John McCallf85e1932011-06-15 23:02:42 +00003854
3855 case CK_ArrayToPointerDecay:
3856 return IIK_nonscalar;
3857
3858 case CK_NullToPointer:
3859 return IIK_okay;
3860
3861 default:
3862 break;
3863 }
3864
3865 // If we have a declaration reference, it had better be a local variable.
John McCallf4b88a42012-03-10 09:33:50 +00003866 } else if (isa<DeclRefExpr>(e)) {
John McCallc03fa492011-06-27 23:59:58 +00003867 if (!isAddressOf) return IIK_nonlocal;
3868
John McCallf4b88a42012-03-10 09:33:50 +00003869 VarDecl *var = dyn_cast<VarDecl>(cast<DeclRefExpr>(e)->getDecl());
3870 if (!var) return IIK_nonlocal;
John McCallc03fa492011-06-27 23:59:58 +00003871
3872 return (var->hasLocalStorage() ? IIK_okay : IIK_nonlocal);
John McCallf85e1932011-06-15 23:02:42 +00003873
3874 // If we have a conditional operator, check both sides.
3875 } else if (ConditionalOperator *cond = dyn_cast<ConditionalOperator>(e)) {
John McCallc03fa492011-06-27 23:59:58 +00003876 if (InvalidICRKind iik = isInvalidICRSource(C, cond->getLHS(), isAddressOf))
John McCallf85e1932011-06-15 23:02:42 +00003877 return iik;
3878
John McCallc03fa492011-06-27 23:59:58 +00003879 return isInvalidICRSource(C, cond->getRHS(), isAddressOf);
John McCallf85e1932011-06-15 23:02:42 +00003880
3881 // These are never scalar.
3882 } else if (isa<ArraySubscriptExpr>(e)) {
3883 return IIK_nonscalar;
3884
3885 // Otherwise, it needs to be a null pointer constant.
3886 } else {
3887 return (e->isNullPointerConstant(C, Expr::NPC_ValueDependentIsNull)
3888 ? IIK_okay : IIK_nonlocal);
3889 }
3890
3891 return IIK_nonlocal;
3892}
3893
3894/// Check whether the given expression is a valid operand for an
3895/// indirect copy/restore.
3896static void checkIndirectCopyRestoreSource(Sema &S, Expr *src) {
3897 assert(src->isRValue());
3898
John McCallc03fa492011-06-27 23:59:58 +00003899 InvalidICRKind iik = isInvalidICRSource(S.Context, src, false);
John McCallf85e1932011-06-15 23:02:42 +00003900 if (iik == IIK_okay) return;
3901
3902 S.Diag(src->getExprLoc(), diag::err_arc_nonlocal_writeback)
3903 << ((unsigned) iik - 1) // shift index into diagnostic explanations
3904 << src->getSourceRange();
3905}
3906
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00003907/// \brief Determine whether we have compatible array types for the
3908/// purposes of GNU by-copy array initialization.
3909static bool hasCompatibleArrayTypes(ASTContext &Context,
3910 const ArrayType *Dest,
3911 const ArrayType *Source) {
3912 // If the source and destination array types are equivalent, we're
3913 // done.
3914 if (Context.hasSameType(QualType(Dest, 0), QualType(Source, 0)))
3915 return true;
3916
3917 // Make sure that the element types are the same.
3918 if (!Context.hasSameType(Dest->getElementType(), Source->getElementType()))
3919 return false;
3920
3921 // The only mismatch we allow is when the destination is an
3922 // incomplete array type and the source is a constant array type.
3923 return Source->isConstantArrayType() && Dest->isIncompleteArrayType();
3924}
3925
John McCallf85e1932011-06-15 23:02:42 +00003926static bool tryObjCWritebackConversion(Sema &S,
3927 InitializationSequence &Sequence,
3928 const InitializedEntity &Entity,
3929 Expr *Initializer) {
3930 bool ArrayDecay = false;
3931 QualType ArgType = Initializer->getType();
3932 QualType ArgPointee;
3933 if (const ArrayType *ArgArrayType = S.Context.getAsArrayType(ArgType)) {
3934 ArrayDecay = true;
3935 ArgPointee = ArgArrayType->getElementType();
3936 ArgType = S.Context.getPointerType(ArgPointee);
3937 }
3938
3939 // Handle write-back conversion.
3940 QualType ConvertedArgType;
3941 if (!S.isObjCWritebackConversion(ArgType, Entity.getType(),
3942 ConvertedArgType))
3943 return false;
3944
3945 // We should copy unless we're passing to an argument explicitly
3946 // marked 'out'.
3947 bool ShouldCopy = true;
3948 if (ParmVarDecl *param = cast_or_null<ParmVarDecl>(Entity.getDecl()))
3949 ShouldCopy = (param->getObjCDeclQualifier() != ParmVarDecl::OBJC_TQ_Out);
3950
3951 // Do we need an lvalue conversion?
3952 if (ArrayDecay || Initializer->isGLValue()) {
3953 ImplicitConversionSequence ICS;
3954 ICS.setStandard();
3955 ICS.Standard.setAsIdentityConversion();
3956
3957 QualType ResultType;
3958 if (ArrayDecay) {
3959 ICS.Standard.First = ICK_Array_To_Pointer;
3960 ResultType = S.Context.getPointerType(ArgPointee);
3961 } else {
3962 ICS.Standard.First = ICK_Lvalue_To_Rvalue;
3963 ResultType = Initializer->getType().getNonLValueExprType(S.Context);
3964 }
3965
3966 Sequence.AddConversionSequenceStep(ICS, ResultType);
3967 }
3968
3969 Sequence.AddPassByIndirectCopyRestoreStep(Entity.getType(), ShouldCopy);
3970 return true;
3971}
3972
Douglas Gregor20093b42009-12-09 23:02:17 +00003973InitializationSequence::InitializationSequence(Sema &S,
3974 const InitializedEntity &Entity,
3975 const InitializationKind &Kind,
3976 Expr **Args,
John McCall5769d612010-02-08 23:07:23 +00003977 unsigned NumArgs)
3978 : FailedCandidateSet(Kind.getLocation()) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003979 ASTContext &Context = S.Context;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003980
Douglas Gregor20093b42009-12-09 23:02:17 +00003981 // C++0x [dcl.init]p16:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003982 // The semantics of initializers are as follows. The destination type is
3983 // the type of the object or reference being initialized and the source
Douglas Gregor20093b42009-12-09 23:02:17 +00003984 // type is the type of the initializer expression. The source type is not
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00003985 // defined when the initializer is a braced-init-list or when it is a
Douglas Gregor20093b42009-12-09 23:02:17 +00003986 // parenthesized list of expressions.
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003987 QualType DestType = Entity.getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00003988
Rafael Espindola12ce0a02011-07-14 22:58:04 +00003989 if (DestType->isDependentType() ||
Ahmed Charles13a140c2012-02-25 11:00:22 +00003990 Expr::hasAnyTypeDependentArguments(llvm::makeArrayRef(Args, NumArgs))) {
Douglas Gregor20093b42009-12-09 23:02:17 +00003991 SequenceKind = DependentSequence;
3992 return;
3993 }
3994
Sebastian Redl7491c492011-06-05 13:59:11 +00003995 // Almost everything is a normal sequence.
3996 setSequenceKind(NormalSequence);
3997
John McCall241d5582010-12-07 22:54:16 +00003998 for (unsigned I = 0; I != NumArgs; ++I)
John McCall32509f12011-11-15 01:35:18 +00003999 if (Args[I]->getType()->isNonOverloadPlaceholderType()) {
John McCall5acb0c92011-10-17 18:40:02 +00004000 // FIXME: should we be doing this here?
John McCall32509f12011-11-15 01:35:18 +00004001 ExprResult result = S.CheckPlaceholderExpr(Args[I]);
4002 if (result.isInvalid()) {
4003 SetFailed(FK_PlaceholderType);
4004 return;
John McCall5acb0c92011-10-17 18:40:02 +00004005 }
John McCall32509f12011-11-15 01:35:18 +00004006 Args[I] = result.take();
John Wiegley429bb272011-04-08 18:41:53 +00004007 }
John McCall241d5582010-12-07 22:54:16 +00004008
John McCall5acb0c92011-10-17 18:40:02 +00004009
Douglas Gregor20093b42009-12-09 23:02:17 +00004010 QualType SourceType;
4011 Expr *Initializer = 0;
Douglas Gregor99a2e602009-12-16 01:38:02 +00004012 if (NumArgs == 1) {
Douglas Gregor20093b42009-12-09 23:02:17 +00004013 Initializer = Args[0];
4014 if (!isa<InitListExpr>(Initializer))
4015 SourceType = Initializer->getType();
4016 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004017
Sebastian Redl3a45c0e2012-02-12 16:37:36 +00004018 // - If the initializer is a (non-parenthesized) braced-init-list, the
4019 // object is list-initialized (8.5.4).
4020 if (Kind.getKind() != InitializationKind::IK_Direct) {
4021 if (InitListExpr *InitList = dyn_cast_or_null<InitListExpr>(Initializer)) {
4022 TryListInitialization(S, Entity, Kind, InitList, *this);
4023 return;
4024 }
Douglas Gregor20093b42009-12-09 23:02:17 +00004025 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004026
Douglas Gregor20093b42009-12-09 23:02:17 +00004027 // - If the destination type is a reference type, see 8.5.3.
4028 if (DestType->isReferenceType()) {
4029 // C++0x [dcl.init.ref]p1:
4030 // A variable declared to be a T& or T&&, that is, "reference to type T"
4031 // (8.3.2), shall be initialized by an object, or function, of type T or
4032 // by an object that can be converted into a T.
4033 // (Therefore, multiple arguments are not permitted.)
4034 if (NumArgs != 1)
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004035 SetFailed(FK_TooManyInitsForReference);
Douglas Gregor20093b42009-12-09 23:02:17 +00004036 else
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004037 TryReferenceInitialization(S, Entity, Kind, Args[0], *this);
Douglas Gregor20093b42009-12-09 23:02:17 +00004038 return;
4039 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004040
Douglas Gregor20093b42009-12-09 23:02:17 +00004041 // - If the initializer is (), the object is value-initialized.
Douglas Gregor99a2e602009-12-16 01:38:02 +00004042 if (Kind.getKind() == InitializationKind::IK_Value ||
4043 (Kind.getKind() == InitializationKind::IK_Direct && NumArgs == 0)) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004044 TryValueInitialization(S, Entity, Kind, *this);
Douglas Gregor20093b42009-12-09 23:02:17 +00004045 return;
4046 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004047
Douglas Gregor99a2e602009-12-16 01:38:02 +00004048 // Handle default initialization.
Nick Lewycky7663f392010-11-20 01:29:55 +00004049 if (Kind.getKind() == InitializationKind::IK_Default) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004050 TryDefaultInitialization(S, Entity, Kind, *this);
Douglas Gregor99a2e602009-12-16 01:38:02 +00004051 return;
4052 }
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004053
John McCallce6c9b72011-02-21 07:22:22 +00004054 // - If the destination type is an array of characters, an array of
4055 // char16_t, an array of char32_t, or an array of wchar_t, and the
4056 // initializer is a string literal, see 8.5.2.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004057 // - Otherwise, if the destination type is an array, the program is
Douglas Gregor20093b42009-12-09 23:02:17 +00004058 // ill-formed.
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004059 if (const ArrayType *DestAT = Context.getAsArrayType(DestType)) {
John McCall73076432012-01-05 00:13:19 +00004060 if (Initializer && isa<VariableArrayType>(DestAT)) {
4061 SetFailed(FK_VariableLengthArrayHasInitializer);
4062 return;
4063 }
4064
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004065 if (Initializer && IsStringInit(Initializer, DestAT, Context)) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004066 TryStringLiteralInitialization(S, Entity, Kind, Initializer, *this);
John McCallce6c9b72011-02-21 07:22:22 +00004067 return;
4068 }
4069
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004070 // Note: as an GNU C extension, we allow initialization of an
4071 // array from a compound literal that creates an array of the same
4072 // type, so long as the initializer has no side effects.
David Blaikie4e4d0842012-03-11 07:00:24 +00004073 if (!S.getLangOpts().CPlusPlus && Initializer &&
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004074 isa<CompoundLiteralExpr>(Initializer->IgnoreParens()) &&
4075 Initializer->getType()->isArrayType()) {
4076 const ArrayType *SourceAT
4077 = Context.getAsArrayType(Initializer->getType());
4078 if (!hasCompatibleArrayTypes(S.Context, DestAT, SourceAT))
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004079 SetFailed(FK_ArrayTypeMismatch);
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004080 else if (Initializer->HasSideEffects(S.Context))
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004081 SetFailed(FK_NonConstantArrayInit);
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004082 else {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004083 AddArrayInitStep(DestType);
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004084 }
Richard Smith0f163e92012-02-15 22:38:09 +00004085 }
Richard Smithf4bb8d02012-07-05 08:39:21 +00004086 // Note: as a GNU C++ extension, we allow list-initialization of a
4087 // class member of array type from a parenthesized initializer list.
David Blaikie4e4d0842012-03-11 07:00:24 +00004088 else if (S.getLangOpts().CPlusPlus &&
Richard Smith0f163e92012-02-15 22:38:09 +00004089 Entity.getKind() == InitializedEntity::EK_Member &&
4090 Initializer && isa<InitListExpr>(Initializer)) {
4091 TryListInitialization(S, Entity, Kind, cast<InitListExpr>(Initializer),
4092 *this);
4093 AddParenthesizedArrayInitStep(DestType);
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004094 } else if (DestAT->getElementType()->isAnyCharacterType())
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004095 SetFailed(FK_ArrayNeedsInitListOrStringLiteral);
Douglas Gregor20093b42009-12-09 23:02:17 +00004096 else
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004097 SetFailed(FK_ArrayNeedsInitList);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004098
Douglas Gregor20093b42009-12-09 23:02:17 +00004099 return;
4100 }
Eli Friedmancfdc81a2009-12-19 08:11:05 +00004101
John McCallf85e1932011-06-15 23:02:42 +00004102 // Determine whether we should consider writeback conversions for
4103 // Objective-C ARC.
David Blaikie4e4d0842012-03-11 07:00:24 +00004104 bool allowObjCWritebackConversion = S.getLangOpts().ObjCAutoRefCount &&
John McCallf85e1932011-06-15 23:02:42 +00004105 Entity.getKind() == InitializedEntity::EK_Parameter;
4106
4107 // We're at the end of the line for C: it's either a write-back conversion
4108 // or it's a C assignment. There's no need to check anything else.
David Blaikie4e4d0842012-03-11 07:00:24 +00004109 if (!S.getLangOpts().CPlusPlus) {
John McCallf85e1932011-06-15 23:02:42 +00004110 // If allowed, check whether this is an Objective-C writeback conversion.
4111 if (allowObjCWritebackConversion &&
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004112 tryObjCWritebackConversion(S, *this, Entity, Initializer)) {
John McCallf85e1932011-06-15 23:02:42 +00004113 return;
4114 }
4115
4116 // Handle initialization in C
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004117 AddCAssignmentStep(DestType);
4118 MaybeProduceObjCObject(S, *this, Entity);
Eli Friedmancfdc81a2009-12-19 08:11:05 +00004119 return;
4120 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004121
David Blaikie4e4d0842012-03-11 07:00:24 +00004122 assert(S.getLangOpts().CPlusPlus);
John McCallf85e1932011-06-15 23:02:42 +00004123
Douglas Gregor20093b42009-12-09 23:02:17 +00004124 // - If the destination type is a (possibly cv-qualified) class type:
4125 if (DestType->isRecordType()) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004126 // - If the initialization is direct-initialization, or if it is
4127 // copy-initialization where the cv-unqualified version of the
4128 // source type is the same class as, or a derived class of, the
Douglas Gregor20093b42009-12-09 23:02:17 +00004129 // class of the destination, constructors are considered. [...]
4130 if (Kind.getKind() == InitializationKind::IK_Direct ||
4131 (Kind.getKind() == InitializationKind::IK_Copy &&
4132 (Context.hasSameUnqualifiedType(SourceType, DestType) ||
4133 S.IsDerivedFrom(SourceType, DestType))))
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004134 TryConstructorInitialization(S, Entity, Kind, Args, NumArgs,
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004135 Entity.getType(), *this);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004136 // - Otherwise (i.e., for the remaining copy-initialization cases),
Douglas Gregor20093b42009-12-09 23:02:17 +00004137 // user-defined conversion sequences that can convert from the source
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004138 // type to the destination type or (when a conversion function is
Douglas Gregor20093b42009-12-09 23:02:17 +00004139 // used) to a derived class thereof are enumerated as described in
4140 // 13.3.1.4, and the best one is chosen through overload resolution
4141 // (13.3).
4142 else
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004143 TryUserDefinedConversion(S, Entity, Kind, Initializer, *this);
Douglas Gregor20093b42009-12-09 23:02:17 +00004144 return;
4145 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004146
Douglas Gregor99a2e602009-12-16 01:38:02 +00004147 if (NumArgs > 1) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004148 SetFailed(FK_TooManyInitsForScalar);
Douglas Gregor99a2e602009-12-16 01:38:02 +00004149 return;
4150 }
4151 assert(NumArgs == 1 && "Zero-argument case handled above");
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004152
4153 // - Otherwise, if the source type is a (possibly cv-qualified) class
Douglas Gregor20093b42009-12-09 23:02:17 +00004154 // type, conversion functions are considered.
Douglas Gregor99a2e602009-12-16 01:38:02 +00004155 if (!SourceType.isNull() && SourceType->isRecordType()) {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004156 TryUserDefinedConversion(S, Entity, Kind, Initializer, *this);
4157 MaybeProduceObjCObject(S, *this, Entity);
Douglas Gregor20093b42009-12-09 23:02:17 +00004158 return;
4159 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004160
Douglas Gregor20093b42009-12-09 23:02:17 +00004161 // - Otherwise, the initial value of the object being initialized is the
Douglas Gregor4a520a22009-12-14 17:27:33 +00004162 // (possibly converted) value of the initializer expression. Standard
Douglas Gregor20093b42009-12-09 23:02:17 +00004163 // conversions (Clause 4) will be used, if necessary, to convert the
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004164 // initializer expression to the cv-unqualified version of the
Douglas Gregor20093b42009-12-09 23:02:17 +00004165 // destination type; no user-defined conversions are considered.
John McCallf85e1932011-06-15 23:02:42 +00004166
4167 ImplicitConversionSequence ICS
4168 = S.TryImplicitConversion(Initializer, Entity.getType(),
4169 /*SuppressUserConversions*/true,
John McCall369371c2010-06-04 02:29:22 +00004170 /*AllowExplicitConversions*/ false,
Douglas Gregor14d0aee2011-01-27 00:58:17 +00004171 /*InOverloadResolution*/ false,
John McCallf85e1932011-06-15 23:02:42 +00004172 /*CStyle=*/Kind.isCStyleOrFunctionalCast(),
4173 allowObjCWritebackConversion);
4174
4175 if (ICS.isStandard() &&
4176 ICS.Standard.Second == ICK_Writeback_Conversion) {
4177 // Objective-C ARC writeback conversion.
4178
4179 // We should copy unless we're passing to an argument explicitly
4180 // marked 'out'.
4181 bool ShouldCopy = true;
4182 if (ParmVarDecl *Param = cast_or_null<ParmVarDecl>(Entity.getDecl()))
4183 ShouldCopy = (Param->getObjCDeclQualifier() != ParmVarDecl::OBJC_TQ_Out);
4184
4185 // If there was an lvalue adjustment, add it as a separate conversion.
4186 if (ICS.Standard.First == ICK_Array_To_Pointer ||
4187 ICS.Standard.First == ICK_Lvalue_To_Rvalue) {
4188 ImplicitConversionSequence LvalueICS;
4189 LvalueICS.setStandard();
4190 LvalueICS.Standard.setAsIdentityConversion();
4191 LvalueICS.Standard.setAllToTypes(ICS.Standard.getToType(0));
4192 LvalueICS.Standard.First = ICS.Standard.First;
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004193 AddConversionSequenceStep(LvalueICS, ICS.Standard.getToType(0));
John McCallf85e1932011-06-15 23:02:42 +00004194 }
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004195
4196 AddPassByIndirectCopyRestoreStep(Entity.getType(), ShouldCopy);
John McCallf85e1932011-06-15 23:02:42 +00004197 } else if (ICS.isBad()) {
Douglas Gregor1be8eec2011-02-19 21:32:49 +00004198 DeclAccessPair dap;
4199 if (Initializer->getType() == Context.OverloadTy &&
4200 !S.ResolveAddressOfOverloadedFunction(Initializer
4201 , DestType, false, dap))
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004202 SetFailed(InitializationSequence::FK_AddressOfOverloadFailed);
Douglas Gregor8e960432010-11-08 03:40:48 +00004203 else
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004204 SetFailed(InitializationSequence::FK_ConversionFailed);
John McCallf85e1932011-06-15 23:02:42 +00004205 } else {
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004206 AddConversionSequenceStep(ICS, Entity.getType());
John McCall856d3792011-06-16 23:24:51 +00004207
Rafael Espindola12ce0a02011-07-14 22:58:04 +00004208 MaybeProduceObjCObject(S, *this, Entity);
Douglas Gregor8e960432010-11-08 03:40:48 +00004209 }
Douglas Gregor20093b42009-12-09 23:02:17 +00004210}
4211
4212InitializationSequence::~InitializationSequence() {
Chris Lattner5f9e2722011-07-23 10:55:15 +00004213 for (SmallVectorImpl<Step>::iterator Step = Steps.begin(),
Douglas Gregor20093b42009-12-09 23:02:17 +00004214 StepEnd = Steps.end();
4215 Step != StepEnd; ++Step)
4216 Step->Destroy();
4217}
4218
4219//===----------------------------------------------------------------------===//
4220// Perform initialization
4221//===----------------------------------------------------------------------===//
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004222static Sema::AssignmentAction
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004223getAssignmentAction(const InitializedEntity &Entity) {
4224 switch(Entity.getKind()) {
4225 case InitializedEntity::EK_Variable:
4226 case InitializedEntity::EK_New:
Douglas Gregora3998bd2010-12-02 21:47:04 +00004227 case InitializedEntity::EK_Exception:
4228 case InitializedEntity::EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00004229 case InitializedEntity::EK_Delegating:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004230 return Sema::AA_Initializing;
4231
4232 case InitializedEntity::EK_Parameter:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004233 if (Entity.getDecl() &&
Douglas Gregor688fc9b2010-04-21 23:24:10 +00004234 isa<ObjCMethodDecl>(Entity.getDecl()->getDeclContext()))
4235 return Sema::AA_Sending;
4236
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004237 return Sema::AA_Passing;
4238
4239 case InitializedEntity::EK_Result:
4240 return Sema::AA_Returning;
4241
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004242 case InitializedEntity::EK_Temporary:
4243 // FIXME: Can we tell apart casting vs. converting?
4244 return Sema::AA_Casting;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004245
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004246 case InitializedEntity::EK_Member:
Anders Carlssond3d824d2010-01-23 04:34:47 +00004247 case InitializedEntity::EK_ArrayElement:
4248 case InitializedEntity::EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00004249 case InitializedEntity::EK_ComplexElement:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00004250 case InitializedEntity::EK_BlockElement:
Douglas Gregor47736542012-02-15 16:57:26 +00004251 case InitializedEntity::EK_LambdaCapture:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004252 return Sema::AA_Initializing;
4253 }
4254
David Blaikie7530c032012-01-17 06:56:22 +00004255 llvm_unreachable("Invalid EntityKind!");
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004256}
4257
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004258/// \brief Whether we should binding a created object as a temporary when
4259/// initializing the given entity.
Douglas Gregor2f599792010-04-02 18:24:57 +00004260static bool shouldBindAsTemporary(const InitializedEntity &Entity) {
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004261 switch (Entity.getKind()) {
Anders Carlsson1b36a2f2010-01-24 00:19:41 +00004262 case InitializedEntity::EK_ArrayElement:
4263 case InitializedEntity::EK_Member:
Douglas Gregor2f599792010-04-02 18:24:57 +00004264 case InitializedEntity::EK_Result:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004265 case InitializedEntity::EK_New:
4266 case InitializedEntity::EK_Variable:
4267 case InitializedEntity::EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00004268 case InitializedEntity::EK_Delegating:
Anders Carlssond3d824d2010-01-23 04:34:47 +00004269 case InitializedEntity::EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00004270 case InitializedEntity::EK_ComplexElement:
Anders Carlssona508b7d2010-02-06 23:23:06 +00004271 case InitializedEntity::EK_Exception:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00004272 case InitializedEntity::EK_BlockElement:
Douglas Gregor47736542012-02-15 16:57:26 +00004273 case InitializedEntity::EK_LambdaCapture:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004274 return false;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004275
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004276 case InitializedEntity::EK_Parameter:
4277 case InitializedEntity::EK_Temporary:
4278 return true;
4279 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004280
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004281 llvm_unreachable("missed an InitializedEntity kind?");
4282}
4283
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004284/// \brief Whether the given entity, when initialized with an object
4285/// created for that initialization, requires destruction.
4286static bool shouldDestroyTemporary(const InitializedEntity &Entity) {
4287 switch (Entity.getKind()) {
4288 case InitializedEntity::EK_Member:
4289 case InitializedEntity::EK_Result:
4290 case InitializedEntity::EK_New:
4291 case InitializedEntity::EK_Base:
Sean Hunt059ce0d2011-05-01 07:04:31 +00004292 case InitializedEntity::EK_Delegating:
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004293 case InitializedEntity::EK_VectorElement:
Eli Friedman0c706c22011-09-19 23:17:44 +00004294 case InitializedEntity::EK_ComplexElement:
Fariborz Jahanian310b1c42010-06-07 16:14:00 +00004295 case InitializedEntity::EK_BlockElement:
Douglas Gregor47736542012-02-15 16:57:26 +00004296 case InitializedEntity::EK_LambdaCapture:
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004297 return false;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004298
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004299 case InitializedEntity::EK_Variable:
4300 case InitializedEntity::EK_Parameter:
4301 case InitializedEntity::EK_Temporary:
4302 case InitializedEntity::EK_ArrayElement:
4303 case InitializedEntity::EK_Exception:
4304 return true;
4305 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004306
4307 llvm_unreachable("missed an InitializedEntity kind?");
Douglas Gregor4154e0b2010-04-24 23:45:46 +00004308}
4309
Richard Smith83da2e72011-10-19 16:55:56 +00004310/// \brief Look for copy and move constructors and constructor templates, for
4311/// copying an object via direct-initialization (per C++11 [dcl.init]p16).
4312static void LookupCopyAndMoveConstructors(Sema &S,
4313 OverloadCandidateSet &CandidateSet,
4314 CXXRecordDecl *Class,
4315 Expr *CurInitExpr) {
4316 DeclContext::lookup_iterator Con, ConEnd;
4317 for (llvm::tie(Con, ConEnd) = S.LookupConstructors(Class);
4318 Con != ConEnd; ++Con) {
4319 CXXConstructorDecl *Constructor = 0;
4320
4321 if ((Constructor = dyn_cast<CXXConstructorDecl>(*Con))) {
4322 // Handle copy/moveconstructors, only.
4323 if (!Constructor || Constructor->isInvalidDecl() ||
4324 !Constructor->isCopyOrMoveConstructor() ||
4325 !Constructor->isConvertingConstructor(/*AllowExplicit=*/true))
4326 continue;
4327
4328 DeclAccessPair FoundDecl
4329 = DeclAccessPair::make(Constructor, Constructor->getAccess());
4330 S.AddOverloadCandidate(Constructor, FoundDecl,
Ahmed Charles13a140c2012-02-25 11:00:22 +00004331 CurInitExpr, CandidateSet);
Richard Smith83da2e72011-10-19 16:55:56 +00004332 continue;
4333 }
4334
4335 // Handle constructor templates.
4336 FunctionTemplateDecl *ConstructorTmpl = cast<FunctionTemplateDecl>(*Con);
4337 if (ConstructorTmpl->isInvalidDecl())
4338 continue;
4339
4340 Constructor = cast<CXXConstructorDecl>(
4341 ConstructorTmpl->getTemplatedDecl());
4342 if (!Constructor->isConvertingConstructor(/*AllowExplicit=*/true))
4343 continue;
4344
4345 // FIXME: Do we need to limit this to copy-constructor-like
4346 // candidates?
4347 DeclAccessPair FoundDecl
4348 = DeclAccessPair::make(ConstructorTmpl, ConstructorTmpl->getAccess());
4349 S.AddTemplateOverloadCandidate(ConstructorTmpl, FoundDecl, 0,
Ahmed Charles13a140c2012-02-25 11:00:22 +00004350 CurInitExpr, CandidateSet, true);
Richard Smith83da2e72011-10-19 16:55:56 +00004351 }
4352}
4353
4354/// \brief Get the location at which initialization diagnostics should appear.
4355static SourceLocation getInitializationLoc(const InitializedEntity &Entity,
4356 Expr *Initializer) {
4357 switch (Entity.getKind()) {
4358 case InitializedEntity::EK_Result:
4359 return Entity.getReturnLoc();
4360
4361 case InitializedEntity::EK_Exception:
4362 return Entity.getThrowLoc();
4363
4364 case InitializedEntity::EK_Variable:
4365 return Entity.getDecl()->getLocation();
4366
Douglas Gregor47736542012-02-15 16:57:26 +00004367 case InitializedEntity::EK_LambdaCapture:
4368 return Entity.getCaptureLoc();
4369
Richard Smith83da2e72011-10-19 16:55:56 +00004370 case InitializedEntity::EK_ArrayElement:
4371 case InitializedEntity::EK_Member:
4372 case InitializedEntity::EK_Parameter:
4373 case InitializedEntity::EK_Temporary:
4374 case InitializedEntity::EK_New:
4375 case InitializedEntity::EK_Base:
4376 case InitializedEntity::EK_Delegating:
4377 case InitializedEntity::EK_VectorElement:
4378 case InitializedEntity::EK_ComplexElement:
4379 case InitializedEntity::EK_BlockElement:
4380 return Initializer->getLocStart();
4381 }
4382 llvm_unreachable("missed an InitializedEntity kind?");
4383}
4384
Douglas Gregor523d46a2010-04-18 07:40:54 +00004385/// \brief Make a (potentially elidable) temporary copy of the object
4386/// provided by the given initializer by calling the appropriate copy
4387/// constructor.
4388///
4389/// \param S The Sema object used for type-checking.
4390///
Abramo Bagnara63e7d252011-01-27 19:55:10 +00004391/// \param T The type of the temporary object, which must either be
Douglas Gregor523d46a2010-04-18 07:40:54 +00004392/// the type of the initializer expression or a superclass thereof.
4393///
James Dennett1dfbd922012-06-14 21:40:34 +00004394/// \param Entity The entity being initialized.
Douglas Gregor523d46a2010-04-18 07:40:54 +00004395///
4396/// \param CurInit The initializer expression.
4397///
4398/// \param IsExtraneousCopy Whether this is an "extraneous" copy that
4399/// is permitted in C++03 (but not C++0x) when binding a reference to
4400/// an rvalue.
4401///
4402/// \returns An expression that copies the initializer expression into
4403/// a temporary object, or an error expression if a copy could not be
4404/// created.
John McCall60d7b3a2010-08-24 06:29:42 +00004405static ExprResult CopyObject(Sema &S,
Douglas Gregor8fcc5162010-09-12 08:07:23 +00004406 QualType T,
4407 const InitializedEntity &Entity,
4408 ExprResult CurInit,
4409 bool IsExtraneousCopy) {
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004410 // Determine which class type we're copying to.
Anders Carlsson1b36a2f2010-01-24 00:19:41 +00004411 Expr *CurInitExpr = (Expr *)CurInit.get();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004412 CXXRecordDecl *Class = 0;
Douglas Gregor523d46a2010-04-18 07:40:54 +00004413 if (const RecordType *Record = T->getAs<RecordType>())
Douglas Gregor2f599792010-04-02 18:24:57 +00004414 Class = cast<CXXRecordDecl>(Record->getDecl());
4415 if (!Class)
4416 return move(CurInit);
4417
Douglas Gregorf5d8f462011-01-21 18:05:27 +00004418 // C++0x [class.copy]p32:
Douglas Gregor2f599792010-04-02 18:24:57 +00004419 // When certain criteria are met, an implementation is allowed to
4420 // omit the copy/move construction of a class object, even if the
4421 // copy/move constructor and/or destructor for the object have
4422 // side effects. [...]
4423 // - when a temporary class object that has not been bound to a
4424 // reference (12.2) would be copied/moved to a class object
4425 // with the same cv-unqualified type, the copy/move operation
4426 // can be omitted by constructing the temporary object
4427 // directly into the target of the omitted copy/move
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004428 //
Douglas Gregor2f599792010-04-02 18:24:57 +00004429 // Note that the other three bullets are handled elsewhere. Copy
Douglas Gregor3c9034c2010-05-15 00:13:29 +00004430 // elision for return statements and throw expressions are handled as part
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004431 // of constructor initialization, while copy elision for exception handlers
Douglas Gregor3c9034c2010-05-15 00:13:29 +00004432 // is handled by the run-time.
John McCall558d2ab2010-09-15 10:14:12 +00004433 bool Elidable = CurInitExpr->isTemporaryObject(S.Context, Class);
Richard Smith83da2e72011-10-19 16:55:56 +00004434 SourceLocation Loc = getInitializationLoc(Entity, CurInit.get());
Douglas Gregorf86fcb32010-04-24 21:09:25 +00004435
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004436 // Make sure that the type we are copying is complete.
Douglas Gregord10099e2012-05-04 16:32:21 +00004437 if (S.RequireCompleteType(Loc, T, diag::err_temp_copy_incomplete))
Douglas Gregorf86fcb32010-04-24 21:09:25 +00004438 return move(CurInit);
4439
Douglas Gregorcc15f012011-01-21 19:38:21 +00004440 // Perform overload resolution using the class's copy/move constructors.
Richard Smith83da2e72011-10-19 16:55:56 +00004441 // Only consider constructors and constructor templates. Per
4442 // C++0x [dcl.init]p16, second bullet to class types, this initialization
4443 // is direct-initialization.
John McCall5769d612010-02-08 23:07:23 +00004444 OverloadCandidateSet CandidateSet(Loc);
Richard Smith83da2e72011-10-19 16:55:56 +00004445 LookupCopyAndMoveConstructors(S, CandidateSet, Class, CurInitExpr);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004446
Abramo Bagnara7cc58b42011-10-05 07:56:41 +00004447 bool HadMultipleCandidates = (CandidateSet.size() > 1);
4448
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004449 OverloadCandidateSet::iterator Best;
Chandler Carruth25ca4212011-02-25 19:41:05 +00004450 switch (CandidateSet.BestViableFunction(S, Loc, Best)) {
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004451 case OR_Success:
4452 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004453
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004454 case OR_No_Viable_Function:
Jeffrey Yasskin57d12fd2010-06-07 15:58:05 +00004455 S.Diag(Loc, IsExtraneousCopy && !S.isSFINAEContext()
4456 ? diag::ext_rvalue_to_reference_temp_copy_no_viable
4457 : diag::err_temp_copy_no_viable)
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00004458 << (int)Entity.getKind() << CurInitExpr->getType()
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004459 << CurInitExpr->getSourceRange();
Ahmed Charles13a140c2012-02-25 11:00:22 +00004460 CandidateSet.NoteCandidates(S, OCD_AllCandidates, CurInitExpr);
Jeffrey Yasskin57d12fd2010-06-07 15:58:05 +00004461 if (!IsExtraneousCopy || S.isSFINAEContext())
John McCallf312b1e2010-08-26 23:41:50 +00004462 return ExprError();
Jeffrey Yasskin57d12fd2010-06-07 15:58:05 +00004463 return move(CurInit);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004464
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004465 case OR_Ambiguous:
4466 S.Diag(Loc, diag::err_temp_copy_ambiguous)
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00004467 << (int)Entity.getKind() << CurInitExpr->getType()
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004468 << CurInitExpr->getSourceRange();
Ahmed Charles13a140c2012-02-25 11:00:22 +00004469 CandidateSet.NoteCandidates(S, OCD_ViableCandidates, CurInitExpr);
John McCallf312b1e2010-08-26 23:41:50 +00004470 return ExprError();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004471
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004472 case OR_Deleted:
4473 S.Diag(Loc, diag::err_temp_copy_deleted)
Douglas Gregor7abfbdb2009-12-19 03:01:41 +00004474 << (int)Entity.getKind() << CurInitExpr->getType()
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004475 << CurInitExpr->getSourceRange();
Richard Smith6c4c36c2012-03-30 20:53:28 +00004476 S.NoteDeletedFunction(Best->Function);
John McCallf312b1e2010-08-26 23:41:50 +00004477 return ExprError();
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004478 }
4479
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004480 CXXConstructorDecl *Constructor = cast<CXXConstructorDecl>(Best->Function);
John McCallca0408f2010-08-23 06:44:23 +00004481 ASTOwningVector<Expr*> ConstructorArgs(S);
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004482 CurInit.release(); // Ownership transferred into MultiExprArg, below.
Douglas Gregor523d46a2010-04-18 07:40:54 +00004483
Anders Carlsson9a68a672010-04-21 18:47:17 +00004484 S.CheckConstructorAccess(Loc, Constructor, Entity,
Jeffrey Yasskin57d12fd2010-06-07 15:58:05 +00004485 Best->FoundDecl.getAccess(), IsExtraneousCopy);
Douglas Gregor523d46a2010-04-18 07:40:54 +00004486
4487 if (IsExtraneousCopy) {
4488 // If this is a totally extraneous copy for C++03 reference
4489 // binding purposes, just return the original initialization
Douglas Gregor2559a702010-04-18 07:57:34 +00004490 // expression. We don't generate an (elided) copy operation here
4491 // because doing so would require us to pass down a flag to avoid
4492 // infinite recursion, where each step adds another extraneous,
4493 // elidable copy.
Douglas Gregor523d46a2010-04-18 07:40:54 +00004494
Douglas Gregor2559a702010-04-18 07:57:34 +00004495 // Instantiate the default arguments of any extra parameters in
4496 // the selected copy constructor, as if we were going to create a
4497 // proper call to the copy constructor.
4498 for (unsigned I = 1, N = Constructor->getNumParams(); I != N; ++I) {
4499 ParmVarDecl *Parm = Constructor->getParamDecl(I);
4500 if (S.RequireCompleteType(Loc, Parm->getType(),
Douglas Gregord10099e2012-05-04 16:32:21 +00004501 diag::err_call_incomplete_argument))
Douglas Gregor2559a702010-04-18 07:57:34 +00004502 break;
4503
4504 // Build the default argument expression; we don't actually care
4505 // if this succeeds or not, because this routine will complain
4506 // if there was a problem.
4507 S.BuildCXXDefaultArgExpr(Loc, Constructor, Parm);
4508 }
4509
Douglas Gregor523d46a2010-04-18 07:40:54 +00004510 return S.Owned(CurInitExpr);
4511 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004512
Eli Friedman5f2987c2012-02-02 03:46:19 +00004513 S.MarkFunctionReferenced(Loc, Constructor);
Chandler Carruth25ca4212011-02-25 19:41:05 +00004514
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004515 // Determine the arguments required to actually perform the
Douglas Gregor523d46a2010-04-18 07:40:54 +00004516 // constructor call (we might have derived-to-base conversions, or
4517 // the copy constructor may have default arguments).
John McCallf312b1e2010-08-26 23:41:50 +00004518 if (S.CompleteConstructorCall(Constructor, MultiExprArg(&CurInitExpr, 1),
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004519 Loc, ConstructorArgs))
John McCallf312b1e2010-08-26 23:41:50 +00004520 return ExprError();
Douglas Gregor3fbaf3e2010-04-17 22:01:05 +00004521
Douglas Gregorb86cf0c2010-04-25 00:55:24 +00004522 // Actually perform the constructor call.
4523 CurInit = S.BuildCXXConstructExpr(Loc, T, Constructor, Elidable,
John McCall7a1fad32010-08-24 07:32:53 +00004524 move_arg(ConstructorArgs),
Abramo Bagnara7cc58b42011-10-05 07:56:41 +00004525 HadMultipleCandidates,
John McCall7a1fad32010-08-24 07:32:53 +00004526 /*ZeroInit*/ false,
Chandler Carruth428edaf2010-10-25 08:47:36 +00004527 CXXConstructExpr::CK_Complete,
4528 SourceRange());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004529
Douglas Gregorb86cf0c2010-04-25 00:55:24 +00004530 // If we're supposed to bind temporaries, do so.
4531 if (!CurInit.isInvalid() && shouldBindAsTemporary(Entity))
4532 CurInit = S.MaybeBindToTemporary(CurInit.takeAs<Expr>());
4533 return move(CurInit);
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004534}
Douglas Gregor20093b42009-12-09 23:02:17 +00004535
Richard Smith83da2e72011-10-19 16:55:56 +00004536/// \brief Check whether elidable copy construction for binding a reference to
4537/// a temporary would have succeeded if we were building in C++98 mode, for
4538/// -Wc++98-compat.
4539static void CheckCXX98CompatAccessibleCopy(Sema &S,
4540 const InitializedEntity &Entity,
4541 Expr *CurInitExpr) {
David Blaikie4e4d0842012-03-11 07:00:24 +00004542 assert(S.getLangOpts().CPlusPlus0x);
Richard Smith83da2e72011-10-19 16:55:56 +00004543
4544 const RecordType *Record = CurInitExpr->getType()->getAs<RecordType>();
4545 if (!Record)
4546 return;
4547
4548 SourceLocation Loc = getInitializationLoc(Entity, CurInitExpr);
4549 if (S.Diags.getDiagnosticLevel(diag::warn_cxx98_compat_temp_copy, Loc)
4550 == DiagnosticsEngine::Ignored)
4551 return;
4552
4553 // Find constructors which would have been considered.
4554 OverloadCandidateSet CandidateSet(Loc);
4555 LookupCopyAndMoveConstructors(
4556 S, CandidateSet, cast<CXXRecordDecl>(Record->getDecl()), CurInitExpr);
4557
4558 // Perform overload resolution.
4559 OverloadCandidateSet::iterator Best;
4560 OverloadingResult OR = CandidateSet.BestViableFunction(S, Loc, Best);
4561
4562 PartialDiagnostic Diag = S.PDiag(diag::warn_cxx98_compat_temp_copy)
4563 << OR << (int)Entity.getKind() << CurInitExpr->getType()
4564 << CurInitExpr->getSourceRange();
4565
4566 switch (OR) {
4567 case OR_Success:
4568 S.CheckConstructorAccess(Loc, cast<CXXConstructorDecl>(Best->Function),
John McCallb9abd8722012-04-07 03:04:20 +00004569 Entity, Best->FoundDecl.getAccess(), Diag);
Richard Smith83da2e72011-10-19 16:55:56 +00004570 // FIXME: Check default arguments as far as that's possible.
4571 break;
4572
4573 case OR_No_Viable_Function:
4574 S.Diag(Loc, Diag);
Ahmed Charles13a140c2012-02-25 11:00:22 +00004575 CandidateSet.NoteCandidates(S, OCD_AllCandidates, CurInitExpr);
Richard Smith83da2e72011-10-19 16:55:56 +00004576 break;
4577
4578 case OR_Ambiguous:
4579 S.Diag(Loc, Diag);
Ahmed Charles13a140c2012-02-25 11:00:22 +00004580 CandidateSet.NoteCandidates(S, OCD_ViableCandidates, CurInitExpr);
Richard Smith83da2e72011-10-19 16:55:56 +00004581 break;
4582
4583 case OR_Deleted:
4584 S.Diag(Loc, Diag);
Richard Smith6c4c36c2012-03-30 20:53:28 +00004585 S.NoteDeletedFunction(Best->Function);
Richard Smith83da2e72011-10-19 16:55:56 +00004586 break;
4587 }
4588}
4589
Douglas Gregora41a8c52010-04-22 00:20:18 +00004590void InitializationSequence::PrintInitLocationNote(Sema &S,
4591 const InitializedEntity &Entity) {
4592 if (Entity.getKind() == InitializedEntity::EK_Parameter && Entity.getDecl()) {
4593 if (Entity.getDecl()->getLocation().isInvalid())
4594 return;
4595
4596 if (Entity.getDecl()->getDeclName())
4597 S.Diag(Entity.getDecl()->getLocation(), diag::note_parameter_named_here)
4598 << Entity.getDecl()->getDeclName();
4599 else
4600 S.Diag(Entity.getDecl()->getLocation(), diag::note_parameter_here);
4601 }
4602}
4603
Sebastian Redl3b802322011-07-14 19:07:55 +00004604static bool isReferenceBinding(const InitializationSequence::Step &s) {
4605 return s.Kind == InitializationSequence::SK_BindReference ||
4606 s.Kind == InitializationSequence::SK_BindReferenceToTemporary;
4607}
4608
Sebastian Redl10f04a62011-12-22 14:44:04 +00004609static ExprResult
4610PerformConstructorInitialization(Sema &S,
4611 const InitializedEntity &Entity,
4612 const InitializationKind &Kind,
4613 MultiExprArg Args,
4614 const InitializationSequence::Step& Step,
4615 bool &ConstructorInitRequiresZeroInit) {
4616 unsigned NumArgs = Args.size();
4617 CXXConstructorDecl *Constructor
4618 = cast<CXXConstructorDecl>(Step.Function.Function);
4619 bool HadMultipleCandidates = Step.Function.HadMultipleCandidates;
4620
4621 // Build a call to the selected constructor.
4622 ASTOwningVector<Expr*> ConstructorArgs(S);
4623 SourceLocation Loc = (Kind.isCopyInit() && Kind.getEqualLoc().isValid())
4624 ? Kind.getEqualLoc()
4625 : Kind.getLocation();
4626
4627 if (Kind.getKind() == InitializationKind::IK_Default) {
4628 // Force even a trivial, implicit default constructor to be
4629 // semantically checked. We do this explicitly because we don't build
4630 // the definition for completely trivial constructors.
Matt Beaumont-Gay28e47022012-02-24 08:37:56 +00004631 assert(Constructor->getParent() && "No parent class for constructor.");
Sebastian Redl10f04a62011-12-22 14:44:04 +00004632 if (Constructor->isDefaulted() && Constructor->isDefaultConstructor() &&
Douglas Gregor5d86f612012-02-24 07:48:37 +00004633 Constructor->isTrivial() && !Constructor->isUsed(false))
Sebastian Redl10f04a62011-12-22 14:44:04 +00004634 S.DefineImplicitDefaultConstructor(Loc, Constructor);
4635 }
4636
4637 ExprResult CurInit = S.Owned((Expr *)0);
4638
Douglas Gregored878af2012-02-24 23:56:31 +00004639 // C++ [over.match.copy]p1:
4640 // - When initializing a temporary to be bound to the first parameter
4641 // of a constructor that takes a reference to possibly cv-qualified
4642 // T as its first argument, called with a single argument in the
4643 // context of direct-initialization, explicit conversion functions
4644 // are also considered.
4645 bool AllowExplicitConv = Kind.AllowExplicit() && !Kind.isCopyInit() &&
4646 Args.size() == 1 &&
4647 Constructor->isCopyOrMoveConstructor();
4648
Sebastian Redl10f04a62011-12-22 14:44:04 +00004649 // Determine the arguments required to actually perform the constructor
4650 // call.
4651 if (S.CompleteConstructorCall(Constructor, move(Args),
Douglas Gregored878af2012-02-24 23:56:31 +00004652 Loc, ConstructorArgs,
4653 AllowExplicitConv))
Sebastian Redl10f04a62011-12-22 14:44:04 +00004654 return ExprError();
4655
4656
4657 if (Entity.getKind() == InitializedEntity::EK_Temporary &&
Sebastian Redl188158d2012-03-08 21:05:45 +00004658 (Kind.getKind() == InitializationKind::IK_DirectList ||
4659 (NumArgs != 1 && // FIXME: Hack to work around cast weirdness
4660 (Kind.getKind() == InitializationKind::IK_Direct ||
4661 Kind.getKind() == InitializationKind::IK_Value)))) {
Sebastian Redl10f04a62011-12-22 14:44:04 +00004662 // An explicitly-constructed temporary, e.g., X(1, 2).
4663 unsigned NumExprs = ConstructorArgs.size();
4664 Expr **Exprs = (Expr **)ConstructorArgs.take();
Eli Friedman5f2987c2012-02-02 03:46:19 +00004665 S.MarkFunctionReferenced(Loc, Constructor);
Sebastian Redl10f04a62011-12-22 14:44:04 +00004666 S.DiagnoseUseOfDecl(Constructor, Loc);
4667
4668 TypeSourceInfo *TSInfo = Entity.getTypeSourceInfo();
4669 if (!TSInfo)
4670 TSInfo = S.Context.getTrivialTypeSourceInfo(Entity.getType(), Loc);
Sebastian Redl188158d2012-03-08 21:05:45 +00004671 SourceRange ParenRange;
4672 if (Kind.getKind() != InitializationKind::IK_DirectList)
4673 ParenRange = Kind.getParenRange();
Sebastian Redl10f04a62011-12-22 14:44:04 +00004674
4675 CurInit = S.Owned(new (S.Context) CXXTemporaryObjectExpr(S.Context,
4676 Constructor,
4677 TSInfo,
4678 Exprs,
4679 NumExprs,
Sebastian Redl188158d2012-03-08 21:05:45 +00004680 ParenRange,
Sebastian Redl10f04a62011-12-22 14:44:04 +00004681 HadMultipleCandidates,
4682 ConstructorInitRequiresZeroInit));
4683 } else {
4684 CXXConstructExpr::ConstructionKind ConstructKind =
4685 CXXConstructExpr::CK_Complete;
4686
4687 if (Entity.getKind() == InitializedEntity::EK_Base) {
4688 ConstructKind = Entity.getBaseSpecifier()->isVirtual() ?
4689 CXXConstructExpr::CK_VirtualBase :
4690 CXXConstructExpr::CK_NonVirtualBase;
4691 } else if (Entity.getKind() == InitializedEntity::EK_Delegating) {
4692 ConstructKind = CXXConstructExpr::CK_Delegating;
4693 }
4694
4695 // Only get the parenthesis range if it is a direct construction.
4696 SourceRange parenRange =
4697 Kind.getKind() == InitializationKind::IK_Direct ?
4698 Kind.getParenRange() : SourceRange();
4699
4700 // If the entity allows NRVO, mark the construction as elidable
4701 // unconditionally.
4702 if (Entity.allowsNRVO())
4703 CurInit = S.BuildCXXConstructExpr(Loc, Entity.getType(),
4704 Constructor, /*Elidable=*/true,
4705 move_arg(ConstructorArgs),
4706 HadMultipleCandidates,
4707 ConstructorInitRequiresZeroInit,
4708 ConstructKind,
4709 parenRange);
4710 else
4711 CurInit = S.BuildCXXConstructExpr(Loc, Entity.getType(),
4712 Constructor,
4713 move_arg(ConstructorArgs),
4714 HadMultipleCandidates,
4715 ConstructorInitRequiresZeroInit,
4716 ConstructKind,
4717 parenRange);
4718 }
4719 if (CurInit.isInvalid())
4720 return ExprError();
4721
4722 // Only check access if all of that succeeded.
4723 S.CheckConstructorAccess(Loc, Constructor, Entity,
4724 Step.Function.FoundDecl.getAccess());
4725 S.DiagnoseUseOfDecl(Step.Function.FoundDecl, Loc);
4726
4727 if (shouldBindAsTemporary(Entity))
4728 CurInit = S.MaybeBindToTemporary(CurInit.takeAs<Expr>());
4729
4730 return move(CurInit);
4731}
4732
Richard Smith36d02af2012-06-04 22:27:30 +00004733/// Determine whether the specified InitializedEntity definitely has a lifetime
4734/// longer than the current full-expression. Conservatively returns false if
4735/// it's unclear.
4736static bool
4737InitializedEntityOutlivesFullExpression(const InitializedEntity &Entity) {
4738 const InitializedEntity *Top = &Entity;
4739 while (Top->getParent())
4740 Top = Top->getParent();
4741
4742 switch (Top->getKind()) {
4743 case InitializedEntity::EK_Variable:
4744 case InitializedEntity::EK_Result:
4745 case InitializedEntity::EK_Exception:
4746 case InitializedEntity::EK_Member:
4747 case InitializedEntity::EK_New:
4748 case InitializedEntity::EK_Base:
4749 case InitializedEntity::EK_Delegating:
4750 return true;
4751
4752 case InitializedEntity::EK_ArrayElement:
4753 case InitializedEntity::EK_VectorElement:
4754 case InitializedEntity::EK_BlockElement:
4755 case InitializedEntity::EK_ComplexElement:
4756 // Could not determine what the full initialization is. Assume it might not
4757 // outlive the full-expression.
4758 return false;
4759
4760 case InitializedEntity::EK_Parameter:
4761 case InitializedEntity::EK_Temporary:
4762 case InitializedEntity::EK_LambdaCapture:
4763 // The entity being initialized might not outlive the full-expression.
4764 return false;
4765 }
4766
4767 llvm_unreachable("unknown entity kind");
4768}
4769
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004770ExprResult
Douglas Gregor20093b42009-12-09 23:02:17 +00004771InitializationSequence::Perform(Sema &S,
4772 const InitializedEntity &Entity,
4773 const InitializationKind &Kind,
John McCallf312b1e2010-08-26 23:41:50 +00004774 MultiExprArg Args,
Douglas Gregord87b61f2009-12-10 17:56:55 +00004775 QualType *ResultType) {
Sebastian Redld695d6b2011-06-05 13:59:05 +00004776 if (Failed()) {
Douglas Gregor20093b42009-12-09 23:02:17 +00004777 unsigned NumArgs = Args.size();
4778 Diagnose(S, Entity, Kind, (Expr **)Args.release(), NumArgs);
John McCallf312b1e2010-08-26 23:41:50 +00004779 return ExprError();
Douglas Gregor20093b42009-12-09 23:02:17 +00004780 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004781
Sebastian Redl7491c492011-06-05 13:59:11 +00004782 if (getKind() == DependentSequence) {
Douglas Gregord87b61f2009-12-10 17:56:55 +00004783 // If the declaration is a non-dependent, incomplete array type
4784 // that has an initializer, then its type will be completed once
4785 // the initializer is instantiated.
Douglas Gregord6542d82009-12-22 15:35:07 +00004786 if (ResultType && !Entity.getType()->isDependentType() &&
Douglas Gregord87b61f2009-12-10 17:56:55 +00004787 Args.size() == 1) {
Douglas Gregord6542d82009-12-22 15:35:07 +00004788 QualType DeclType = Entity.getType();
Douglas Gregord87b61f2009-12-10 17:56:55 +00004789 if (const IncompleteArrayType *ArrayT
4790 = S.Context.getAsIncompleteArrayType(DeclType)) {
4791 // FIXME: We don't currently have the ability to accurately
4792 // compute the length of an initializer list without
4793 // performing full type-checking of the initializer list
4794 // (since we have to determine where braces are implicitly
4795 // introduced and such). So, we fall back to making the array
4796 // type a dependently-sized array type with no specified
4797 // bound.
4798 if (isa<InitListExpr>((Expr *)Args.get()[0])) {
4799 SourceRange Brackets;
Douglas Gregord6542d82009-12-22 15:35:07 +00004800
Douglas Gregord87b61f2009-12-10 17:56:55 +00004801 // Scavange the location of the brackets from the entity, if we can.
Douglas Gregord6542d82009-12-22 15:35:07 +00004802 if (DeclaratorDecl *DD = Entity.getDecl()) {
4803 if (TypeSourceInfo *TInfo = DD->getTypeSourceInfo()) {
4804 TypeLoc TL = TInfo->getTypeLoc();
4805 if (IncompleteArrayTypeLoc *ArrayLoc
4806 = dyn_cast<IncompleteArrayTypeLoc>(&TL))
4807 Brackets = ArrayLoc->getBracketsRange();
4808 }
Douglas Gregord87b61f2009-12-10 17:56:55 +00004809 }
4810
4811 *ResultType
4812 = S.Context.getDependentSizedArrayType(ArrayT->getElementType(),
4813 /*NumElts=*/0,
4814 ArrayT->getSizeModifier(),
4815 ArrayT->getIndexTypeCVRQualifiers(),
4816 Brackets);
4817 }
4818
4819 }
4820 }
Sebastian Redl5b9cc5d2012-02-11 23:51:47 +00004821 if (Kind.getKind() == InitializationKind::IK_Direct &&
4822 !Kind.isExplicitCast()) {
4823 // Rebuild the ParenListExpr.
4824 SourceRange ParenRange = Kind.getParenRange();
4825 return S.ActOnParenListExpr(ParenRange.getBegin(), ParenRange.getEnd(),
4826 move(Args));
4827 }
Manuel Klimek0d9106f2011-06-22 20:02:16 +00004828 assert(Kind.getKind() == InitializationKind::IK_Copy ||
Douglas Gregora9b55a42012-04-04 04:06:51 +00004829 Kind.isExplicitCast() ||
4830 Kind.getKind() == InitializationKind::IK_DirectList);
Manuel Klimek0d9106f2011-06-22 20:02:16 +00004831 return ExprResult(Args.release()[0]);
Douglas Gregor20093b42009-12-09 23:02:17 +00004832 }
4833
Sebastian Redl7491c492011-06-05 13:59:11 +00004834 // No steps means no initialization.
4835 if (Steps.empty())
Douglas Gregor99a2e602009-12-16 01:38:02 +00004836 return S.Owned((Expr *)0);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004837
Richard Smith03544fc2012-04-19 06:58:00 +00004838 if (S.getLangOpts().CPlusPlus0x && Entity.getType()->isReferenceType() &&
4839 Args.size() == 1 && isa<InitListExpr>(Args.get()[0]) &&
4840 Entity.getKind() != InitializedEntity::EK_Parameter) {
4841 // Produce a C++98 compatibility warning if we are initializing a reference
4842 // from an initializer list. For parameters, we produce a better warning
4843 // elsewhere.
4844 Expr *Init = Args.get()[0];
4845 S.Diag(Init->getLocStart(), diag::warn_cxx98_compat_reference_list_init)
4846 << Init->getSourceRange();
4847 }
4848
Richard Smith36d02af2012-06-04 22:27:30 +00004849 // Diagnose cases where we initialize a pointer to an array temporary, and the
4850 // pointer obviously outlives the temporary.
4851 if (Args.size() == 1 && Args.get()[0]->getType()->isArrayType() &&
4852 Entity.getType()->isPointerType() &&
4853 InitializedEntityOutlivesFullExpression(Entity)) {
4854 Expr *Init = Args.get()[0];
4855 Expr::LValueClassification Kind = Init->ClassifyLValue(S.Context);
4856 if (Kind == Expr::LV_ClassTemporary || Kind == Expr::LV_ArrayTemporary)
4857 S.Diag(Init->getLocStart(), diag::warn_temporary_array_to_pointer_decay)
4858 << Init->getSourceRange();
4859 }
4860
Douglas Gregord6542d82009-12-22 15:35:07 +00004861 QualType DestType = Entity.getType().getNonReferenceType();
4862 // FIXME: Ugly hack around the fact that Entity.getType() is not
Eli Friedmana91eb542009-12-22 02:10:53 +00004863 // the same as Entity.getDecl()->getType() in cases involving type merging,
4864 // and we want latter when it makes sense.
Douglas Gregord87b61f2009-12-10 17:56:55 +00004865 if (ResultType)
Eli Friedmana91eb542009-12-22 02:10:53 +00004866 *ResultType = Entity.getDecl() ? Entity.getDecl()->getType() :
Douglas Gregord6542d82009-12-22 15:35:07 +00004867 Entity.getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00004868
John McCall60d7b3a2010-08-24 06:29:42 +00004869 ExprResult CurInit = S.Owned((Expr *)0);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004870
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004871 // For initialization steps that start with a single initializer,
Douglas Gregor99a2e602009-12-16 01:38:02 +00004872 // grab the only argument out the Args and place it into the "current"
4873 // initializer.
4874 switch (Steps.front().Kind) {
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004875 case SK_ResolveAddressOfOverloadedFunction:
4876 case SK_CastDerivedToBaseRValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00004877 case SK_CastDerivedToBaseXValue:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004878 case SK_CastDerivedToBaseLValue:
4879 case SK_BindReference:
4880 case SK_BindReferenceToTemporary:
Douglas Gregor523d46a2010-04-18 07:40:54 +00004881 case SK_ExtraneousCopyToTemporary:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004882 case SK_UserConversion:
4883 case SK_QualificationConversionLValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00004884 case SK_QualificationConversionXValue:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004885 case SK_QualificationConversionRValue:
4886 case SK_ConversionSequence:
4887 case SK_ListInitialization:
Sebastian Redl13dc8f92011-11-27 16:50:07 +00004888 case SK_UnwrapInitList:
4889 case SK_RewrapInitList:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004890 case SK_CAssignment:
Eli Friedmancfdc81a2009-12-19 08:11:05 +00004891 case SK_StringInit:
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00004892 case SK_ObjCObjectConversion:
John McCallf85e1932011-06-15 23:02:42 +00004893 case SK_ArrayInit:
Richard Smith0f163e92012-02-15 22:38:09 +00004894 case SK_ParenthesizedArrayInit:
John McCallf85e1932011-06-15 23:02:42 +00004895 case SK_PassByIndirectCopyRestore:
4896 case SK_PassByIndirectRestore:
Sebastian Redl2b916b82012-01-17 22:49:42 +00004897 case SK_ProduceObjCObject:
4898 case SK_StdInitializerList: {
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004899 assert(Args.size() == 1);
John Wiegley429bb272011-04-08 18:41:53 +00004900 CurInit = Args.get()[0];
4901 if (!CurInit.get()) return ExprError();
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004902 break;
John McCallf6a16482010-12-04 03:47:34 +00004903 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004904
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004905 case SK_ConstructorInitialization:
Richard Smithf4bb8d02012-07-05 08:39:21 +00004906 case SK_ListConstructorCall:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00004907 case SK_ZeroInitialization:
4908 break;
Douglas Gregor20093b42009-12-09 23:02:17 +00004909 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004910
4911 // Walk through the computed steps for the initialization sequence,
Douglas Gregor20093b42009-12-09 23:02:17 +00004912 // performing the specified conversions along the way.
Douglas Gregor16006c92009-12-16 18:50:27 +00004913 bool ConstructorInitRequiresZeroInit = false;
Douglas Gregor20093b42009-12-09 23:02:17 +00004914 for (step_iterator Step = step_begin(), StepEnd = step_end();
4915 Step != StepEnd; ++Step) {
4916 if (CurInit.isInvalid())
John McCallf312b1e2010-08-26 23:41:50 +00004917 return ExprError();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004918
John Wiegley429bb272011-04-08 18:41:53 +00004919 QualType SourceType = CurInit.get() ? CurInit.get()->getType() : QualType();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004920
Douglas Gregor20093b42009-12-09 23:02:17 +00004921 switch (Step->Kind) {
4922 case SK_ResolveAddressOfOverloadedFunction:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004923 // Overload resolution determined which function invoke; update the
Douglas Gregor20093b42009-12-09 23:02:17 +00004924 // initializer to reflect that choice.
John Wiegley429bb272011-04-08 18:41:53 +00004925 S.CheckAddressOfMemberAccess(CurInit.get(), Step->Function.FoundDecl);
John McCallb697e082010-05-06 18:15:07 +00004926 S.DiagnoseUseOfDecl(Step->Function.FoundDecl, Kind.getLocation());
John McCallb13b7372010-02-01 03:16:54 +00004927 CurInit = S.FixOverloadedFunctionReference(move(CurInit),
John McCall6bb80172010-03-30 21:47:33 +00004928 Step->Function.FoundDecl,
John McCall9aa472c2010-03-19 07:35:19 +00004929 Step->Function.Function);
Douglas Gregor20093b42009-12-09 23:02:17 +00004930 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004931
Douglas Gregor20093b42009-12-09 23:02:17 +00004932 case SK_CastDerivedToBaseRValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00004933 case SK_CastDerivedToBaseXValue:
Douglas Gregor20093b42009-12-09 23:02:17 +00004934 case SK_CastDerivedToBaseLValue: {
4935 // We have a derived-to-base cast that produces either an rvalue or an
4936 // lvalue. Perform that cast.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004937
John McCallf871d0c2010-08-07 06:22:56 +00004938 CXXCastPath BasePath;
Anders Carlsson5cf86ba2010-04-24 19:06:50 +00004939
Douglas Gregor20093b42009-12-09 23:02:17 +00004940 // Casts to inaccessible base classes are allowed with C-style casts.
4941 bool IgnoreBaseAccess = Kind.isCStyleOrFunctionalCast();
4942 if (S.CheckDerivedToBaseConversion(SourceType, Step->Type,
John Wiegley429bb272011-04-08 18:41:53 +00004943 CurInit.get()->getLocStart(),
4944 CurInit.get()->getSourceRange(),
Anders Carlsson5cf86ba2010-04-24 19:06:50 +00004945 &BasePath, IgnoreBaseAccess))
John McCallf312b1e2010-08-26 23:41:50 +00004946 return ExprError();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004947
Douglas Gregor6fb745b2010-05-13 16:44:06 +00004948 if (S.BasePathInvolvesVirtualBase(BasePath)) {
4949 QualType T = SourceType;
4950 if (const PointerType *Pointer = T->getAs<PointerType>())
4951 T = Pointer->getPointeeType();
4952 if (const RecordType *RecordTy = T->getAs<RecordType>())
John Wiegley429bb272011-04-08 18:41:53 +00004953 S.MarkVTableUsed(CurInit.get()->getLocStart(),
Douglas Gregor6fb745b2010-05-13 16:44:06 +00004954 cast<CXXRecordDecl>(RecordTy->getDecl()));
4955 }
4956
John McCall5baba9d2010-08-25 10:28:54 +00004957 ExprValueKind VK =
Sebastian Redl906082e2010-07-20 04:20:21 +00004958 Step->Kind == SK_CastDerivedToBaseLValue ?
John McCall5baba9d2010-08-25 10:28:54 +00004959 VK_LValue :
Sebastian Redl906082e2010-07-20 04:20:21 +00004960 (Step->Kind == SK_CastDerivedToBaseXValue ?
John McCall5baba9d2010-08-25 10:28:54 +00004961 VK_XValue :
4962 VK_RValue);
John McCallf871d0c2010-08-07 06:22:56 +00004963 CurInit = S.Owned(ImplicitCastExpr::Create(S.Context,
4964 Step->Type,
John McCall2de56d12010-08-25 11:45:40 +00004965 CK_DerivedToBase,
John McCall5baba9d2010-08-25 10:28:54 +00004966 CurInit.get(),
4967 &BasePath, VK));
Douglas Gregor20093b42009-12-09 23:02:17 +00004968 break;
4969 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004970
Douglas Gregor20093b42009-12-09 23:02:17 +00004971 case SK_BindReference:
John Wiegley429bb272011-04-08 18:41:53 +00004972 if (FieldDecl *BitField = CurInit.get()->getBitField()) {
Douglas Gregor20093b42009-12-09 23:02:17 +00004973 // References cannot bind to bit fields (C++ [dcl.init.ref]p5).
4974 S.Diag(Kind.getLocation(), diag::err_reference_bind_to_bitfield)
Douglas Gregord6542d82009-12-22 15:35:07 +00004975 << Entity.getType().isVolatileQualified()
Douglas Gregor20093b42009-12-09 23:02:17 +00004976 << BitField->getDeclName()
John Wiegley429bb272011-04-08 18:41:53 +00004977 << CurInit.get()->getSourceRange();
Douglas Gregor20093b42009-12-09 23:02:17 +00004978 S.Diag(BitField->getLocation(), diag::note_bitfield_decl);
John McCallf312b1e2010-08-26 23:41:50 +00004979 return ExprError();
Douglas Gregor20093b42009-12-09 23:02:17 +00004980 }
Anders Carlssona6fe0bf2010-01-29 02:47:33 +00004981
John Wiegley429bb272011-04-08 18:41:53 +00004982 if (CurInit.get()->refersToVectorElement()) {
John McCall41593e32010-02-02 19:02:38 +00004983 // References cannot bind to vector elements.
Anders Carlsson09380262010-01-31 17:18:49 +00004984 S.Diag(Kind.getLocation(), diag::err_reference_bind_to_vector_element)
4985 << Entity.getType().isVolatileQualified()
John Wiegley429bb272011-04-08 18:41:53 +00004986 << CurInit.get()->getSourceRange();
Douglas Gregora41a8c52010-04-22 00:20:18 +00004987 PrintInitLocationNote(S, Entity);
John McCallf312b1e2010-08-26 23:41:50 +00004988 return ExprError();
Anders Carlsson09380262010-01-31 17:18:49 +00004989 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00004990
Douglas Gregor20093b42009-12-09 23:02:17 +00004991 // Reference binding does not have any corresponding ASTs.
4992
4993 // Check exception specifications
John Wiegley429bb272011-04-08 18:41:53 +00004994 if (S.CheckExceptionSpecCompatibility(CurInit.get(), DestType))
John McCallf312b1e2010-08-26 23:41:50 +00004995 return ExprError();
Anders Carlsson3aba0932010-01-31 18:34:51 +00004996
Douglas Gregor20093b42009-12-09 23:02:17 +00004997 break;
Anders Carlsson3aba0932010-01-31 18:34:51 +00004998
Douglas Gregor20093b42009-12-09 23:02:17 +00004999 case SK_BindReferenceToTemporary:
5000 // Check exception specifications
John Wiegley429bb272011-04-08 18:41:53 +00005001 if (S.CheckExceptionSpecCompatibility(CurInit.get(), DestType))
John McCallf312b1e2010-08-26 23:41:50 +00005002 return ExprError();
Douglas Gregor20093b42009-12-09 23:02:17 +00005003
Douglas Gregor03e80032011-06-21 17:03:29 +00005004 // Materialize the temporary into memory.
Douglas Gregorb4b7b502011-06-22 15:05:02 +00005005 CurInit = new (S.Context) MaterializeTemporaryExpr(
5006 Entity.getType().getNonReferenceType(),
5007 CurInit.get(),
Douglas Gregor03e80032011-06-21 17:03:29 +00005008 Entity.getType()->isLValueReferenceType());
Douglas Gregord7b23162011-06-22 16:12:01 +00005009
5010 // If we're binding to an Objective-C object that has lifetime, we
5011 // need cleanups.
David Blaikie4e4d0842012-03-11 07:00:24 +00005012 if (S.getLangOpts().ObjCAutoRefCount &&
Douglas Gregord7b23162011-06-22 16:12:01 +00005013 CurInit.get()->getType()->isObjCLifetimeType())
5014 S.ExprNeedsCleanups = true;
5015
Douglas Gregor20093b42009-12-09 23:02:17 +00005016 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005017
Douglas Gregor523d46a2010-04-18 07:40:54 +00005018 case SK_ExtraneousCopyToTemporary:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005019 CurInit = CopyObject(S, Step->Type, Entity, move(CurInit),
Douglas Gregor523d46a2010-04-18 07:40:54 +00005020 /*IsExtraneousCopy=*/true);
5021 break;
5022
Douglas Gregor20093b42009-12-09 23:02:17 +00005023 case SK_UserConversion: {
5024 // We have a user-defined conversion that invokes either a constructor
5025 // or a conversion function.
John McCalldaa8e4e2010-11-15 09:13:47 +00005026 CastKind CastKind;
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005027 bool IsCopy = false;
John McCall9aa472c2010-03-19 07:35:19 +00005028 FunctionDecl *Fn = Step->Function.Function;
5029 DeclAccessPair FoundFn = Step->Function.FoundDecl;
Abramo Bagnara7cc58b42011-10-05 07:56:41 +00005030 bool HadMultipleCandidates = Step->Function.HadMultipleCandidates;
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005031 bool CreatedObject = false;
John McCallb13b7372010-02-01 03:16:54 +00005032 if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(Fn)) {
Douglas Gregor20093b42009-12-09 23:02:17 +00005033 // Build a call to the selected constructor.
John McCallca0408f2010-08-23 06:44:23 +00005034 ASTOwningVector<Expr*> ConstructorArgs(S);
John Wiegley429bb272011-04-08 18:41:53 +00005035 SourceLocation Loc = CurInit.get()->getLocStart();
Douglas Gregor20093b42009-12-09 23:02:17 +00005036 CurInit.release(); // Ownership transferred into MultiExprArg, below.
John McCallb13b7372010-02-01 03:16:54 +00005037
Douglas Gregor20093b42009-12-09 23:02:17 +00005038 // Determine the arguments required to actually perform the constructor
5039 // call.
John Wiegley429bb272011-04-08 18:41:53 +00005040 Expr *Arg = CurInit.get();
Douglas Gregor20093b42009-12-09 23:02:17 +00005041 if (S.CompleteConstructorCall(Constructor,
John Wiegley429bb272011-04-08 18:41:53 +00005042 MultiExprArg(&Arg, 1),
Douglas Gregor20093b42009-12-09 23:02:17 +00005043 Loc, ConstructorArgs))
John McCallf312b1e2010-08-26 23:41:50 +00005044 return ExprError();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005045
Richard Smithf2e4dfc2012-02-11 19:22:50 +00005046 // Build an expression that constructs a temporary.
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005047 CurInit = S.BuildCXXConstructExpr(Loc, Step->Type, Constructor,
John McCall7a1fad32010-08-24 07:32:53 +00005048 move_arg(ConstructorArgs),
Abramo Bagnara7cc58b42011-10-05 07:56:41 +00005049 HadMultipleCandidates,
John McCall7a1fad32010-08-24 07:32:53 +00005050 /*ZeroInit*/ false,
Chandler Carruth428edaf2010-10-25 08:47:36 +00005051 CXXConstructExpr::CK_Complete,
5052 SourceRange());
Douglas Gregor20093b42009-12-09 23:02:17 +00005053 if (CurInit.isInvalid())
John McCallf312b1e2010-08-26 23:41:50 +00005054 return ExprError();
John McCallb13b7372010-02-01 03:16:54 +00005055
Anders Carlsson9a68a672010-04-21 18:47:17 +00005056 S.CheckConstructorAccess(Kind.getLocation(), Constructor, Entity,
John McCall9aa472c2010-03-19 07:35:19 +00005057 FoundFn.getAccess());
John McCallb697e082010-05-06 18:15:07 +00005058 S.DiagnoseUseOfDecl(FoundFn, Kind.getLocation());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005059
John McCall2de56d12010-08-25 11:45:40 +00005060 CastKind = CK_ConstructorConversion;
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005061 QualType Class = S.Context.getTypeDeclType(Constructor->getParent());
5062 if (S.Context.hasSameUnqualifiedType(SourceType, Class) ||
5063 S.IsDerivedFrom(SourceType, Class))
5064 IsCopy = true;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005065
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005066 CreatedObject = true;
Douglas Gregor20093b42009-12-09 23:02:17 +00005067 } else {
5068 // Build a call to the conversion function.
John McCallb13b7372010-02-01 03:16:54 +00005069 CXXConversionDecl *Conversion = cast<CXXConversionDecl>(Fn);
John Wiegley429bb272011-04-08 18:41:53 +00005070 S.CheckMemberOperatorAccess(Kind.getLocation(), CurInit.get(), 0,
John McCall9aa472c2010-03-19 07:35:19 +00005071 FoundFn);
John McCallb697e082010-05-06 18:15:07 +00005072 S.DiagnoseUseOfDecl(FoundFn, Kind.getLocation());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005073
5074 // FIXME: Should we move this initialization into a separate
Douglas Gregor20093b42009-12-09 23:02:17 +00005075 // derived-to-base conversion? I believe the answer is "no", because
5076 // we don't want to turn off access control here for c-style casts.
John Wiegley429bb272011-04-08 18:41:53 +00005077 ExprResult CurInitExprRes =
5078 S.PerformObjectArgumentInitialization(CurInit.take(), /*Qualifier=*/0,
5079 FoundFn, Conversion);
5080 if(CurInitExprRes.isInvalid())
John McCallf312b1e2010-08-26 23:41:50 +00005081 return ExprError();
John Wiegley429bb272011-04-08 18:41:53 +00005082 CurInit = move(CurInitExprRes);
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005083
Douglas Gregor20093b42009-12-09 23:02:17 +00005084 // Build the actual call to the conversion function.
Abramo Bagnara7cc58b42011-10-05 07:56:41 +00005085 CurInit = S.BuildCXXMemberCallExpr(CurInit.get(), FoundFn, Conversion,
5086 HadMultipleCandidates);
Douglas Gregor20093b42009-12-09 23:02:17 +00005087 if (CurInit.isInvalid() || !CurInit.get())
John McCallf312b1e2010-08-26 23:41:50 +00005088 return ExprError();
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005089
John McCall2de56d12010-08-25 11:45:40 +00005090 CastKind = CK_UserDefinedConversion;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005091
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005092 CreatedObject = Conversion->getResultType()->isRecordType();
Douglas Gregor20093b42009-12-09 23:02:17 +00005093 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005094
Sebastian Redl3b802322011-07-14 19:07:55 +00005095 bool RequiresCopy = !IsCopy && !isReferenceBinding(Steps.back());
Abramo Bagnara960809e2011-11-16 22:46:05 +00005096 bool MaybeBindToTemp = RequiresCopy || shouldBindAsTemporary(Entity);
5097
5098 if (!MaybeBindToTemp && CreatedObject && shouldDestroyTemporary(Entity)) {
John Wiegley429bb272011-04-08 18:41:53 +00005099 QualType T = CurInit.get()->getType();
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005100 if (const RecordType *Record = T->getAs<RecordType>()) {
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005101 CXXDestructorDecl *Destructor
Douglas Gregordb89f282010-07-01 22:47:18 +00005102 = S.LookupDestructor(cast<CXXRecordDecl>(Record->getDecl()));
John Wiegley429bb272011-04-08 18:41:53 +00005103 S.CheckDestructorAccess(CurInit.get()->getLocStart(), Destructor,
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005104 S.PDiag(diag::err_access_dtor_temp) << T);
Eli Friedman5f2987c2012-02-02 03:46:19 +00005105 S.MarkFunctionReferenced(CurInit.get()->getLocStart(), Destructor);
John Wiegley429bb272011-04-08 18:41:53 +00005106 S.DiagnoseUseOfDecl(Destructor, CurInit.get()->getLocStart());
Douglas Gregor4154e0b2010-04-24 23:45:46 +00005107 }
5108 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005109
John McCallf871d0c2010-08-07 06:22:56 +00005110 CurInit = S.Owned(ImplicitCastExpr::Create(S.Context,
John Wiegley429bb272011-04-08 18:41:53 +00005111 CurInit.get()->getType(),
5112 CastKind, CurInit.get(), 0,
Eli Friedman104be6f2011-09-27 01:11:35 +00005113 CurInit.get()->getValueKind()));
Abramo Bagnara960809e2011-11-16 22:46:05 +00005114 if (MaybeBindToTemp)
5115 CurInit = S.MaybeBindToTemporary(CurInit.takeAs<Expr>());
Douglas Gregor2f599792010-04-02 18:24:57 +00005116 if (RequiresCopy)
Douglas Gregor523d46a2010-04-18 07:40:54 +00005117 CurInit = CopyObject(S, Entity.getType().getNonReferenceType(), Entity,
5118 move(CurInit), /*IsExtraneousCopy=*/false);
Douglas Gregor20093b42009-12-09 23:02:17 +00005119 break;
5120 }
Sebastian Redl906082e2010-07-20 04:20:21 +00005121
Douglas Gregor20093b42009-12-09 23:02:17 +00005122 case SK_QualificationConversionLValue:
Sebastian Redl906082e2010-07-20 04:20:21 +00005123 case SK_QualificationConversionXValue:
5124 case SK_QualificationConversionRValue: {
Douglas Gregor20093b42009-12-09 23:02:17 +00005125 // Perform a qualification conversion; these can never go wrong.
John McCall5baba9d2010-08-25 10:28:54 +00005126 ExprValueKind VK =
Sebastian Redl906082e2010-07-20 04:20:21 +00005127 Step->Kind == SK_QualificationConversionLValue ?
John McCall5baba9d2010-08-25 10:28:54 +00005128 VK_LValue :
Sebastian Redl906082e2010-07-20 04:20:21 +00005129 (Step->Kind == SK_QualificationConversionXValue ?
John McCall5baba9d2010-08-25 10:28:54 +00005130 VK_XValue :
5131 VK_RValue);
John Wiegley429bb272011-04-08 18:41:53 +00005132 CurInit = S.ImpCastExprToType(CurInit.take(), Step->Type, CK_NoOp, VK);
Douglas Gregor20093b42009-12-09 23:02:17 +00005133 break;
Sebastian Redl906082e2010-07-20 04:20:21 +00005134 }
5135
Douglas Gregorf0e43e52010-04-16 19:30:02 +00005136 case SK_ConversionSequence: {
John McCallf85e1932011-06-15 23:02:42 +00005137 Sema::CheckedConversionKind CCK
5138 = Kind.isCStyleCast()? Sema::CCK_CStyleCast
5139 : Kind.isFunctionalCast()? Sema::CCK_FunctionalCast
Richard Smithc8d7f582011-11-29 22:48:16 +00005140 : Kind.isExplicitCast()? Sema::CCK_OtherCast
John McCallf85e1932011-06-15 23:02:42 +00005141 : Sema::CCK_ImplicitConversion;
John Wiegley429bb272011-04-08 18:41:53 +00005142 ExprResult CurInitExprRes =
5143 S.PerformImplicitConversion(CurInit.get(), Step->Type, *Step->ICS,
John McCallf85e1932011-06-15 23:02:42 +00005144 getAssignmentAction(Entity), CCK);
John Wiegley429bb272011-04-08 18:41:53 +00005145 if (CurInitExprRes.isInvalid())
John McCallf312b1e2010-08-26 23:41:50 +00005146 return ExprError();
John Wiegley429bb272011-04-08 18:41:53 +00005147 CurInit = move(CurInitExprRes);
Douglas Gregor20093b42009-12-09 23:02:17 +00005148 break;
Douglas Gregorf0e43e52010-04-16 19:30:02 +00005149 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005150
Douglas Gregord87b61f2009-12-10 17:56:55 +00005151 case SK_ListInitialization: {
John Wiegley429bb272011-04-08 18:41:53 +00005152 InitListExpr *InitList = cast<InitListExpr>(CurInit.get());
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005153 // Hack: We must pass *ResultType if available in order to set the type
5154 // of arrays, e.g. in 'int ar[] = {1, 2, 3};'.
5155 // But in 'const X &x = {1, 2, 3};' we're supposed to initialize a
5156 // temporary, not a reference, so we should pass Ty.
5157 // Worst case: 'const int (&arref)[] = {1, 2, 3};'.
5158 // Since this step is never used for a reference directly, we explicitly
5159 // unwrap references here and rewrap them afterwards.
5160 // We also need to create a InitializeTemporary entity for this.
5161 QualType Ty = ResultType ? ResultType->getNonReferenceType() : Step->Type;
Sebastian Redlcbf82092012-03-07 16:10:45 +00005162 bool IsTemporary = Entity.getType()->isReferenceType();
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005163 InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(Ty);
5164 InitListChecker PerformInitList(S, IsTemporary ? TempEntity : Entity,
5165 InitList, Ty, /*VerifyOnly=*/false,
Sebastian Redl168319c2012-02-12 16:37:24 +00005166 Kind.getKind() != InitializationKind::IK_DirectList ||
David Blaikie4e4d0842012-03-11 07:00:24 +00005167 !S.getLangOpts().CPlusPlus0x);
Sebastian Redl14b0c192011-09-24 17:48:00 +00005168 if (PerformInitList.HadError())
John McCallf312b1e2010-08-26 23:41:50 +00005169 return ExprError();
Douglas Gregord87b61f2009-12-10 17:56:55 +00005170
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005171 if (ResultType) {
5172 if ((*ResultType)->isRValueReferenceType())
5173 Ty = S.Context.getRValueReferenceType(Ty);
5174 else if ((*ResultType)->isLValueReferenceType())
5175 Ty = S.Context.getLValueReferenceType(Ty,
5176 (*ResultType)->getAs<LValueReferenceType>()->isSpelledAsLValue());
5177 *ResultType = Ty;
5178 }
5179
5180 InitListExpr *StructuredInitList =
5181 PerformInitList.getFullyStructuredList();
Douglas Gregord87b61f2009-12-10 17:56:55 +00005182 CurInit.release();
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005183 CurInit = S.Owned(StructuredInitList);
Douglas Gregord87b61f2009-12-10 17:56:55 +00005184 break;
5185 }
Douglas Gregor51c56d62009-12-14 20:49:26 +00005186
Sebastian Redl10f04a62011-12-22 14:44:04 +00005187 case SK_ListConstructorCall: {
Sebastian Redl168319c2012-02-12 16:37:24 +00005188 // When an initializer list is passed for a parameter of type "reference
5189 // to object", we don't get an EK_Temporary entity, but instead an
5190 // EK_Parameter entity with reference type.
Sebastian Redlbac5cf42012-02-19 12:27:56 +00005191 // FIXME: This is a hack. What we really should do is create a user
5192 // conversion step for this case, but this makes it considerably more
5193 // complicated. For now, this will do.
Sebastian Redl168319c2012-02-12 16:37:24 +00005194 InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(
5195 Entity.getType().getNonReferenceType());
5196 bool UseTemporary = Entity.getType()->isReferenceType();
Richard Smithf4bb8d02012-07-05 08:39:21 +00005197 assert(Args.size() == 1 && "expected a single argument for list init");
5198 InitListExpr *InitList = cast<InitListExpr>(Args.get()[0]);
Richard Smith03544fc2012-04-19 06:58:00 +00005199 S.Diag(InitList->getExprLoc(), diag::warn_cxx98_compat_ctor_list_init)
5200 << InitList->getSourceRange();
Sebastian Redl10f04a62011-12-22 14:44:04 +00005201 MultiExprArg Arg(InitList->getInits(), InitList->getNumInits());
Sebastian Redl168319c2012-02-12 16:37:24 +00005202 CurInit = PerformConstructorInitialization(S, UseTemporary ? TempEntity :
5203 Entity,
5204 Kind, move(Arg), *Step,
Sebastian Redl10f04a62011-12-22 14:44:04 +00005205 ConstructorInitRequiresZeroInit);
5206 break;
5207 }
Sebastian Redl8713d4e2011-09-24 17:47:52 +00005208
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005209 case SK_UnwrapInitList:
5210 CurInit = S.Owned(cast<InitListExpr>(CurInit.take())->getInit(0));
5211 break;
5212
5213 case SK_RewrapInitList: {
5214 Expr *E = CurInit.take();
5215 InitListExpr *Syntactic = Step->WrappingSyntacticList;
5216 InitListExpr *ILE = new (S.Context) InitListExpr(S.Context,
5217 Syntactic->getLBraceLoc(), &E, 1, Syntactic->getRBraceLoc());
5218 ILE->setSyntacticForm(Syntactic);
5219 ILE->setType(E->getType());
5220 ILE->setValueKind(E->getValueKind());
5221 CurInit = S.Owned(ILE);
5222 break;
5223 }
5224
Sebastian Redlbac5cf42012-02-19 12:27:56 +00005225 case SK_ConstructorInitialization: {
5226 // When an initializer list is passed for a parameter of type "reference
5227 // to object", we don't get an EK_Temporary entity, but instead an
5228 // EK_Parameter entity with reference type.
5229 // FIXME: This is a hack. What we really should do is create a user
5230 // conversion step for this case, but this makes it considerably more
5231 // complicated. For now, this will do.
5232 InitializedEntity TempEntity = InitializedEntity::InitializeTemporary(
5233 Entity.getType().getNonReferenceType());
5234 bool UseTemporary = Entity.getType()->isReferenceType();
5235 CurInit = PerformConstructorInitialization(S, UseTemporary ? TempEntity
5236 : Entity,
5237 Kind, move(Args), *Step,
Sebastian Redl10f04a62011-12-22 14:44:04 +00005238 ConstructorInitRequiresZeroInit);
Douglas Gregor51c56d62009-12-14 20:49:26 +00005239 break;
Sebastian Redlbac5cf42012-02-19 12:27:56 +00005240 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005241
Douglas Gregor71d17402009-12-15 00:01:57 +00005242 case SK_ZeroInitialization: {
Douglas Gregor16006c92009-12-16 18:50:27 +00005243 step_iterator NextStep = Step;
5244 ++NextStep;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005245 if (NextStep != StepEnd &&
Richard Smithf4bb8d02012-07-05 08:39:21 +00005246 (NextStep->Kind == SK_ConstructorInitialization ||
5247 NextStep->Kind == SK_ListConstructorCall)) {
Douglas Gregor16006c92009-12-16 18:50:27 +00005248 // The need for zero-initialization is recorded directly into
5249 // the call to the object's constructor within the next step.
5250 ConstructorInitRequiresZeroInit = true;
5251 } else if (Kind.getKind() == InitializationKind::IK_Value &&
David Blaikie4e4d0842012-03-11 07:00:24 +00005252 S.getLangOpts().CPlusPlus &&
Douglas Gregor16006c92009-12-16 18:50:27 +00005253 !Kind.isImplicitValueInit()) {
Douglas Gregorab6677e2010-09-08 00:15:04 +00005254 TypeSourceInfo *TSInfo = Entity.getTypeSourceInfo();
5255 if (!TSInfo)
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005256 TSInfo = S.Context.getTrivialTypeSourceInfo(Step->Type,
Douglas Gregorab6677e2010-09-08 00:15:04 +00005257 Kind.getRange().getBegin());
5258
5259 CurInit = S.Owned(new (S.Context) CXXScalarValueInitExpr(
5260 TSInfo->getType().getNonLValueExprType(S.Context),
5261 TSInfo,
Douglas Gregor71d17402009-12-15 00:01:57 +00005262 Kind.getRange().getEnd()));
Douglas Gregor16006c92009-12-16 18:50:27 +00005263 } else {
Douglas Gregor71d17402009-12-15 00:01:57 +00005264 CurInit = S.Owned(new (S.Context) ImplicitValueInitExpr(Step->Type));
Douglas Gregor16006c92009-12-16 18:50:27 +00005265 }
Douglas Gregor71d17402009-12-15 00:01:57 +00005266 break;
5267 }
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005268
5269 case SK_CAssignment: {
John Wiegley429bb272011-04-08 18:41:53 +00005270 QualType SourceType = CurInit.get()->getType();
5271 ExprResult Result = move(CurInit);
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005272 Sema::AssignConvertType ConvTy =
John Wiegley429bb272011-04-08 18:41:53 +00005273 S.CheckSingleAssignmentConstraints(Step->Type, Result);
5274 if (Result.isInvalid())
5275 return ExprError();
5276 CurInit = move(Result);
Douglas Gregoraa037312009-12-22 07:24:36 +00005277
5278 // If this is a call, allow conversion to a transparent union.
John Wiegley429bb272011-04-08 18:41:53 +00005279 ExprResult CurInitExprRes = move(CurInit);
Douglas Gregoraa037312009-12-22 07:24:36 +00005280 if (ConvTy != Sema::Compatible &&
5281 Entity.getKind() == InitializedEntity::EK_Parameter &&
John Wiegley429bb272011-04-08 18:41:53 +00005282 S.CheckTransparentUnionArgumentConstraints(Step->Type, CurInitExprRes)
Douglas Gregoraa037312009-12-22 07:24:36 +00005283 == Sema::Compatible)
5284 ConvTy = Sema::Compatible;
John Wiegley429bb272011-04-08 18:41:53 +00005285 if (CurInitExprRes.isInvalid())
5286 return ExprError();
5287 CurInit = move(CurInitExprRes);
Douglas Gregoraa037312009-12-22 07:24:36 +00005288
Douglas Gregora41a8c52010-04-22 00:20:18 +00005289 bool Complained;
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005290 if (S.DiagnoseAssignmentResult(ConvTy, Kind.getLocation(),
5291 Step->Type, SourceType,
John Wiegley429bb272011-04-08 18:41:53 +00005292 CurInit.get(),
Douglas Gregora41a8c52010-04-22 00:20:18 +00005293 getAssignmentAction(Entity),
5294 &Complained)) {
5295 PrintInitLocationNote(S, Entity);
John McCallf312b1e2010-08-26 23:41:50 +00005296 return ExprError();
Douglas Gregora41a8c52010-04-22 00:20:18 +00005297 } else if (Complained)
5298 PrintInitLocationNote(S, Entity);
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005299 break;
5300 }
Eli Friedmancfdc81a2009-12-19 08:11:05 +00005301
5302 case SK_StringInit: {
5303 QualType Ty = Step->Type;
John Wiegley429bb272011-04-08 18:41:53 +00005304 CheckStringInit(CurInit.get(), ResultType ? *ResultType : Ty,
John McCallfef8b342011-02-21 07:57:55 +00005305 S.Context.getAsArrayType(Ty), S);
Eli Friedmancfdc81a2009-12-19 08:11:05 +00005306 break;
5307 }
Douglas Gregor569c3162010-08-07 11:51:51 +00005308
5309 case SK_ObjCObjectConversion:
John Wiegley429bb272011-04-08 18:41:53 +00005310 CurInit = S.ImpCastExprToType(CurInit.take(), Step->Type,
John McCall2de56d12010-08-25 11:45:40 +00005311 CK_ObjCObjectLValueCast,
Eli Friedmanc1c0dfb2011-09-27 21:58:52 +00005312 CurInit.get()->getValueKind());
Douglas Gregor569c3162010-08-07 11:51:51 +00005313 break;
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005314
5315 case SK_ArrayInit:
5316 // Okay: we checked everything before creating this step. Note that
5317 // this is a GNU extension.
5318 S.Diag(Kind.getLocation(), diag::ext_array_init_copy)
John Wiegley429bb272011-04-08 18:41:53 +00005319 << Step->Type << CurInit.get()->getType()
5320 << CurInit.get()->getSourceRange();
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005321
5322 // If the destination type is an incomplete array type, update the
5323 // type accordingly.
5324 if (ResultType) {
5325 if (const IncompleteArrayType *IncompleteDest
5326 = S.Context.getAsIncompleteArrayType(Step->Type)) {
5327 if (const ConstantArrayType *ConstantSource
John Wiegley429bb272011-04-08 18:41:53 +00005328 = S.Context.getAsConstantArrayType(CurInit.get()->getType())) {
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005329 *ResultType = S.Context.getConstantArrayType(
5330 IncompleteDest->getElementType(),
5331 ConstantSource->getSize(),
5332 ArrayType::Normal, 0);
5333 }
5334 }
5335 }
John McCallf85e1932011-06-15 23:02:42 +00005336 break;
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005337
Richard Smith0f163e92012-02-15 22:38:09 +00005338 case SK_ParenthesizedArrayInit:
5339 // Okay: we checked everything before creating this step. Note that
5340 // this is a GNU extension.
5341 S.Diag(Kind.getLocation(), diag::ext_array_init_parens)
5342 << CurInit.get()->getSourceRange();
5343 break;
5344
John McCallf85e1932011-06-15 23:02:42 +00005345 case SK_PassByIndirectCopyRestore:
5346 case SK_PassByIndirectRestore:
5347 checkIndirectCopyRestoreSource(S, CurInit.get());
5348 CurInit = S.Owned(new (S.Context)
5349 ObjCIndirectCopyRestoreExpr(CurInit.take(), Step->Type,
5350 Step->Kind == SK_PassByIndirectCopyRestore));
5351 break;
5352
5353 case SK_ProduceObjCObject:
5354 CurInit = S.Owned(ImplicitCastExpr::Create(S.Context, Step->Type,
John McCall33e56f32011-09-10 06:18:15 +00005355 CK_ARCProduceObject,
John McCallf85e1932011-06-15 23:02:42 +00005356 CurInit.take(), 0, VK_RValue));
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005357 break;
Sebastian Redl2b916b82012-01-17 22:49:42 +00005358
5359 case SK_StdInitializerList: {
5360 QualType Dest = Step->Type;
5361 QualType E;
5362 bool Success = S.isStdInitializerList(Dest, &E);
5363 (void)Success;
5364 assert(Success && "Destination type changed?");
Sebastian Redl28357452012-03-05 19:35:43 +00005365
5366 // If the element type has a destructor, check it.
5367 if (CXXRecordDecl *RD = E->getAsCXXRecordDecl()) {
5368 if (!RD->hasIrrelevantDestructor()) {
5369 if (CXXDestructorDecl *Destructor = S.LookupDestructor(RD)) {
5370 S.MarkFunctionReferenced(Kind.getLocation(), Destructor);
5371 S.CheckDestructorAccess(Kind.getLocation(), Destructor,
5372 S.PDiag(diag::err_access_dtor_temp) << E);
5373 S.DiagnoseUseOfDecl(Destructor, Kind.getLocation());
5374 }
5375 }
5376 }
5377
Sebastian Redl2b916b82012-01-17 22:49:42 +00005378 InitListExpr *ILE = cast<InitListExpr>(CurInit.take());
Richard Smith03544fc2012-04-19 06:58:00 +00005379 S.Diag(ILE->getExprLoc(), diag::warn_cxx98_compat_initializer_list_init)
5380 << ILE->getSourceRange();
Sebastian Redl2b916b82012-01-17 22:49:42 +00005381 unsigned NumInits = ILE->getNumInits();
5382 SmallVector<Expr*, 16> Converted(NumInits);
5383 InitializedEntity HiddenArray = InitializedEntity::InitializeTemporary(
5384 S.Context.getConstantArrayType(E,
5385 llvm::APInt(S.Context.getTypeSize(S.Context.getSizeType()),
5386 NumInits),
5387 ArrayType::Normal, 0));
5388 InitializedEntity Element =InitializedEntity::InitializeElement(S.Context,
5389 0, HiddenArray);
5390 for (unsigned i = 0; i < NumInits; ++i) {
5391 Element.setElementIndex(i);
5392 ExprResult Init = S.Owned(ILE->getInit(i));
5393 ExprResult Res = S.PerformCopyInitialization(Element,
5394 Init.get()->getExprLoc(),
5395 Init);
5396 assert(!Res.isInvalid() && "Result changed since try phase.");
5397 Converted[i] = Res.take();
5398 }
5399 InitListExpr *Semantic = new (S.Context)
5400 InitListExpr(S.Context, ILE->getLBraceLoc(),
5401 Converted.data(), NumInits, ILE->getRBraceLoc());
5402 Semantic->setSyntacticForm(ILE);
5403 Semantic->setType(Dest);
Sebastian Redl32cf1f22012-02-17 08:42:25 +00005404 Semantic->setInitializesStdInitializerList();
Sebastian Redl2b916b82012-01-17 22:49:42 +00005405 CurInit = S.Owned(Semantic);
5406 break;
5407 }
Douglas Gregor20093b42009-12-09 23:02:17 +00005408 }
5409 }
John McCall15d7d122010-11-11 03:21:53 +00005410
5411 // Diagnose non-fatal problems with the completed initialization.
5412 if (Entity.getKind() == InitializedEntity::EK_Member &&
5413 cast<FieldDecl>(Entity.getDecl())->isBitField())
5414 S.CheckBitFieldInitialization(Kind.getLocation(),
5415 cast<FieldDecl>(Entity.getDecl()),
5416 CurInit.get());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005417
Douglas Gregor20093b42009-12-09 23:02:17 +00005418 return move(CurInit);
5419}
5420
5421//===----------------------------------------------------------------------===//
5422// Diagnose initialization failures
5423//===----------------------------------------------------------------------===//
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005424bool InitializationSequence::Diagnose(Sema &S,
Douglas Gregor20093b42009-12-09 23:02:17 +00005425 const InitializedEntity &Entity,
5426 const InitializationKind &Kind,
5427 Expr **Args, unsigned NumArgs) {
Sebastian Redld695d6b2011-06-05 13:59:05 +00005428 if (!Failed())
Douglas Gregor20093b42009-12-09 23:02:17 +00005429 return false;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005430
Douglas Gregord6542d82009-12-22 15:35:07 +00005431 QualType DestType = Entity.getType();
Douglas Gregor20093b42009-12-09 23:02:17 +00005432 switch (Failure) {
5433 case FK_TooManyInitsForReference:
Douglas Gregor9db7dbb2010-01-31 09:12:51 +00005434 // FIXME: Customize for the initialized entity?
5435 if (NumArgs == 0)
5436 S.Diag(Kind.getLocation(), diag::err_reference_without_init)
5437 << DestType.getNonReferenceType();
5438 else // FIXME: diagnostic below could be better!
5439 S.Diag(Kind.getLocation(), diag::err_reference_has_multiple_inits)
5440 << SourceRange(Args[0]->getLocStart(), Args[NumArgs - 1]->getLocEnd());
Douglas Gregor20093b42009-12-09 23:02:17 +00005441 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005442
Douglas Gregor20093b42009-12-09 23:02:17 +00005443 case FK_ArrayNeedsInitList:
5444 case FK_ArrayNeedsInitListOrStringLiteral:
5445 S.Diag(Kind.getLocation(), diag::err_array_init_not_init_list)
5446 << (Failure == FK_ArrayNeedsInitListOrStringLiteral);
5447 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005448
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005449 case FK_ArrayTypeMismatch:
5450 case FK_NonConstantArrayInit:
5451 S.Diag(Kind.getLocation(),
5452 (Failure == FK_ArrayTypeMismatch
5453 ? diag::err_array_init_different_type
5454 : diag::err_array_init_non_constant_array))
5455 << DestType.getNonReferenceType()
5456 << Args[0]->getType()
5457 << Args[0]->getSourceRange();
5458 break;
5459
John McCall73076432012-01-05 00:13:19 +00005460 case FK_VariableLengthArrayHasInitializer:
5461 S.Diag(Kind.getLocation(), diag::err_variable_object_no_init)
5462 << Args[0]->getSourceRange();
5463 break;
5464
John McCall6bb80172010-03-30 21:47:33 +00005465 case FK_AddressOfOverloadFailed: {
5466 DeclAccessPair Found;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005467 S.ResolveAddressOfOverloadedFunction(Args[0],
Douglas Gregor20093b42009-12-09 23:02:17 +00005468 DestType.getNonReferenceType(),
John McCall6bb80172010-03-30 21:47:33 +00005469 true,
5470 Found);
Douglas Gregor20093b42009-12-09 23:02:17 +00005471 break;
John McCall6bb80172010-03-30 21:47:33 +00005472 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005473
Douglas Gregor20093b42009-12-09 23:02:17 +00005474 case FK_ReferenceInitOverloadFailed:
Douglas Gregor4a520a22009-12-14 17:27:33 +00005475 case FK_UserConversionOverloadFailed:
Douglas Gregor20093b42009-12-09 23:02:17 +00005476 switch (FailedOverloadResult) {
5477 case OR_Ambiguous:
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005478 if (Failure == FK_UserConversionOverloadFailed)
5479 S.Diag(Kind.getLocation(), diag::err_typecheck_ambiguous_condition)
5480 << Args[0]->getType() << DestType
5481 << Args[0]->getSourceRange();
5482 else
5483 S.Diag(Kind.getLocation(), diag::err_ref_init_ambiguous)
5484 << DestType << Args[0]->getType()
5485 << Args[0]->getSourceRange();
5486
Ahmed Charles13a140c2012-02-25 11:00:22 +00005487 FailedCandidateSet.NoteCandidates(S, OCD_ViableCandidates,
5488 llvm::makeArrayRef(Args, NumArgs));
Douglas Gregor20093b42009-12-09 23:02:17 +00005489 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005490
Douglas Gregor20093b42009-12-09 23:02:17 +00005491 case OR_No_Viable_Function:
5492 S.Diag(Kind.getLocation(), diag::err_typecheck_nonviable_condition)
5493 << Args[0]->getType() << DestType.getNonReferenceType()
5494 << Args[0]->getSourceRange();
Ahmed Charles13a140c2012-02-25 11:00:22 +00005495 FailedCandidateSet.NoteCandidates(S, OCD_AllCandidates,
5496 llvm::makeArrayRef(Args, NumArgs));
Douglas Gregor20093b42009-12-09 23:02:17 +00005497 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005498
Douglas Gregor20093b42009-12-09 23:02:17 +00005499 case OR_Deleted: {
5500 S.Diag(Kind.getLocation(), diag::err_typecheck_deleted_function)
5501 << Args[0]->getType() << DestType.getNonReferenceType()
5502 << Args[0]->getSourceRange();
5503 OverloadCandidateSet::iterator Best;
John McCall120d63c2010-08-24 20:38:10 +00005504 OverloadingResult Ovl
Douglas Gregor8fcc5162010-09-12 08:07:23 +00005505 = FailedCandidateSet.BestViableFunction(S, Kind.getLocation(), Best,
5506 true);
Douglas Gregor20093b42009-12-09 23:02:17 +00005507 if (Ovl == OR_Deleted) {
Richard Smith6c4c36c2012-03-30 20:53:28 +00005508 S.NoteDeletedFunction(Best->Function);
Douglas Gregor20093b42009-12-09 23:02:17 +00005509 } else {
Jeffrey Yasskin9f61aa92009-12-12 05:05:38 +00005510 llvm_unreachable("Inconsistent overload resolution?");
Douglas Gregor20093b42009-12-09 23:02:17 +00005511 }
5512 break;
5513 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005514
Douglas Gregor20093b42009-12-09 23:02:17 +00005515 case OR_Success:
Jeffrey Yasskin9f61aa92009-12-12 05:05:38 +00005516 llvm_unreachable("Conversion did not fail!");
Douglas Gregor20093b42009-12-09 23:02:17 +00005517 }
5518 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005519
Douglas Gregor20093b42009-12-09 23:02:17 +00005520 case FK_NonConstLValueReferenceBindingToTemporary:
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005521 if (isa<InitListExpr>(Args[0])) {
5522 S.Diag(Kind.getLocation(),
5523 diag::err_lvalue_reference_bind_to_initlist)
5524 << DestType.getNonReferenceType().isVolatileQualified()
5525 << DestType.getNonReferenceType()
5526 << Args[0]->getSourceRange();
5527 break;
5528 }
5529 // Intentional fallthrough
5530
Douglas Gregor20093b42009-12-09 23:02:17 +00005531 case FK_NonConstLValueReferenceBindingToUnrelated:
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005532 S.Diag(Kind.getLocation(),
Douglas Gregor20093b42009-12-09 23:02:17 +00005533 Failure == FK_NonConstLValueReferenceBindingToTemporary
5534 ? diag::err_lvalue_reference_bind_to_temporary
5535 : diag::err_lvalue_reference_bind_to_unrelated)
Douglas Gregoref06e242010-01-29 19:39:15 +00005536 << DestType.getNonReferenceType().isVolatileQualified()
Douglas Gregor20093b42009-12-09 23:02:17 +00005537 << DestType.getNonReferenceType()
5538 << Args[0]->getType()
5539 << Args[0]->getSourceRange();
5540 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005541
Douglas Gregor20093b42009-12-09 23:02:17 +00005542 case FK_RValueReferenceBindingToLValue:
5543 S.Diag(Kind.getLocation(), diag::err_lvalue_to_rvalue_ref)
Douglas Gregorfb5d7ef2011-01-21 01:04:33 +00005544 << DestType.getNonReferenceType() << Args[0]->getType()
Douglas Gregor20093b42009-12-09 23:02:17 +00005545 << Args[0]->getSourceRange();
5546 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005547
Douglas Gregor20093b42009-12-09 23:02:17 +00005548 case FK_ReferenceInitDropsQualifiers:
5549 S.Diag(Kind.getLocation(), diag::err_reference_bind_drops_quals)
5550 << DestType.getNonReferenceType()
5551 << Args[0]->getType()
5552 << Args[0]->getSourceRange();
5553 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005554
Douglas Gregor20093b42009-12-09 23:02:17 +00005555 case FK_ReferenceInitFailed:
5556 S.Diag(Kind.getLocation(), diag::err_reference_bind_failed)
5557 << DestType.getNonReferenceType()
John McCall7eb0a9e2010-11-24 05:12:34 +00005558 << Args[0]->isLValue()
Douglas Gregor20093b42009-12-09 23:02:17 +00005559 << Args[0]->getType()
5560 << Args[0]->getSourceRange();
Douglas Gregor926df6c2011-06-11 01:09:30 +00005561 if (DestType.getNonReferenceType()->isObjCObjectPointerType() &&
5562 Args[0]->getType()->isObjCObjectPointerType())
5563 S.EmitRelatedResultTypeNote(Args[0]);
Douglas Gregor20093b42009-12-09 23:02:17 +00005564 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005565
Douglas Gregor1be8eec2011-02-19 21:32:49 +00005566 case FK_ConversionFailed: {
5567 QualType FromType = Args[0]->getType();
Richard Trieu6efd4c52011-11-23 22:32:32 +00005568 PartialDiagnostic PDiag = S.PDiag(diag::err_init_conversion_failed)
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005569 << (int)Entity.getKind()
Douglas Gregor20093b42009-12-09 23:02:17 +00005570 << DestType
John McCall7eb0a9e2010-11-24 05:12:34 +00005571 << Args[0]->isLValue()
Douglas Gregor1be8eec2011-02-19 21:32:49 +00005572 << FromType
Douglas Gregor20093b42009-12-09 23:02:17 +00005573 << Args[0]->getSourceRange();
Richard Trieu6efd4c52011-11-23 22:32:32 +00005574 S.HandleFunctionTypeMismatch(PDiag, FromType, DestType);
5575 S.Diag(Kind.getLocation(), PDiag);
Douglas Gregor926df6c2011-06-11 01:09:30 +00005576 if (DestType.getNonReferenceType()->isObjCObjectPointerType() &&
5577 Args[0]->getType()->isObjCObjectPointerType())
5578 S.EmitRelatedResultTypeNote(Args[0]);
Douglas Gregord87b61f2009-12-10 17:56:55 +00005579 break;
Douglas Gregor1be8eec2011-02-19 21:32:49 +00005580 }
John Wiegley429bb272011-04-08 18:41:53 +00005581
5582 case FK_ConversionFromPropertyFailed:
5583 // No-op. This error has already been reported.
5584 break;
5585
Douglas Gregord87b61f2009-12-10 17:56:55 +00005586 case FK_TooManyInitsForScalar: {
Douglas Gregor99a2e602009-12-16 01:38:02 +00005587 SourceRange R;
5588
5589 if (InitListExpr *InitList = dyn_cast<InitListExpr>(Args[0]))
Douglas Gregor19311e72010-09-08 21:40:08 +00005590 R = SourceRange(InitList->getInit(0)->getLocEnd(),
Douglas Gregor99a2e602009-12-16 01:38:02 +00005591 InitList->getLocEnd());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005592 else
Douglas Gregor19311e72010-09-08 21:40:08 +00005593 R = SourceRange(Args[0]->getLocEnd(), Args[NumArgs - 1]->getLocEnd());
Douglas Gregord87b61f2009-12-10 17:56:55 +00005594
Douglas Gregor19311e72010-09-08 21:40:08 +00005595 R.setBegin(S.PP.getLocForEndOfToken(R.getBegin()));
5596 if (Kind.isCStyleOrFunctionalCast())
5597 S.Diag(Kind.getLocation(), diag::err_builtin_func_cast_more_than_one_arg)
5598 << R;
5599 else
5600 S.Diag(Kind.getLocation(), diag::err_excess_initializers)
5601 << /*scalar=*/2 << R;
Douglas Gregord87b61f2009-12-10 17:56:55 +00005602 break;
5603 }
5604
5605 case FK_ReferenceBindingToInitList:
5606 S.Diag(Kind.getLocation(), diag::err_reference_bind_init_list)
5607 << DestType.getNonReferenceType() << Args[0]->getSourceRange();
5608 break;
5609
5610 case FK_InitListBadDestinationType:
5611 S.Diag(Kind.getLocation(), diag::err_init_list_bad_dest_type)
5612 << (DestType->isRecordType()) << DestType << Args[0]->getSourceRange();
5613 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005614
Sebastian Redlcf15cef2011-12-22 18:58:38 +00005615 case FK_ListConstructorOverloadFailed:
Douglas Gregor51c56d62009-12-14 20:49:26 +00005616 case FK_ConstructorOverloadFailed: {
5617 SourceRange ArgsRange;
5618 if (NumArgs)
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005619 ArgsRange = SourceRange(Args[0]->getLocStart(),
Douglas Gregor51c56d62009-12-14 20:49:26 +00005620 Args[NumArgs - 1]->getLocEnd());
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005621
Sebastian Redlcf15cef2011-12-22 18:58:38 +00005622 if (Failure == FK_ListConstructorOverloadFailed) {
5623 assert(NumArgs == 1 && "List construction from other than 1 argument.");
5624 InitListExpr *InitList = cast<InitListExpr>(Args[0]);
5625 Args = InitList->getInits();
5626 NumArgs = InitList->getNumInits();
5627 }
5628
Douglas Gregor51c56d62009-12-14 20:49:26 +00005629 // FIXME: Using "DestType" for the entity we're printing is probably
5630 // bad.
5631 switch (FailedOverloadResult) {
5632 case OR_Ambiguous:
5633 S.Diag(Kind.getLocation(), diag::err_ovl_ambiguous_init)
5634 << DestType << ArgsRange;
John McCall120d63c2010-08-24 20:38:10 +00005635 FailedCandidateSet.NoteCandidates(S, OCD_ViableCandidates,
Ahmed Charles13a140c2012-02-25 11:00:22 +00005636 llvm::makeArrayRef(Args, NumArgs));
Douglas Gregor51c56d62009-12-14 20:49:26 +00005637 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005638
Douglas Gregor51c56d62009-12-14 20:49:26 +00005639 case OR_No_Viable_Function:
Douglas Gregor9db7dbb2010-01-31 09:12:51 +00005640 if (Kind.getKind() == InitializationKind::IK_Default &&
5641 (Entity.getKind() == InitializedEntity::EK_Base ||
5642 Entity.getKind() == InitializedEntity::EK_Member) &&
5643 isa<CXXConstructorDecl>(S.CurContext)) {
5644 // This is implicit default initialization of a member or
5645 // base within a constructor. If no viable function was
5646 // found, notify the user that she needs to explicitly
5647 // initialize this base/member.
5648 CXXConstructorDecl *Constructor
5649 = cast<CXXConstructorDecl>(S.CurContext);
5650 if (Entity.getKind() == InitializedEntity::EK_Base) {
5651 S.Diag(Kind.getLocation(), diag::err_missing_default_ctor)
5652 << Constructor->isImplicit()
5653 << S.Context.getTypeDeclType(Constructor->getParent())
5654 << /*base=*/0
5655 << Entity.getType();
5656
5657 RecordDecl *BaseDecl
5658 = Entity.getBaseSpecifier()->getType()->getAs<RecordType>()
5659 ->getDecl();
5660 S.Diag(BaseDecl->getLocation(), diag::note_previous_decl)
5661 << S.Context.getTagDeclType(BaseDecl);
5662 } else {
5663 S.Diag(Kind.getLocation(), diag::err_missing_default_ctor)
5664 << Constructor->isImplicit()
5665 << S.Context.getTypeDeclType(Constructor->getParent())
5666 << /*member=*/1
5667 << Entity.getName();
5668 S.Diag(Entity.getDecl()->getLocation(), diag::note_field_decl);
5669
5670 if (const RecordType *Record
5671 = Entity.getType()->getAs<RecordType>())
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005672 S.Diag(Record->getDecl()->getLocation(),
Douglas Gregor9db7dbb2010-01-31 09:12:51 +00005673 diag::note_previous_decl)
5674 << S.Context.getTagDeclType(Record->getDecl());
5675 }
5676 break;
5677 }
5678
Douglas Gregor51c56d62009-12-14 20:49:26 +00005679 S.Diag(Kind.getLocation(), diag::err_ovl_no_viable_function_in_init)
5680 << DestType << ArgsRange;
Ahmed Charles13a140c2012-02-25 11:00:22 +00005681 FailedCandidateSet.NoteCandidates(S, OCD_AllCandidates,
5682 llvm::makeArrayRef(Args, NumArgs));
Douglas Gregor51c56d62009-12-14 20:49:26 +00005683 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005684
Douglas Gregor51c56d62009-12-14 20:49:26 +00005685 case OR_Deleted: {
Douglas Gregor51c56d62009-12-14 20:49:26 +00005686 OverloadCandidateSet::iterator Best;
John McCall120d63c2010-08-24 20:38:10 +00005687 OverloadingResult Ovl
5688 = FailedCandidateSet.BestViableFunction(S, Kind.getLocation(), Best);
Douglas Gregore4e68d42012-02-15 19:33:52 +00005689 if (Ovl != OR_Deleted) {
5690 S.Diag(Kind.getLocation(), diag::err_ovl_deleted_init)
5691 << true << DestType << ArgsRange;
Douglas Gregor51c56d62009-12-14 20:49:26 +00005692 llvm_unreachable("Inconsistent overload resolution?");
Douglas Gregore4e68d42012-02-15 19:33:52 +00005693 break;
Douglas Gregor51c56d62009-12-14 20:49:26 +00005694 }
Douglas Gregore4e68d42012-02-15 19:33:52 +00005695
5696 // If this is a defaulted or implicitly-declared function, then
5697 // it was implicitly deleted. Make it clear that the deletion was
5698 // implicit.
Richard Smith6c4c36c2012-03-30 20:53:28 +00005699 if (S.isImplicitlyDeleted(Best->Function))
Douglas Gregore4e68d42012-02-15 19:33:52 +00005700 S.Diag(Kind.getLocation(), diag::err_ovl_deleted_special_init)
Richard Smith6c4c36c2012-03-30 20:53:28 +00005701 << S.getSpecialMember(cast<CXXMethodDecl>(Best->Function))
Douglas Gregore4e68d42012-02-15 19:33:52 +00005702 << DestType << ArgsRange;
Richard Smith6c4c36c2012-03-30 20:53:28 +00005703 else
5704 S.Diag(Kind.getLocation(), diag::err_ovl_deleted_init)
5705 << true << DestType << ArgsRange;
5706
5707 S.NoteDeletedFunction(Best->Function);
Douglas Gregor51c56d62009-12-14 20:49:26 +00005708 break;
5709 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005710
Douglas Gregor51c56d62009-12-14 20:49:26 +00005711 case OR_Success:
5712 llvm_unreachable("Conversion did not fail!");
Douglas Gregor51c56d62009-12-14 20:49:26 +00005713 }
Douglas Gregor51c56d62009-12-14 20:49:26 +00005714 }
David Blaikie9fdefb32012-01-17 08:24:58 +00005715 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005716
Douglas Gregor99a2e602009-12-16 01:38:02 +00005717 case FK_DefaultInitOfConst:
Douglas Gregor9db7dbb2010-01-31 09:12:51 +00005718 if (Entity.getKind() == InitializedEntity::EK_Member &&
5719 isa<CXXConstructorDecl>(S.CurContext)) {
5720 // This is implicit default-initialization of a const member in
5721 // a constructor. Complain that it needs to be explicitly
5722 // initialized.
5723 CXXConstructorDecl *Constructor = cast<CXXConstructorDecl>(S.CurContext);
5724 S.Diag(Kind.getLocation(), diag::err_uninitialized_member_in_ctor)
5725 << Constructor->isImplicit()
5726 << S.Context.getTypeDeclType(Constructor->getParent())
5727 << /*const=*/1
5728 << Entity.getName();
5729 S.Diag(Entity.getDecl()->getLocation(), diag::note_previous_decl)
5730 << Entity.getName();
5731 } else {
5732 S.Diag(Kind.getLocation(), diag::err_default_init_const)
5733 << DestType << (bool)DestType->getAs<RecordType>();
5734 }
Douglas Gregor99a2e602009-12-16 01:38:02 +00005735 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005736
Sebastian Redl8713d4e2011-09-24 17:47:52 +00005737 case FK_Incomplete:
Douglas Gregor69a30b82012-04-10 20:43:46 +00005738 S.RequireCompleteType(Kind.getLocation(), FailedIncompleteType,
Sebastian Redl8713d4e2011-09-24 17:47:52 +00005739 diag::err_init_incomplete_type);
5740 break;
5741
Sebastian Redl14b0c192011-09-24 17:48:00 +00005742 case FK_ListInitializationFailed: {
5743 // Run the init list checker again to emit diagnostics.
5744 InitListExpr* InitList = cast<InitListExpr>(Args[0]);
5745 QualType DestType = Entity.getType();
5746 InitListChecker DiagnoseInitList(S, Entity, InitList,
Sebastian Redlc2235182011-10-16 18:19:28 +00005747 DestType, /*VerifyOnly=*/false,
Sebastian Redl168319c2012-02-12 16:37:24 +00005748 Kind.getKind() != InitializationKind::IK_DirectList ||
David Blaikie4e4d0842012-03-11 07:00:24 +00005749 !S.getLangOpts().CPlusPlus0x);
Sebastian Redl14b0c192011-09-24 17:48:00 +00005750 assert(DiagnoseInitList.HadError() &&
5751 "Inconsistent init list check result.");
5752 break;
5753 }
John McCall5acb0c92011-10-17 18:40:02 +00005754
5755 case FK_PlaceholderType: {
5756 // FIXME: Already diagnosed!
5757 break;
5758 }
Sebastian Redl2b916b82012-01-17 22:49:42 +00005759
5760 case FK_InitListElementCopyFailure: {
5761 // Try to perform all copies again.
5762 InitListExpr* InitList = cast<InitListExpr>(Args[0]);
5763 unsigned NumInits = InitList->getNumInits();
5764 QualType DestType = Entity.getType();
5765 QualType E;
5766 bool Success = S.isStdInitializerList(DestType, &E);
5767 (void)Success;
5768 assert(Success && "Where did the std::initializer_list go?");
5769 InitializedEntity HiddenArray = InitializedEntity::InitializeTemporary(
5770 S.Context.getConstantArrayType(E,
5771 llvm::APInt(S.Context.getTypeSize(S.Context.getSizeType()),
5772 NumInits),
5773 ArrayType::Normal, 0));
5774 InitializedEntity Element = InitializedEntity::InitializeElement(S.Context,
5775 0, HiddenArray);
5776 // Show at most 3 errors. Otherwise, you'd get a lot of errors for errors
5777 // where the init list type is wrong, e.g.
5778 // std::initializer_list<void*> list = { 1, 2, 3, 4, 5, 6, 7, 8 };
5779 // FIXME: Emit a note if we hit the limit?
5780 int ErrorCount = 0;
5781 for (unsigned i = 0; i < NumInits && ErrorCount < 3; ++i) {
5782 Element.setElementIndex(i);
5783 ExprResult Init = S.Owned(InitList->getInit(i));
5784 if (S.PerformCopyInitialization(Element, Init.get()->getExprLoc(), Init)
5785 .isInvalid())
5786 ++ErrorCount;
5787 }
5788 break;
5789 }
Sebastian Redl70e24fc2012-04-01 19:54:59 +00005790
5791 case FK_ExplicitConstructor: {
5792 S.Diag(Kind.getLocation(), diag::err_selected_explicit_constructor)
5793 << Args[0]->getSourceRange();
5794 OverloadCandidateSet::iterator Best;
5795 OverloadingResult Ovl
5796 = FailedCandidateSet.BestViableFunction(S, Kind.getLocation(), Best);
Matt Beaumont-Gaye7d0bbf2012-04-02 19:05:35 +00005797 (void)Ovl;
Sebastian Redl70e24fc2012-04-01 19:54:59 +00005798 assert(Ovl == OR_Success && "Inconsistent overload resolution");
5799 CXXConstructorDecl *CtorDecl = cast<CXXConstructorDecl>(Best->Function);
5800 S.Diag(CtorDecl->getLocation(), diag::note_constructor_declared_here);
5801 break;
5802 }
Douglas Gregor20093b42009-12-09 23:02:17 +00005803 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005804
Douglas Gregora41a8c52010-04-22 00:20:18 +00005805 PrintInitLocationNote(S, Entity);
Douglas Gregor20093b42009-12-09 23:02:17 +00005806 return true;
5807}
Douglas Gregor18ef5e22009-12-18 05:02:21 +00005808
Chris Lattner5f9e2722011-07-23 10:55:15 +00005809void InitializationSequence::dump(raw_ostream &OS) const {
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005810 switch (SequenceKind) {
5811 case FailedSequence: {
5812 OS << "Failed sequence: ";
5813 switch (Failure) {
5814 case FK_TooManyInitsForReference:
5815 OS << "too many initializers for reference";
5816 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005817
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005818 case FK_ArrayNeedsInitList:
5819 OS << "array requires initializer list";
5820 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005821
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005822 case FK_ArrayNeedsInitListOrStringLiteral:
5823 OS << "array requires initializer list or string literal";
5824 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005825
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00005826 case FK_ArrayTypeMismatch:
5827 OS << "array type mismatch";
5828 break;
5829
5830 case FK_NonConstantArrayInit:
5831 OS << "non-constant array initializer";
5832 break;
5833
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005834 case FK_AddressOfOverloadFailed:
5835 OS << "address of overloaded function failed";
5836 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005837
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005838 case FK_ReferenceInitOverloadFailed:
5839 OS << "overload resolution for reference initialization failed";
5840 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005841
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005842 case FK_NonConstLValueReferenceBindingToTemporary:
5843 OS << "non-const lvalue reference bound to temporary";
5844 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005845
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005846 case FK_NonConstLValueReferenceBindingToUnrelated:
5847 OS << "non-const lvalue reference bound to unrelated type";
5848 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005849
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005850 case FK_RValueReferenceBindingToLValue:
5851 OS << "rvalue reference bound to an lvalue";
5852 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005853
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005854 case FK_ReferenceInitDropsQualifiers:
5855 OS << "reference initialization drops qualifiers";
5856 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005857
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005858 case FK_ReferenceInitFailed:
5859 OS << "reference initialization failed";
5860 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005861
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005862 case FK_ConversionFailed:
5863 OS << "conversion failed";
5864 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005865
John Wiegley429bb272011-04-08 18:41:53 +00005866 case FK_ConversionFromPropertyFailed:
5867 OS << "conversion from property failed";
5868 break;
5869
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005870 case FK_TooManyInitsForScalar:
5871 OS << "too many initializers for scalar";
5872 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005873
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005874 case FK_ReferenceBindingToInitList:
5875 OS << "referencing binding to initializer list";
5876 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005877
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005878 case FK_InitListBadDestinationType:
5879 OS << "initializer list for non-aggregate, non-scalar type";
5880 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005881
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005882 case FK_UserConversionOverloadFailed:
5883 OS << "overloading failed for user-defined conversion";
5884 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005885
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005886 case FK_ConstructorOverloadFailed:
5887 OS << "constructor overloading failed";
5888 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005889
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005890 case FK_DefaultInitOfConst:
5891 OS << "default initialization of a const variable";
5892 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005893
Douglas Gregor72a43bb2010-05-20 22:12:02 +00005894 case FK_Incomplete:
5895 OS << "initialization of incomplete type";
5896 break;
Sebastian Redl8713d4e2011-09-24 17:47:52 +00005897
5898 case FK_ListInitializationFailed:
Sebastian Redl14b0c192011-09-24 17:48:00 +00005899 OS << "list initialization checker failure";
John McCall5acb0c92011-10-17 18:40:02 +00005900 break;
5901
John McCall73076432012-01-05 00:13:19 +00005902 case FK_VariableLengthArrayHasInitializer:
5903 OS << "variable length array has an initializer";
5904 break;
5905
John McCall5acb0c92011-10-17 18:40:02 +00005906 case FK_PlaceholderType:
5907 OS << "initializer expression isn't contextually valid";
5908 break;
Nick Lewyckyb0c6c332011-12-22 20:21:32 +00005909
5910 case FK_ListConstructorOverloadFailed:
5911 OS << "list constructor overloading failed";
5912 break;
Sebastian Redl2b916b82012-01-17 22:49:42 +00005913
5914 case FK_InitListElementCopyFailure:
5915 OS << "copy construction of initializer list element failed";
5916 break;
Sebastian Redl70e24fc2012-04-01 19:54:59 +00005917
5918 case FK_ExplicitConstructor:
5919 OS << "list copy initialization chose explicit constructor";
5920 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005921 }
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005922 OS << '\n';
5923 return;
5924 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005925
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005926 case DependentSequence:
Sebastian Redl7491c492011-06-05 13:59:11 +00005927 OS << "Dependent sequence\n";
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005928 return;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005929
Sebastian Redl7491c492011-06-05 13:59:11 +00005930 case NormalSequence:
5931 OS << "Normal sequence: ";
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005932 break;
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005933 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005934
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005935 for (step_iterator S = step_begin(), SEnd = step_end(); S != SEnd; ++S) {
5936 if (S != step_begin()) {
5937 OS << " -> ";
5938 }
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005939
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005940 switch (S->Kind) {
5941 case SK_ResolveAddressOfOverloadedFunction:
5942 OS << "resolve address of overloaded function";
5943 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005944
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005945 case SK_CastDerivedToBaseRValue:
5946 OS << "derived-to-base case (rvalue" << S->Type.getAsString() << ")";
5947 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005948
Sebastian Redl906082e2010-07-20 04:20:21 +00005949 case SK_CastDerivedToBaseXValue:
5950 OS << "derived-to-base case (xvalue" << S->Type.getAsString() << ")";
5951 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005952
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005953 case SK_CastDerivedToBaseLValue:
5954 OS << "derived-to-base case (lvalue" << S->Type.getAsString() << ")";
5955 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005956
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005957 case SK_BindReference:
5958 OS << "bind reference to lvalue";
5959 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005960
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005961 case SK_BindReferenceToTemporary:
5962 OS << "bind reference to a temporary";
5963 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005964
Douglas Gregor523d46a2010-04-18 07:40:54 +00005965 case SK_ExtraneousCopyToTemporary:
5966 OS << "extraneous C++03 copy to temporary";
5967 break;
5968
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005969 case SK_UserConversion:
Benjamin Kramerb8989f22011-10-14 18:45:37 +00005970 OS << "user-defined conversion via " << *S->Function.Function;
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005971 break;
Sebastian Redl906082e2010-07-20 04:20:21 +00005972
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005973 case SK_QualificationConversionRValue:
5974 OS << "qualification conversion (rvalue)";
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005975 break;
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005976
Sebastian Redl906082e2010-07-20 04:20:21 +00005977 case SK_QualificationConversionXValue:
5978 OS << "qualification conversion (xvalue)";
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005979 break;
Sebastian Redl906082e2010-07-20 04:20:21 +00005980
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005981 case SK_QualificationConversionLValue:
5982 OS << "qualification conversion (lvalue)";
5983 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005984
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005985 case SK_ConversionSequence:
5986 OS << "implicit conversion sequence (";
5987 S->ICS->DebugPrint(); // FIXME: use OS
5988 OS << ")";
5989 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005990
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005991 case SK_ListInitialization:
Sebastian Redl8713d4e2011-09-24 17:47:52 +00005992 OS << "list aggregate initialization";
5993 break;
5994
5995 case SK_ListConstructorCall:
5996 OS << "list initialization via constructor";
Douglas Gregorde4b1d82010-01-29 19:14:02 +00005997 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00005998
Sebastian Redl13dc8f92011-11-27 16:50:07 +00005999 case SK_UnwrapInitList:
6000 OS << "unwrap reference initializer list";
6001 break;
6002
6003 case SK_RewrapInitList:
6004 OS << "rewrap reference initializer list";
6005 break;
6006
Douglas Gregorde4b1d82010-01-29 19:14:02 +00006007 case SK_ConstructorInitialization:
6008 OS << "constructor initialization";
6009 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00006010
Douglas Gregorde4b1d82010-01-29 19:14:02 +00006011 case SK_ZeroInitialization:
6012 OS << "zero initialization";
6013 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00006014
Douglas Gregorde4b1d82010-01-29 19:14:02 +00006015 case SK_CAssignment:
6016 OS << "C assignment";
6017 break;
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00006018
Douglas Gregorde4b1d82010-01-29 19:14:02 +00006019 case SK_StringInit:
6020 OS << "string initialization";
6021 break;
Douglas Gregor569c3162010-08-07 11:51:51 +00006022
6023 case SK_ObjCObjectConversion:
6024 OS << "Objective-C object conversion";
6025 break;
Douglas Gregorcd9ec3b2011-02-22 18:29:51 +00006026
6027 case SK_ArrayInit:
6028 OS << "array initialization";
6029 break;
John McCallf85e1932011-06-15 23:02:42 +00006030
Richard Smith0f163e92012-02-15 22:38:09 +00006031 case SK_ParenthesizedArrayInit:
6032 OS << "parenthesized array initialization";
6033 break;
6034
John McCallf85e1932011-06-15 23:02:42 +00006035 case SK_PassByIndirectCopyRestore:
6036 OS << "pass by indirect copy and restore";
6037 break;
6038
6039 case SK_PassByIndirectRestore:
6040 OS << "pass by indirect restore";
6041 break;
6042
6043 case SK_ProduceObjCObject:
6044 OS << "Objective-C object retension";
6045 break;
Sebastian Redl2b916b82012-01-17 22:49:42 +00006046
6047 case SK_StdInitializerList:
6048 OS << "std::initializer_list from initializer list";
6049 break;
Douglas Gregorde4b1d82010-01-29 19:14:02 +00006050 }
6051 }
6052}
6053
6054void InitializationSequence::dump() const {
6055 dump(llvm::errs());
6056}
6057
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006058static void DiagnoseNarrowingInInitList(Sema &S, InitializationSequence &Seq,
6059 QualType EntityType,
6060 const Expr *PreInit,
6061 const Expr *PostInit) {
6062 if (Seq.step_begin() == Seq.step_end() || PreInit->isValueDependent())
6063 return;
6064
6065 // A narrowing conversion can only appear as the final implicit conversion in
6066 // an initialization sequence.
6067 const InitializationSequence::Step &LastStep = Seq.step_end()[-1];
6068 if (LastStep.Kind != InitializationSequence::SK_ConversionSequence)
6069 return;
6070
6071 const ImplicitConversionSequence &ICS = *LastStep.ICS;
6072 const StandardConversionSequence *SCS = 0;
6073 switch (ICS.getKind()) {
6074 case ImplicitConversionSequence::StandardConversion:
6075 SCS = &ICS.Standard;
6076 break;
6077 case ImplicitConversionSequence::UserDefinedConversion:
6078 SCS = &ICS.UserDefined.After;
6079 break;
6080 case ImplicitConversionSequence::AmbiguousConversion:
6081 case ImplicitConversionSequence::EllipsisConversion:
6082 case ImplicitConversionSequence::BadConversion:
6083 return;
6084 }
6085
6086 // Determine the type prior to the narrowing conversion. If a conversion
6087 // operator was used, this may be different from both the type of the entity
6088 // and of the pre-initialization expression.
6089 QualType PreNarrowingType = PreInit->getType();
6090 if (Seq.step_begin() + 1 != Seq.step_end())
6091 PreNarrowingType = Seq.step_end()[-2].Type;
6092
6093 // C++11 [dcl.init.list]p7: Check whether this is a narrowing conversion.
6094 APValue ConstantValue;
Richard Smithf6028062012-03-23 23:55:39 +00006095 QualType ConstantType;
6096 switch (SCS->getNarrowingKind(S.Context, PostInit, ConstantValue,
6097 ConstantType)) {
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006098 case NK_Not_Narrowing:
6099 // No narrowing occurred.
6100 return;
6101
6102 case NK_Type_Narrowing:
6103 // This was a floating-to-integer conversion, which is always considered a
6104 // narrowing conversion even if the value is a constant and can be
6105 // represented exactly as an integer.
6106 S.Diag(PostInit->getLocStart(),
David Blaikie4e4d0842012-03-11 07:00:24 +00006107 S.getLangOpts().MicrosoftExt || !S.getLangOpts().CPlusPlus0x?
Douglas Gregorf3c82c52012-01-23 15:29:33 +00006108 diag::warn_init_list_type_narrowing
6109 : S.isSFINAEContext()?
6110 diag::err_init_list_type_narrowing_sfinae
6111 : diag::err_init_list_type_narrowing)
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006112 << PostInit->getSourceRange()
6113 << PreNarrowingType.getLocalUnqualifiedType()
6114 << EntityType.getLocalUnqualifiedType();
6115 break;
6116
6117 case NK_Constant_Narrowing:
6118 // A constant value was narrowed.
6119 S.Diag(PostInit->getLocStart(),
David Blaikie4e4d0842012-03-11 07:00:24 +00006120 S.getLangOpts().MicrosoftExt || !S.getLangOpts().CPlusPlus0x?
Douglas Gregorf3c82c52012-01-23 15:29:33 +00006121 diag::warn_init_list_constant_narrowing
6122 : S.isSFINAEContext()?
6123 diag::err_init_list_constant_narrowing_sfinae
6124 : diag::err_init_list_constant_narrowing)
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006125 << PostInit->getSourceRange()
Richard Smithf6028062012-03-23 23:55:39 +00006126 << ConstantValue.getAsString(S.getASTContext(), ConstantType)
Jeffrey Yasskin99061492011-08-29 15:59:37 +00006127 << EntityType.getLocalUnqualifiedType();
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006128 break;
6129
6130 case NK_Variable_Narrowing:
6131 // A variable's value may have been narrowed.
6132 S.Diag(PostInit->getLocStart(),
David Blaikie4e4d0842012-03-11 07:00:24 +00006133 S.getLangOpts().MicrosoftExt || !S.getLangOpts().CPlusPlus0x?
Douglas Gregorf3c82c52012-01-23 15:29:33 +00006134 diag::warn_init_list_variable_narrowing
6135 : S.isSFINAEContext()?
6136 diag::err_init_list_variable_narrowing_sfinae
6137 : diag::err_init_list_variable_narrowing)
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006138 << PostInit->getSourceRange()
6139 << PreNarrowingType.getLocalUnqualifiedType()
Jeffrey Yasskin99061492011-08-29 15:59:37 +00006140 << EntityType.getLocalUnqualifiedType();
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006141 break;
6142 }
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006143
Dylan Noblesmithf7ccbad2012-02-05 02:13:05 +00006144 SmallString<128> StaticCast;
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006145 llvm::raw_svector_ostream OS(StaticCast);
6146 OS << "static_cast<";
6147 if (const TypedefType *TT = EntityType->getAs<TypedefType>()) {
6148 // It's important to use the typedef's name if there is one so that the
6149 // fixit doesn't break code using types like int64_t.
6150 //
6151 // FIXME: This will break if the typedef requires qualification. But
6152 // getQualifiedNameAsString() includes non-machine-parsable components.
Benjamin Kramerb8989f22011-10-14 18:45:37 +00006153 OS << *TT->getDecl();
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006154 } else if (const BuiltinType *BT = EntityType->getAs<BuiltinType>())
David Blaikie4e4d0842012-03-11 07:00:24 +00006155 OS << BT->getName(S.getLangOpts());
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006156 else {
6157 // Oops, we didn't find the actual type of the variable. Don't emit a fixit
6158 // with a broken cast.
6159 return;
6160 }
6161 OS << ">(";
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006162 S.Diag(PostInit->getLocStart(), diag::note_init_list_narrowing_override)
6163 << PostInit->getSourceRange()
6164 << FixItHint::CreateInsertion(PostInit->getLocStart(), OS.str())
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006165 << FixItHint::CreateInsertion(
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006166 S.getPreprocessor().getLocForEndOfToken(PostInit->getLocEnd()), ")");
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006167}
6168
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006169//===----------------------------------------------------------------------===//
6170// Initialization helper functions
6171//===----------------------------------------------------------------------===//
Sean Hunt2be7e902011-05-12 22:46:29 +00006172bool
6173Sema::CanPerformCopyInitialization(const InitializedEntity &Entity,
6174 ExprResult Init) {
6175 if (Init.isInvalid())
6176 return false;
6177
6178 Expr *InitE = Init.get();
6179 assert(InitE && "No initialization expression");
6180
Douglas Gregor3c394c52012-07-31 22:15:04 +00006181 InitializationKind Kind
6182 = InitializationKind::CreateCopy(InitE->getLocStart(), SourceLocation());
Sean Hunt2be7e902011-05-12 22:46:29 +00006183 InitializationSequence Seq(*this, Entity, Kind, &InitE, 1);
Sebastian Redl383616c2011-06-05 12:23:28 +00006184 return !Seq.Failed();
Sean Hunt2be7e902011-05-12 22:46:29 +00006185}
6186
NAKAMURA Takumidfbb02a2011-01-27 07:10:08 +00006187ExprResult
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006188Sema::PerformCopyInitialization(const InitializedEntity &Entity,
6189 SourceLocation EqualLoc,
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006190 ExprResult Init,
Douglas Gregored878af2012-02-24 23:56:31 +00006191 bool TopLevelOfInitList,
6192 bool AllowExplicit) {
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006193 if (Init.isInvalid())
6194 return ExprError();
6195
John McCall15d7d122010-11-11 03:21:53 +00006196 Expr *InitE = Init.get();
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006197 assert(InitE && "No initialization expression?");
6198
6199 if (EqualLoc.isInvalid())
6200 EqualLoc = InitE->getLocStart();
6201
6202 InitializationKind Kind = InitializationKind::CreateCopy(InitE->getLocStart(),
Douglas Gregored878af2012-02-24 23:56:31 +00006203 EqualLoc,
6204 AllowExplicit);
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006205 InitializationSequence Seq(*this, Entity, Kind, &InitE, 1);
6206 Init.release();
Jeffrey Yasskin19159132011-07-26 23:20:30 +00006207
Richard Smith4c3fc9b2012-01-18 05:21:49 +00006208 ExprResult Result = Seq.Perform(*this, Entity, Kind, MultiExprArg(&InitE, 1));
6209
6210 if (!Result.isInvalid() && TopLevelOfInitList)
6211 DiagnoseNarrowingInInitList(*this, Seq, Entity.getType(),
6212 InitE, Result.get());
6213
6214 return Result;
Douglas Gregor18ef5e22009-12-18 05:02:21 +00006215}