blob: fdfd6c07059a78cf54de56034d6487273c65fa68 [file] [log] [blame]
Ted Kremenek21475702008-09-05 17:16:31 +00001//===--- DeclCXX.cpp - C++ Declaration AST Node Implementation ------------===//
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//
10// This file implements the C++ related Decl classes.
11//
12//===----------------------------------------------------------------------===//
Ted Kremenek21475702008-09-05 17:16:31 +000013#include "clang/AST/DeclCXX.h"
14#include "clang/AST/ASTContext.h"
Faisal Vali2b391ab2013-09-26 19:54:12 +000015#include "clang/AST/ASTLambda.h"
Argyrios Kyrtzidis65ad5692010-10-24 17:26:36 +000016#include "clang/AST/ASTMutationListener.h"
Douglas Gregor8fb95122010-09-29 00:15:42 +000017#include "clang/AST/CXXInheritance.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000018#include "clang/AST/DeclTemplate.h"
Anders Carlsson5bbe1d72009-03-14 00:25:26 +000019#include "clang/AST/Expr.h"
Douglas Gregord73f3dd2011-11-01 01:16:03 +000020#include "clang/AST/ExprCXX.h"
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +000021#include "clang/AST/TypeLoc.h"
Douglas Gregorb6acda02008-11-12 23:21:09 +000022#include "clang/Basic/IdentifierTable.h"
Douglas Gregor74a34442008-12-23 21:31:30 +000023#include "llvm/ADT/STLExtras.h"
Fariborz Jahaniana9540492009-09-12 19:52:10 +000024#include "llvm/ADT/SmallPtrSet.h"
Ted Kremenek21475702008-09-05 17:16:31 +000025using namespace clang;
26
27//===----------------------------------------------------------------------===//
28// Decl Allocation/Deallocation Method Implementations
29//===----------------------------------------------------------------------===//
Douglas Gregor5101c242008-12-05 18:15:24 +000030
David Blaikie68e081d2011-12-20 02:48:34 +000031void AccessSpecDecl::anchor() { }
32
Douglas Gregor72172e92012-01-05 21:55:30 +000033AccessSpecDecl *AccessSpecDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smithf7981722013-11-22 09:01:48 +000034 return new (C, ID) AccessSpecDecl(EmptyShell());
Douglas Gregor72172e92012-01-05 21:55:30 +000035}
36
Richard Smitha4ba74c2013-08-30 04:46:40 +000037void LazyASTUnresolvedSet::getFromExternalSource(ASTContext &C) const {
38 ExternalASTSource *Source = C.getExternalSource();
39 assert(Impl.Decls.isLazy() && "getFromExternalSource for non-lazy set");
40 assert(Source && "getFromExternalSource with no external source");
41
42 for (ASTUnresolvedSet::iterator I = Impl.begin(); I != Impl.end(); ++I)
43 I.setDecl(cast<NamedDecl>(Source->GetExternalDecl(
44 reinterpret_cast<uintptr_t>(I.getDecl()) >> 2)));
45 Impl.Decls.setLazy(false);
46}
47
John McCall67da35c2010-02-04 22:26:26 +000048CXXRecordDecl::DefinitionData::DefinitionData(CXXRecordDecl *D)
Nico Weber6a6376b2016-02-19 01:52:46 +000049 : UserDeclaredConstructor(false), UserDeclaredSpecialMembers(0),
50 Aggregate(true), PlainOldData(true), Empty(true), Polymorphic(false),
51 Abstract(false), IsStandardLayout(true), HasNoNonEmptyBases(true),
52 HasPrivateFields(false), HasProtectedFields(false),
53 HasPublicFields(false), HasMutableFields(false), HasVariantMembers(false),
54 HasOnlyCMembers(true), HasInClassInitializer(false),
55 HasUninitializedReferenceMember(false), HasUninitializedFields(false),
Richard Smith12e79312016-05-13 06:47:56 +000056 HasInheritedConstructor(false), HasInheritedAssignment(false),
Nico Weber6a6376b2016-02-19 01:52:46 +000057 NeedOverloadResolutionForMoveConstructor(false),
58 NeedOverloadResolutionForMoveAssignment(false),
59 NeedOverloadResolutionForDestructor(false),
60 DefaultedMoveConstructorIsDeleted(false),
61 DefaultedMoveAssignmentIsDeleted(false),
62 DefaultedDestructorIsDeleted(false), HasTrivialSpecialMembers(SMF_All),
63 DeclaredNonTrivialSpecialMembers(0), HasIrrelevantDestructor(true),
64 HasConstexprNonCopyMoveConstructor(false),
Nico Weber72c57f42016-02-24 20:58:14 +000065 HasDefaultedDefaultConstructor(false),
Nico Weber6a6376b2016-02-19 01:52:46 +000066 DefaultedDefaultConstructorIsConstexpr(true),
67 HasConstexprDefaultConstructor(false),
68 HasNonLiteralTypeFieldsOrBases(false), ComputedVisibleConversions(false),
69 UserProvidedDefaultConstructor(false), DeclaredSpecialMembers(0),
70 ImplicitCopyConstructorHasConstParam(true),
71 ImplicitCopyAssignmentHasConstParam(true),
72 HasDeclaredCopyConstructorWithConstParam(false),
73 HasDeclaredCopyAssignmentWithConstParam(false), IsLambda(false),
Richard Trieudc4cb022017-02-17 07:19:24 +000074 IsParsingBaseSpecifiers(false), NumBases(0), NumVBases(0), Bases(),
75 VBases(), Definition(D), FirstFriend() {}
John McCall67da35c2010-02-04 22:26:26 +000076
Benjamin Kramer300c0632012-07-04 17:03:33 +000077CXXBaseSpecifier *CXXRecordDecl::DefinitionData::getBasesSlowCase() const {
78 return Bases.get(Definition->getASTContext().getExternalSource());
79}
80
81CXXBaseSpecifier *CXXRecordDecl::DefinitionData::getVBasesSlowCase() const {
82 return VBases.get(Definition->getASTContext().getExternalSource());
83}
84
Richard Smith053f6c62014-05-16 23:01:30 +000085CXXRecordDecl::CXXRecordDecl(Kind K, TagKind TK, const ASTContext &C,
86 DeclContext *DC, SourceLocation StartLoc,
87 SourceLocation IdLoc, IdentifierInfo *Id,
88 CXXRecordDecl *PrevDecl)
89 : RecordDecl(K, TK, C, DC, StartLoc, IdLoc, Id, PrevDecl),
90 DefinitionData(PrevDecl ? PrevDecl->DefinitionData
Richard Smithb6483992016-05-17 22:44:15 +000091 : nullptr),
Richard Smith053f6c62014-05-16 23:01:30 +000092 TemplateOrInstantiation() {}
Douglas Gregorb6acda02008-11-12 23:21:09 +000093
Jay Foad39c79802011-01-12 09:06:06 +000094CXXRecordDecl *CXXRecordDecl::Create(const ASTContext &C, TagKind TK,
Abramo Bagnara29c2d462011-03-09 14:09:51 +000095 DeclContext *DC, SourceLocation StartLoc,
96 SourceLocation IdLoc, IdentifierInfo *Id,
Douglas Gregor1ec5e9f2009-05-15 19:11:46 +000097 CXXRecordDecl* PrevDecl,
98 bool DelayTypeCreation) {
Richard Smith053f6c62014-05-16 23:01:30 +000099 CXXRecordDecl *R = new (C, DC) CXXRecordDecl(CXXRecord, TK, C, DC, StartLoc,
Richard Smithf7981722013-11-22 09:01:48 +0000100 IdLoc, Id, PrevDecl);
Douglas Gregor7dab26b2013-02-09 01:35:03 +0000101 R->MayHaveOutOfDateDef = C.getLangOpts().Modules;
Mike Stump11289f42009-09-09 15:08:12 +0000102
Douglas Gregorb6b8f9e2009-07-29 23:36:44 +0000103 // FIXME: DelayTypeCreation seems like such a hack
Douglas Gregor1ec5e9f2009-05-15 19:11:46 +0000104 if (!DelayTypeCreation)
Mike Stump11289f42009-09-09 15:08:12 +0000105 C.getTypeDeclType(R, PrevDecl);
Ted Kremenek21475702008-09-05 17:16:31 +0000106 return R;
107}
108
Richard Smith053f6c62014-05-16 23:01:30 +0000109CXXRecordDecl *
110CXXRecordDecl::CreateLambda(const ASTContext &C, DeclContext *DC,
111 TypeSourceInfo *Info, SourceLocation Loc,
112 bool Dependent, bool IsGeneric,
113 LambdaCaptureDefault CaptureDefault) {
Richard Smithf7981722013-11-22 09:01:48 +0000114 CXXRecordDecl *R =
Richard Smith053f6c62014-05-16 23:01:30 +0000115 new (C, DC) CXXRecordDecl(CXXRecord, TTK_Class, C, DC, Loc, Loc,
116 nullptr, nullptr);
Douglas Gregorc8a73492012-02-13 15:44:47 +0000117 R->IsBeingDefined = true;
Richard Smith64c06302014-05-22 23:19:02 +0000118 R->DefinitionData =
Richard Smith053f6c62014-05-16 23:01:30 +0000119 new (C) struct LambdaDefinitionData(R, Info, Dependent, IsGeneric,
Richard Smith64c06302014-05-22 23:19:02 +0000120 CaptureDefault);
Douglas Gregor7dab26b2013-02-09 01:35:03 +0000121 R->MayHaveOutOfDateDef = false;
James Dennett8f60cdd2013-09-05 17:46:21 +0000122 R->setImplicit(true);
Craig Topper36250ad2014-05-12 05:36:57 +0000123 C.getTypeDeclType(R, /*PrevDecl=*/nullptr);
Douglas Gregorc8a73492012-02-13 15:44:47 +0000124 return R;
125}
126
Douglas Gregor72172e92012-01-05 21:55:30 +0000127CXXRecordDecl *
128CXXRecordDecl::CreateDeserialized(const ASTContext &C, unsigned ID) {
Richard Smithf7981722013-11-22 09:01:48 +0000129 CXXRecordDecl *R = new (C, ID) CXXRecordDecl(
Richard Smith053f6c62014-05-16 23:01:30 +0000130 CXXRecord, TTK_Struct, C, nullptr, SourceLocation(), SourceLocation(),
Craig Topper36250ad2014-05-12 05:36:57 +0000131 nullptr, nullptr);
Douglas Gregor7dab26b2013-02-09 01:35:03 +0000132 R->MayHaveOutOfDateDef = false;
133 return R;
Argyrios Kyrtzidis39f0e302010-07-02 11:54:55 +0000134}
135
Mike Stump11289f42009-09-09 15:08:12 +0000136void
Craig Toppere6337e12015-12-25 00:36:02 +0000137CXXRecordDecl::setBases(CXXBaseSpecifier const * const *Bases,
138 unsigned NumBases) {
Douglas Gregor4a62bdf2010-02-11 01:30:34 +0000139 ASTContext &C = getASTContext();
Douglas Gregorcfd8ddc2008-11-05 16:20:31 +0000140
Douglas Gregord4c5ed02010-10-29 22:39:52 +0000141 if (!data().Bases.isOffset() && data().NumBases > 0)
142 C.Deallocate(data().getBases());
Mike Stump11289f42009-09-09 15:08:12 +0000143
Craig Toppere6337e12015-12-25 00:36:02 +0000144 if (NumBases) {
Richard Smith872307e2016-03-08 22:17:41 +0000145 if (!C.getLangOpts().CPlusPlus1z) {
146 // C++ [dcl.init.aggr]p1:
147 // An aggregate is [...] a class with [...] no base classes [...].
148 data().Aggregate = false;
149 }
Richard Smithaed32b42011-10-18 20:08:55 +0000150
151 // C++ [class]p4:
152 // A POD-struct is an aggregate class...
153 data().PlainOldData = false;
154 }
155
Anders Carlssonabb20e62010-03-29 05:13:12 +0000156 // The set of seen virtual base types.
Anders Carlssone47380f2010-03-29 19:49:09 +0000157 llvm::SmallPtrSet<CanQualType, 8> SeenVBaseTypes;
Anders Carlssonabb20e62010-03-29 05:13:12 +0000158
159 // The virtual bases of this class.
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000160 SmallVector<const CXXBaseSpecifier *, 8> VBases;
Mike Stump11289f42009-09-09 15:08:12 +0000161
Craig Toppere6337e12015-12-25 00:36:02 +0000162 data().Bases = new(C) CXXBaseSpecifier [NumBases];
163 data().NumBases = NumBases;
164 for (unsigned i = 0; i < NumBases; ++i) {
Douglas Gregord4c5ed02010-10-29 22:39:52 +0000165 data().getBases()[i] = *Bases[i];
Fariborz Jahanian3554b5a2009-07-10 20:13:23 +0000166 // Keep track of inherited vbases for this base class.
167 const CXXBaseSpecifier *Base = Bases[i];
168 QualType BaseType = Base->getType();
Douglas Gregorbeab56e2010-02-27 00:25:28 +0000169 // Skip dependent types; we can't do any checking on them now.
Fariborz Jahanian3554b5a2009-07-10 20:13:23 +0000170 if (BaseType->isDependentType())
171 continue;
172 CXXRecordDecl *BaseClassDecl
Ted Kremenekc23c7e62009-07-29 21:53:49 +0000173 = cast<CXXRecordDecl>(BaseType->getAs<RecordType>()->getDecl());
Anders Carlssonabb20e62010-03-29 05:13:12 +0000174
Chandler Carruthb1963742011-04-30 09:17:45 +0000175 if (!BaseClassDecl->isEmpty()) {
176 if (!data().Empty) {
177 // C++0x [class]p7:
178 // A standard-layout class is a class that:
179 // [...]
180 // -- either has no non-static data members in the most derived
181 // class and at most one base class with non-static data members,
182 // or has no base classes with non-static data members, and
183 // If this is the second non-empty base, then neither of these two
184 // clauses can be true.
Chandler Carruth583edf82011-04-30 10:07:30 +0000185 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000186 }
187
David Majnemer5cfda6f2016-05-22 05:34:26 +0000188 // C++14 [meta.unary.prop]p4:
189 // T is a class type [...] with [...] no base class B for which
190 // is_empty<B>::value is false.
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000191 data().Empty = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000192 data().HasNoNonEmptyBases = false;
193 }
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000194
Richard Smith872307e2016-03-08 22:17:41 +0000195 // C++1z [dcl.init.agg]p1:
196 // An aggregate is a class with [...] no private or protected base classes
197 if (Base->getAccessSpecifier() != AS_public)
198 data().Aggregate = false;
199
Douglas Gregor11c024b2010-09-28 20:50:54 +0000200 // C++ [class.virtual]p1:
201 // A class that declares or inherits a virtual function is called a
202 // polymorphic class.
203 if (BaseClassDecl->isPolymorphic())
204 data().Polymorphic = true;
Chandler Carruthe71d0622011-04-24 02:49:34 +0000205
Chandler Carruthb1963742011-04-30 09:17:45 +0000206 // C++0x [class]p7:
207 // A standard-layout class is a class that: [...]
208 // -- has no non-standard-layout base classes
Chandler Carruth583edf82011-04-30 10:07:30 +0000209 if (!BaseClassDecl->isStandardLayout())
210 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000211
Chandler Carruthe71d0622011-04-24 02:49:34 +0000212 // Record if this base is the first non-literal field or base.
Richard Smithd9f663b2013-04-22 15:31:51 +0000213 if (!hasNonLiteralTypeFieldsOrBases() && !BaseType->isLiteralType(C))
Chandler Carruthe71d0622011-04-24 02:49:34 +0000214 data().HasNonLiteralTypeFieldsOrBases = true;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000215
Anders Carlssonabb20e62010-03-29 05:13:12 +0000216 // Now go through all virtual bases of this base and add them.
Aaron Ballman445a9392014-03-13 16:15:17 +0000217 for (const auto &VBase : BaseClassDecl->vbases()) {
Anders Carlssonabb20e62010-03-29 05:13:12 +0000218 // Add this base if it's not already in the list.
David Blaikie82e95a32014-11-19 07:49:47 +0000219 if (SeenVBaseTypes.insert(C.getCanonicalType(VBase.getType())).second) {
Aaron Ballman445a9392014-03-13 16:15:17 +0000220 VBases.push_back(&VBase);
Richard Smith1c33fe82012-11-28 06:23:12 +0000221
222 // C++11 [class.copy]p8:
223 // The implicitly-declared copy constructor for a class X will have
224 // the form 'X::X(const X&)' if each [...] virtual base class B of X
225 // has a copy constructor whose first parameter is of type
226 // 'const B&' or 'const volatile B&' [...]
Aaron Ballman445a9392014-03-13 16:15:17 +0000227 if (CXXRecordDecl *VBaseDecl = VBase.getType()->getAsCXXRecordDecl())
Richard Smith1c33fe82012-11-28 06:23:12 +0000228 if (!VBaseDecl->hasCopyConstructorWithConstParam())
229 data().ImplicitCopyConstructorHasConstParam = false;
Richard Smith872307e2016-03-08 22:17:41 +0000230
231 // C++1z [dcl.init.agg]p1:
232 // An aggregate is a class with [...] no virtual base classes
233 data().Aggregate = false;
Richard Smith1c33fe82012-11-28 06:23:12 +0000234 }
Fariborz Jahanian3554b5a2009-07-10 20:13:23 +0000235 }
Anders Carlssonabb20e62010-03-29 05:13:12 +0000236
237 if (Base->isVirtual()) {
238 // Add this base if it's not already in the list.
David Blaikie82e95a32014-11-19 07:49:47 +0000239 if (SeenVBaseTypes.insert(C.getCanonicalType(BaseType)).second)
Richard Smith1c33fe82012-11-28 06:23:12 +0000240 VBases.push_back(Base);
241
David Majnemer5cfda6f2016-05-22 05:34:26 +0000242 // C++14 [meta.unary.prop] is_empty:
243 // T is a class type, but not a union type, with ... no virtual base
244 // classes
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000245 data().Empty = false;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000246
Richard Smith872307e2016-03-08 22:17:41 +0000247 // C++1z [dcl.init.agg]p1:
248 // An aggregate is a class with [...] no virtual base classes
249 data().Aggregate = false;
250
Richard Smith328aae52012-11-30 05:11:39 +0000251 // C++11 [class.ctor]p5, C++11 [class.copy]p12, C++11 [class.copy]p25:
252 // A [default constructor, copy/move constructor, or copy/move assignment
253 // operator for a class X] is trivial [...] if:
254 // -- class X has [...] no virtual base classes
255 data().HasTrivialSpecialMembers &= SMF_Destructor;
Chandler Carruthb1963742011-04-30 09:17:45 +0000256
257 // C++0x [class]p7:
258 // A standard-layout class is a class that: [...]
259 // -- has [...] no virtual base classes
Chandler Carruth583edf82011-04-30 10:07:30 +0000260 data().IsStandardLayout = false;
Richard Smithcc36f692011-12-22 02:22:31 +0000261
262 // C++11 [dcl.constexpr]p4:
263 // In the definition of a constexpr constructor [...]
264 // -- the class shall not have any virtual base classes
265 data().DefaultedDefaultConstructorIsConstexpr = false;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000266 } else {
267 // C++ [class.ctor]p5:
Alexis Huntf479f1b2011-05-09 18:22:59 +0000268 // A default constructor is trivial [...] if:
269 // -- all the direct base classes of its class have trivial default
270 // constructors.
271 if (!BaseClassDecl->hasTrivialDefaultConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000272 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
273
Chandler Carruthad7d4042011-04-23 23:10:33 +0000274 // C++0x [class.copy]p13:
275 // A copy/move constructor for class X is trivial if [...]
276 // [...]
277 // -- the constructor selected to copy/move each direct base class
278 // subobject is trivial, and
Douglas Gregor11c024b2010-09-28 20:50:54 +0000279 if (!BaseClassDecl->hasTrivialCopyConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000280 data().HasTrivialSpecialMembers &= ~SMF_CopyConstructor;
Richard Smith6b02d462012-12-08 08:32:28 +0000281 // If the base class doesn't have a simple move constructor, we'll eagerly
282 // declare it and perform overload resolution to determine which function
283 // it actually calls. If it does have a simple move constructor, this
284 // check is correct.
Richard Smith16488472012-11-16 00:53:38 +0000285 if (!BaseClassDecl->hasTrivialMoveConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000286 data().HasTrivialSpecialMembers &= ~SMF_MoveConstructor;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000287
288 // C++0x [class.copy]p27:
289 // A copy/move assignment operator for class X is trivial if [...]
290 // [...]
291 // -- the assignment operator selected to copy/move each direct base
292 // class subobject is trivial, and
Douglas Gregor11c024b2010-09-28 20:50:54 +0000293 if (!BaseClassDecl->hasTrivialCopyAssignment())
Richard Smith328aae52012-11-30 05:11:39 +0000294 data().HasTrivialSpecialMembers &= ~SMF_CopyAssignment;
Richard Smith6b02d462012-12-08 08:32:28 +0000295 // If the base class doesn't have a simple move assignment, we'll eagerly
296 // declare it and perform overload resolution to determine which function
297 // it actually calls. If it does have a simple move assignment, this
298 // check is correct.
Richard Smith16488472012-11-16 00:53:38 +0000299 if (!BaseClassDecl->hasTrivialMoveAssignment())
Richard Smith328aae52012-11-30 05:11:39 +0000300 data().HasTrivialSpecialMembers &= ~SMF_MoveAssignment;
Richard Smithcc36f692011-12-22 02:22:31 +0000301
302 // C++11 [class.ctor]p6:
Richard Smithc101e612012-01-11 18:26:05 +0000303 // If that user-written default constructor would satisfy the
Richard Smithcc36f692011-12-22 02:22:31 +0000304 // requirements of a constexpr constructor, the implicitly-defined
305 // default constructor is constexpr.
306 if (!BaseClassDecl->hasConstexprDefaultConstructor())
307 data().DefaultedDefaultConstructorIsConstexpr = false;
Anders Carlssonabb20e62010-03-29 05:13:12 +0000308 }
Richard Smith92f241f2012-12-08 02:53:02 +0000309
Douglas Gregor11c024b2010-09-28 20:50:54 +0000310 // C++ [class.ctor]p3:
311 // A destructor is trivial if all the direct base classes of its class
312 // have trivial destructors.
313 if (!BaseClassDecl->hasTrivialDestructor())
Richard Smith328aae52012-11-30 05:11:39 +0000314 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
Richard Smith561fb152012-02-25 07:33:38 +0000315
316 if (!BaseClassDecl->hasIrrelevantDestructor())
317 data().HasIrrelevantDestructor = false;
318
Richard Smith1c33fe82012-11-28 06:23:12 +0000319 // C++11 [class.copy]p18:
320 // The implicitly-declared copy assignment oeprator for a class X will
321 // have the form 'X& X::operator=(const X&)' if each direct base class B
322 // of X has a copy assignment operator whose parameter is of type 'const
323 // B&', 'const volatile B&', or 'B' [...]
324 if (!BaseClassDecl->hasCopyAssignmentWithConstParam())
325 data().ImplicitCopyAssignmentHasConstParam = false;
326
327 // C++11 [class.copy]p8:
328 // The implicitly-declared copy constructor for a class X will have
329 // the form 'X::X(const X&)' if each direct [...] base class B of X
330 // has a copy constructor whose first parameter is of type
331 // 'const B&' or 'const volatile B&' [...]
332 if (!BaseClassDecl->hasCopyConstructorWithConstParam())
333 data().ImplicitCopyConstructorHasConstParam = false;
334
John McCall31168b02011-06-15 23:02:42 +0000335 // A class has an Objective-C object member if... or any of its bases
336 // has an Objective-C object member.
337 if (BaseClassDecl->hasObjectMember())
338 setHasObjectMember(true);
Fariborz Jahanian78652202013-01-25 23:57:05 +0000339
340 if (BaseClassDecl->hasVolatileMember())
341 setHasVolatileMember(true);
John McCall31168b02011-06-15 23:02:42 +0000342
Douglas Gregor61226d32011-05-13 01:05:07 +0000343 // Keep track of the presence of mutable fields.
344 if (BaseClassDecl->hasMutableFields())
345 data().HasMutableFields = true;
Richard Smith593f9932012-12-08 02:01:17 +0000346
347 if (BaseClassDecl->hasUninitializedReferenceMember())
348 data().HasUninitializedReferenceMember = true;
Richard Smith6b02d462012-12-08 08:32:28 +0000349
Nico Weber6a6376b2016-02-19 01:52:46 +0000350 if (!BaseClassDecl->allowConstDefaultInit())
351 data().HasUninitializedFields = true;
352
Richard Smith6b02d462012-12-08 08:32:28 +0000353 addedClassSubobject(BaseClassDecl);
Fariborz Jahanian3554b5a2009-07-10 20:13:23 +0000354 }
Anders Carlssonabb20e62010-03-29 05:13:12 +0000355
David Majnemer5ef4fe72014-06-13 06:43:46 +0000356 if (VBases.empty()) {
357 data().IsParsingBaseSpecifiers = false;
Anders Carlssonabb20e62010-03-29 05:13:12 +0000358 return;
David Majnemer5ef4fe72014-06-13 06:43:46 +0000359 }
Anders Carlssonabb20e62010-03-29 05:13:12 +0000360
361 // Create base specifier for any direct or indirect virtual bases.
362 data().VBases = new (C) CXXBaseSpecifier[VBases.size()];
363 data().NumVBases = VBases.size();
Richard Smith6b02d462012-12-08 08:32:28 +0000364 for (int I = 0, E = VBases.size(); I != E; ++I) {
365 QualType Type = VBases[I]->getType();
366 if (!Type->isDependentType())
367 addedClassSubobject(Type->getAsCXXRecordDecl());
Richard Smith26935e62011-07-12 23:49:11 +0000368 data().getVBases()[I] = *VBases[I];
Richard Smith6b02d462012-12-08 08:32:28 +0000369 }
David Majnemer5ef4fe72014-06-13 06:43:46 +0000370
371 data().IsParsingBaseSpecifiers = false;
Richard Smith6b02d462012-12-08 08:32:28 +0000372}
373
374void CXXRecordDecl::addedClassSubobject(CXXRecordDecl *Subobj) {
375 // C++11 [class.copy]p11:
376 // A defaulted copy/move constructor for a class X is defined as
377 // deleted if X has:
378 // -- a direct or virtual base class B that cannot be copied/moved [...]
379 // -- a non-static data member of class type M (or array thereof)
380 // that cannot be copied or moved [...]
381 if (!Subobj->hasSimpleMoveConstructor())
382 data().NeedOverloadResolutionForMoveConstructor = true;
383
384 // C++11 [class.copy]p23:
385 // A defaulted copy/move assignment operator for a class X is defined as
386 // deleted if X has:
387 // -- a direct or virtual base class B that cannot be copied/moved [...]
388 // -- a non-static data member of class type M (or array thereof)
389 // that cannot be copied or moved [...]
390 if (!Subobj->hasSimpleMoveAssignment())
391 data().NeedOverloadResolutionForMoveAssignment = true;
392
393 // C++11 [class.ctor]p5, C++11 [class.copy]p11, C++11 [class.dtor]p5:
394 // A defaulted [ctor or dtor] for a class X is defined as
395 // deleted if X has:
396 // -- any direct or virtual base class [...] has a type with a destructor
397 // that is deleted or inaccessible from the defaulted [ctor or dtor].
398 // -- any non-static data member has a type with a destructor
399 // that is deleted or inaccessible from the defaulted [ctor or dtor].
400 if (!Subobj->hasSimpleDestructor()) {
401 data().NeedOverloadResolutionForMoveConstructor = true;
402 data().NeedOverloadResolutionForDestructor = true;
403 }
Douglas Gregor9d6290b2008-10-23 18:13:27 +0000404}
405
Douglas Gregord2e6a452010-01-14 17:47:39 +0000406bool CXXRecordDecl::hasAnyDependentBases() const {
407 if (!isDependentContext())
408 return false;
409
Benjamin Kramer6e4f6e12015-07-25 15:07:25 +0000410 return !forallBases([](const CXXRecordDecl *) { return true; });
Douglas Gregord2e6a452010-01-14 17:47:39 +0000411}
412
Chandler Carrutha3e1f9a2011-04-23 10:47:28 +0000413bool CXXRecordDecl::isTriviallyCopyable() const {
414 // C++0x [class]p5:
415 // A trivially copyable class is a class that:
416 // -- has no non-trivial copy constructors,
Richard Smith16488472012-11-16 00:53:38 +0000417 if (hasNonTrivialCopyConstructor()) return false;
Chandler Carrutha3e1f9a2011-04-23 10:47:28 +0000418 // -- has no non-trivial move constructors,
Richard Smith16488472012-11-16 00:53:38 +0000419 if (hasNonTrivialMoveConstructor()) return false;
Chandler Carrutha3e1f9a2011-04-23 10:47:28 +0000420 // -- has no non-trivial copy assignment operators,
Richard Smith16488472012-11-16 00:53:38 +0000421 if (hasNonTrivialCopyAssignment()) return false;
Chandler Carrutha3e1f9a2011-04-23 10:47:28 +0000422 // -- has no non-trivial move assignment operators, and
Richard Smith16488472012-11-16 00:53:38 +0000423 if (hasNonTrivialMoveAssignment()) return false;
Chandler Carrutha3e1f9a2011-04-23 10:47:28 +0000424 // -- has a trivial destructor.
425 if (!hasTrivialDestructor()) return false;
426
427 return true;
428}
429
Douglas Gregor7d9120c2010-09-28 21:55:22 +0000430void CXXRecordDecl::markedVirtualFunctionPure() {
431 // C++ [class.abstract]p2:
432 // A class is abstract if it has at least one pure virtual function.
433 data().Abstract = true;
434}
435
436void CXXRecordDecl::addedMember(Decl *D) {
Joao Matose9a3ed42012-08-31 22:18:20 +0000437 if (!D->isImplicit() &&
438 !isa<FieldDecl>(D) &&
439 !isa<IndirectFieldDecl>(D) &&
440 (!isa<TagDecl>(D) || cast<TagDecl>(D)->getTagKind() == TTK_Class ||
441 cast<TagDecl>(D)->getTagKind() == TTK_Interface))
442 data().HasOnlyCMembers = false;
443
444 // Ignore friends and invalid declarations.
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000445 if (D->getFriendObjectKind() || D->isInvalidDecl())
Douglas Gregord30e79f2010-09-27 21:17:54 +0000446 return;
447
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000448 FunctionTemplateDecl *FunTmpl = dyn_cast<FunctionTemplateDecl>(D);
449 if (FunTmpl)
450 D = FunTmpl->getTemplatedDecl();
Richard Smith5179eb72016-06-28 19:03:57 +0000451
452 // FIXME: Pass NamedDecl* to addedMember?
453 Decl *DUnderlying = D;
454 if (auto *ND = dyn_cast<NamedDecl>(DUnderlying)) {
455 DUnderlying = ND->getUnderlyingDecl();
456 if (FunctionTemplateDecl *UnderlyingFunTmpl =
457 dyn_cast<FunctionTemplateDecl>(DUnderlying))
458 DUnderlying = UnderlyingFunTmpl->getTemplatedDecl();
459 }
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000460
Douglas Gregora832d3e2010-09-28 19:45:33 +0000461 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D)) {
462 if (Method->isVirtual()) {
463 // C++ [dcl.init.aggr]p1:
464 // An aggregate is an array or a class with [...] no virtual functions.
465 data().Aggregate = false;
466
467 // C++ [class]p4:
468 // A POD-struct is an aggregate class...
469 data().PlainOldData = false;
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000470
David Majnemer5cfda6f2016-05-22 05:34:26 +0000471 // C++14 [meta.unary.prop]p4:
472 // T is a class type [...] with [...] no virtual member functions...
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000473 data().Empty = false;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000474
475 // C++ [class.virtual]p1:
476 // A class that declares or inherits a virtual function is called a
477 // polymorphic class.
478 data().Polymorphic = true;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000479
Richard Smith328aae52012-11-30 05:11:39 +0000480 // C++11 [class.ctor]p5, C++11 [class.copy]p12, C++11 [class.copy]p25:
481 // A [default constructor, copy/move constructor, or copy/move
482 // assignment operator for a class X] is trivial [...] if:
Chandler Carruthad7d4042011-04-23 23:10:33 +0000483 // -- class X has no virtual functions [...]
Richard Smith328aae52012-11-30 05:11:39 +0000484 data().HasTrivialSpecialMembers &= SMF_Destructor;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000485
Chandler Carruthb1963742011-04-30 09:17:45 +0000486 // C++0x [class]p7:
487 // A standard-layout class is a class that: [...]
488 // -- has no virtual functions
Chandler Carruth583edf82011-04-30 10:07:30 +0000489 data().IsStandardLayout = false;
Douglas Gregora832d3e2010-09-28 19:45:33 +0000490 }
491 }
Argyrios Kyrtzidis00f52662010-10-20 23:48:42 +0000492
Richard Smith1c33fe82012-11-28 06:23:12 +0000493 // Notify the listener if an implicit member was added after the definition
494 // was completed.
495 if (!isBeingDefined() && D->isImplicit())
496 if (ASTMutationListener *L = getASTMutationListener())
497 L->AddedCXXImplicitMember(data().Definition, D);
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000498
Richard Smith328aae52012-11-30 05:11:39 +0000499 // The kind of special member this declaration is, if any.
500 unsigned SMKind = 0;
501
Richard Smith1c33fe82012-11-28 06:23:12 +0000502 // Handle constructors.
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000503 if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(D)) {
Richard Smith1c33fe82012-11-28 06:23:12 +0000504 if (!Constructor->isImplicit()) {
505 // Note that we have a user-declared constructor.
506 data().UserDeclaredConstructor = true;
507
508 // C++ [class]p4:
509 // A POD-struct is an aggregate class [...]
510 // Since the POD bit is meant to be C++03 POD-ness, clear it even if the
511 // type is technically an aggregate in C++0x since it wouldn't be in 03.
512 data().PlainOldData = false;
513 }
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000514
Alexis Hunt88c75c32011-05-09 21:45:35 +0000515 if (Constructor->isDefaultConstructor()) {
Richard Smith328aae52012-11-30 05:11:39 +0000516 SMKind |= SMF_DefaultConstructor;
517
Richard Smith5179eb72016-06-28 19:03:57 +0000518 if (Constructor->isUserProvided())
Alexis Huntea6f0322011-05-11 22:34:38 +0000519 data().UserProvidedDefaultConstructor = true;
Richard Smith1c33fe82012-11-28 06:23:12 +0000520 if (Constructor->isConstexpr())
Richard Smithcc36f692011-12-22 02:22:31 +0000521 data().HasConstexprDefaultConstructor = true;
Nico Weber72c57f42016-02-24 20:58:14 +0000522 if (Constructor->isDefaulted())
523 data().HasDefaultedDefaultConstructor = true;
Alexis Hunt88c75c32011-05-09 21:45:35 +0000524 }
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000525
Chandler Carruthad7d4042011-04-23 23:10:33 +0000526 if (!FunTmpl) {
Richard Smith1c33fe82012-11-28 06:23:12 +0000527 unsigned Quals;
528 if (Constructor->isCopyConstructor(Quals)) {
Richard Smith328aae52012-11-30 05:11:39 +0000529 SMKind |= SMF_CopyConstructor;
Richard Smith1c33fe82012-11-28 06:23:12 +0000530
531 if (Quals & Qualifiers::Const)
532 data().HasDeclaredCopyConstructorWithConstParam = true;
Richard Smith328aae52012-11-30 05:11:39 +0000533 } else if (Constructor->isMoveConstructor())
534 SMKind |= SMF_MoveConstructor;
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000535 }
Eric Fiselier283d8d42016-12-03 01:26:47 +0000536
Eric Fiselier283d8d42016-12-03 01:26:47 +0000537 // C++11 [dcl.init.aggr]p1: DR1518
Richard Smith505ef812016-12-21 01:57:02 +0000538 // An aggregate is an array or a class with no user-provided, explicit, or
539 // inherited constructors
540 if (Constructor->isUserProvided() || Constructor->isExplicit())
Eric Fiselier283d8d42016-12-03 01:26:47 +0000541 data().Aggregate = false;
Richard Smith5179eb72016-06-28 19:03:57 +0000542 }
Richard Smith1c33fe82012-11-28 06:23:12 +0000543
Richard Smith5179eb72016-06-28 19:03:57 +0000544 // Handle constructors, including those inherited from base classes.
545 if (CXXConstructorDecl *Constructor =
546 dyn_cast<CXXConstructorDecl>(DUnderlying)) {
Richard Smith1c33fe82012-11-28 06:23:12 +0000547 // Record if we see any constexpr constructors which are neither copy
548 // nor move constructors.
Richard Smith5179eb72016-06-28 19:03:57 +0000549 // C++1z [basic.types]p10:
550 // [...] has at least one constexpr constructor or constructor template
551 // (possibly inherited from a base class) that is not a copy or move
552 // constructor [...]
Richard Smith1c33fe82012-11-28 06:23:12 +0000553 if (Constructor->isConstexpr() && !Constructor->isCopyOrMoveConstructor())
Richard Smith111af8d2011-08-10 18:11:37 +0000554 data().HasConstexprNonCopyMoveConstructor = true;
Douglas Gregord30e79f2010-09-27 21:17:54 +0000555 }
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000556
Richard Smith1c33fe82012-11-28 06:23:12 +0000557 // Handle destructors.
Alexis Hunt97ab5542011-05-16 22:41:40 +0000558 if (CXXDestructorDecl *DD = dyn_cast<CXXDestructorDecl>(D)) {
Richard Smith328aae52012-11-30 05:11:39 +0000559 SMKind |= SMF_Destructor;
Richard Smith561fb152012-02-25 07:33:38 +0000560
Stephan Tolksdorfd85fa232014-03-27 20:23:12 +0000561 if (DD->isUserProvided())
Richard Smith1c33fe82012-11-28 06:23:12 +0000562 data().HasIrrelevantDestructor = false;
Stephan Tolksdorfd85fa232014-03-27 20:23:12 +0000563 // If the destructor is explicitly defaulted and not trivial or not public
564 // or if the destructor is deleted, we clear HasIrrelevantDestructor in
565 // finishedDefaultedOrDeletedMember.
Richard Smith1c33fe82012-11-28 06:23:12 +0000566
Richard Smith1c33fe82012-11-28 06:23:12 +0000567 // C++11 [class.dtor]p5:
Richard Smith328aae52012-11-30 05:11:39 +0000568 // A destructor is trivial if [...] the destructor is not virtual.
569 if (DD->isVirtual())
570 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
Douglas Gregor8f9ebe52010-09-27 22:48:58 +0000571 }
Richard Smith1c33fe82012-11-28 06:23:12 +0000572
573 // Handle member functions.
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000574 if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D)) {
Alexis Huntfcaeae42011-05-25 20:50:04 +0000575 if (Method->isCopyAssignmentOperator()) {
Richard Smith328aae52012-11-30 05:11:39 +0000576 SMKind |= SMF_CopyAssignment;
Richard Smith1c33fe82012-11-28 06:23:12 +0000577
578 const ReferenceType *ParamTy =
579 Method->getParamDecl(0)->getType()->getAs<ReferenceType>();
580 if (!ParamTy || ParamTy->getPointeeType().isConstQualified())
581 data().HasDeclaredCopyAssignmentWithConstParam = true;
Alexis Huntfcaeae42011-05-25 20:50:04 +0000582 }
Alexis Huntfcaeae42011-05-25 20:50:04 +0000583
Richard Smith328aae52012-11-30 05:11:39 +0000584 if (Method->isMoveAssignmentOperator())
585 SMKind |= SMF_MoveAssignment;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000586
Douglas Gregor457104e2010-09-29 04:25:11 +0000587 // Keep the list of conversion functions up-to-date.
588 if (CXXConversionDecl *Conversion = dyn_cast<CXXConversionDecl>(D)) {
Douglas Gregor92fde2f2013-04-08 17:12:58 +0000589 // FIXME: We use the 'unsafe' accessor for the access specifier here,
590 // because Sema may not have set it yet. That's really just a misdesign
591 // in Sema. However, LLDB *will* have set the access specifier correctly,
592 // and adds declarations after the class is technically completed,
593 // so completeDefinition()'s overriding of the access specifiers doesn't
594 // work.
595 AccessSpecifier AS = Conversion->getAccessUnsafe();
596
Richard Smith328aae52012-11-30 05:11:39 +0000597 if (Conversion->getPrimaryTemplate()) {
598 // We don't record specializations.
Douglas Gregor457104e2010-09-29 04:25:11 +0000599 } else {
Richard Smitha4ba74c2013-08-30 04:46:40 +0000600 ASTContext &Ctx = getASTContext();
601 ASTUnresolvedSet &Conversions = data().Conversions.get(Ctx);
602 NamedDecl *Primary =
603 FunTmpl ? cast<NamedDecl>(FunTmpl) : cast<NamedDecl>(Conversion);
604 if (Primary->getPreviousDecl())
605 Conversions.replace(cast<NamedDecl>(Primary->getPreviousDecl()),
606 Primary, AS);
Douglas Gregor457104e2010-09-29 04:25:11 +0000607 else
Richard Smitha4ba74c2013-08-30 04:46:40 +0000608 Conversions.addDecl(Ctx, Primary, AS);
Douglas Gregor457104e2010-09-29 04:25:11 +0000609 }
610 }
Richard Smith1c33fe82012-11-28 06:23:12 +0000611
Richard Smith328aae52012-11-30 05:11:39 +0000612 if (SMKind) {
Richard Smith92f241f2012-12-08 02:53:02 +0000613 // If this is the first declaration of a special member, we no longer have
614 // an implicit trivial special member.
615 data().HasTrivialSpecialMembers &=
616 data().DeclaredSpecialMembers | ~SMKind;
617
618 if (!Method->isImplicit() && !Method->isUserProvided()) {
619 // This method is user-declared but not user-provided. We can't work out
620 // whether it's trivial yet (not until we get to the end of the class).
621 // We'll handle this method in finishedDefaultedOrDeletedMember.
622 } else if (Method->isTrivial())
623 data().HasTrivialSpecialMembers |= SMKind;
624 else
625 data().DeclaredNonTrivialSpecialMembers |= SMKind;
626
Richard Smith328aae52012-11-30 05:11:39 +0000627 // Note when we have declared a declared special member, and suppress the
628 // implicit declaration of this special member.
629 data().DeclaredSpecialMembers |= SMKind;
630
631 if (!Method->isImplicit()) {
632 data().UserDeclaredSpecialMembers |= SMKind;
633
634 // C++03 [class]p4:
635 // A POD-struct is an aggregate class that has [...] no user-defined
636 // copy assignment operator and no user-defined destructor.
637 //
638 // Since the POD bit is meant to be C++03 POD-ness, and in C++03,
639 // aggregates could not have any constructors, clear it even for an
640 // explicitly defaulted or deleted constructor.
641 // type is technically an aggregate in C++0x since it wouldn't be in 03.
642 //
643 // Also, a user-declared move assignment operator makes a class non-POD.
644 // This is an extension in C++03.
645 data().PlainOldData = false;
646 }
Richard Smith328aae52012-11-30 05:11:39 +0000647 }
648
Douglas Gregora1ce1f82010-09-27 22:06:20 +0000649 return;
Douglas Gregor8a273912009-07-22 18:25:24 +0000650 }
Richard Smith328aae52012-11-30 05:11:39 +0000651
Douglas Gregora832d3e2010-09-28 19:45:33 +0000652 // Handle non-static data members.
653 if (FieldDecl *Field = dyn_cast<FieldDecl>(D)) {
Douglas Gregor556e5862011-10-10 17:22:13 +0000654 // C++ [class.bit]p2:
655 // A declaration for a bit-field that omits the identifier declares an
656 // unnamed bit-field. Unnamed bit-fields are not members and cannot be
657 // initialized.
658 if (Field->isUnnamedBitfield())
659 return;
660
Douglas Gregora832d3e2010-09-28 19:45:33 +0000661 // C++ [dcl.init.aggr]p1:
662 // An aggregate is an array or a class (clause 9) with [...] no
663 // private or protected non-static data members (clause 11).
664 //
665 // A POD must be an aggregate.
666 if (D->getAccess() == AS_private || D->getAccess() == AS_protected) {
667 data().Aggregate = false;
668 data().PlainOldData = false;
669 }
Chandler Carruthb1963742011-04-30 09:17:45 +0000670
671 // C++0x [class]p7:
672 // A standard-layout class is a class that:
673 // [...]
674 // -- has the same access control for all non-static data members,
675 switch (D->getAccess()) {
676 case AS_private: data().HasPrivateFields = true; break;
677 case AS_protected: data().HasProtectedFields = true; break;
678 case AS_public: data().HasPublicFields = true; break;
David Blaikie83d382b2011-09-23 05:06:16 +0000679 case AS_none: llvm_unreachable("Invalid access specifier");
Chandler Carruthb1963742011-04-30 09:17:45 +0000680 };
681 if ((data().HasPrivateFields + data().HasProtectedFields +
682 data().HasPublicFields) > 1)
Chandler Carruth583edf82011-04-30 10:07:30 +0000683 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000684
Douglas Gregor61226d32011-05-13 01:05:07 +0000685 // Keep track of the presence of mutable fields.
686 if (Field->isMutable())
687 data().HasMutableFields = true;
Richard Smithab44d5b2013-12-10 08:25:00 +0000688
689 // C++11 [class.union]p8, DR1460:
690 // If X is a union, a non-static data member of X that is not an anonymous
691 // union is a variant member of X.
692 if (isUnion() && !Field->isAnonymousStructOrUnion())
693 data().HasVariantMembers = true;
694
Chandler Carruthad7d4042011-04-23 23:10:33 +0000695 // C++0x [class]p9:
Douglas Gregora832d3e2010-09-28 19:45:33 +0000696 // A POD struct is a class that is both a trivial class and a
697 // standard-layout class, and has no non-static data members of type
698 // non-POD struct, non-POD union (or array of such types).
John McCall31168b02011-06-15 23:02:42 +0000699 //
700 // Automatic Reference Counting: the presence of a member of Objective-C pointer type
701 // that does not explicitly have no lifetime makes the class a non-POD.
Douglas Gregora832d3e2010-09-28 19:45:33 +0000702 ASTContext &Context = getASTContext();
703 QualType T = Context.getBaseElementType(Field->getType());
John McCall31168b02011-06-15 23:02:42 +0000704 if (T->isObjCRetainableType() || T.isObjCGCStrong()) {
Ben Langmuir11eab612014-09-26 15:27:29 +0000705 if (!Context.getLangOpts().ObjCAutoRefCount) {
John McCall31168b02011-06-15 23:02:42 +0000706 setHasObjectMember(true);
Ben Langmuir11eab612014-09-26 15:27:29 +0000707 } else if (T.getObjCLifetime() != Qualifiers::OCL_ExplicitNone) {
708 // Objective-C Automatic Reference Counting:
709 // If a class has a non-static data member of Objective-C pointer
710 // type (or array thereof), it is a non-POD type and its
711 // default constructor (if any), copy constructor, move constructor,
712 // copy assignment operator, move assignment operator, and destructor are
713 // non-trivial.
714 setHasObjectMember(true);
715 struct DefinitionData &Data = data();
716 Data.PlainOldData = false;
717 Data.HasTrivialSpecialMembers = 0;
718 Data.HasIrrelevantDestructor = false;
719 }
Eli Friedmana5433322013-07-20 01:06:31 +0000720 } else if (!T.isCXX98PODType(Context))
Douglas Gregora832d3e2010-09-28 19:45:33 +0000721 data().PlainOldData = false;
John McCall31168b02011-06-15 23:02:42 +0000722
Chandler Carruthb1963742011-04-30 09:17:45 +0000723 if (T->isReferenceType()) {
Richard Smith593f9932012-12-08 02:01:17 +0000724 if (!Field->hasInClassInitializer())
725 data().HasUninitializedReferenceMember = true;
Chandler Carruthe71d0622011-04-24 02:49:34 +0000726
Chandler Carruthb1963742011-04-30 09:17:45 +0000727 // C++0x [class]p7:
728 // A standard-layout class is a class that:
729 // -- has no non-static data members of type [...] reference,
Chandler Carruth583edf82011-04-30 10:07:30 +0000730 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000731 }
732
Nico Weber6a6376b2016-02-19 01:52:46 +0000733 if (!Field->hasInClassInitializer() && !Field->isMutable()) {
Richard Smith9b182172016-10-28 19:11:18 +0000734 if (CXXRecordDecl *FieldType = T->getAsCXXRecordDecl()) {
Nico Weber344abaa2016-02-19 02:51:07 +0000735 if (FieldType->hasDefinition() && !FieldType->allowConstDefaultInit())
Nico Weber6a6376b2016-02-19 01:52:46 +0000736 data().HasUninitializedFields = true;
737 } else {
738 data().HasUninitializedFields = true;
739 }
740 }
741
Richard Smith3607ffe2012-02-13 03:54:03 +0000742 // Record if this field is the first non-literal or volatile field or base.
Richard Smithd9f663b2013-04-22 15:31:51 +0000743 if (!T->isLiteralType(Context) || T.isVolatileQualified())
Chandler Carruthe71d0622011-04-24 02:49:34 +0000744 data().HasNonLiteralTypeFieldsOrBases = true;
745
Richard Smithab44d5b2013-12-10 08:25:00 +0000746 if (Field->hasInClassInitializer() ||
747 (Field->isAnonymousStructOrUnion() &&
748 Field->getType()->getAsCXXRecordDecl()->hasInClassInitializer())) {
Richard Smithe2648ba2012-05-07 01:07:30 +0000749 data().HasInClassInitializer = true;
750
751 // C++11 [class]p5:
Richard Smith938f40b2011-06-11 17:19:42 +0000752 // A default constructor is trivial if [...] no non-static data member
753 // of its class has a brace-or-equal-initializer.
Richard Smith328aae52012-11-30 05:11:39 +0000754 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
Richard Smith938f40b2011-06-11 17:19:42 +0000755
Richard Smithe2648ba2012-05-07 01:07:30 +0000756 // C++11 [dcl.init.aggr]p1:
Richard Smith938f40b2011-06-11 17:19:42 +0000757 // An aggregate is a [...] class with [...] no
758 // brace-or-equal-initializers for non-static data members.
Richard Smith852c9db2013-04-20 22:23:05 +0000759 //
Richard Smith872307e2016-03-08 22:17:41 +0000760 // This rule was removed in C++14.
Aaron Ballmandd69ef32014-08-19 15:55:55 +0000761 if (!getASTContext().getLangOpts().CPlusPlus14)
Richard Smith852c9db2013-04-20 22:23:05 +0000762 data().Aggregate = false;
Richard Smith938f40b2011-06-11 17:19:42 +0000763
Richard Smithe2648ba2012-05-07 01:07:30 +0000764 // C++11 [class]p10:
Richard Smith938f40b2011-06-11 17:19:42 +0000765 // A POD struct is [...] a trivial class.
766 data().PlainOldData = false;
767 }
768
Richard Smith6b02d462012-12-08 08:32:28 +0000769 // C++11 [class.copy]p23:
770 // A defaulted copy/move assignment operator for a class X is defined
771 // as deleted if X has:
772 // -- a non-static data member of reference type
773 if (T->isReferenceType())
774 data().DefaultedMoveAssignmentIsDeleted = true;
775
Douglas Gregor11c024b2010-09-28 20:50:54 +0000776 if (const RecordType *RecordTy = T->getAs<RecordType>()) {
777 CXXRecordDecl* FieldRec = cast<CXXRecordDecl>(RecordTy->getDecl());
778 if (FieldRec->getDefinition()) {
Richard Smith6b02d462012-12-08 08:32:28 +0000779 addedClassSubobject(FieldRec);
780
Richard Smithc91d12c2013-11-25 07:07:05 +0000781 // We may need to perform overload resolution to determine whether a
782 // field can be moved if it's const or volatile qualified.
783 if (T.getCVRQualifiers() & (Qualifiers::Const | Qualifiers::Volatile)) {
784 data().NeedOverloadResolutionForMoveConstructor = true;
785 data().NeedOverloadResolutionForMoveAssignment = true;
786 }
787
Richard Smith6b02d462012-12-08 08:32:28 +0000788 // C++11 [class.ctor]p5, C++11 [class.copy]p11:
789 // A defaulted [special member] for a class X is defined as
790 // deleted if:
791 // -- X is a union-like class that has a variant member with a
792 // non-trivial [corresponding special member]
793 if (isUnion()) {
794 if (FieldRec->hasNonTrivialMoveConstructor())
795 data().DefaultedMoveConstructorIsDeleted = true;
796 if (FieldRec->hasNonTrivialMoveAssignment())
797 data().DefaultedMoveAssignmentIsDeleted = true;
798 if (FieldRec->hasNonTrivialDestructor())
799 data().DefaultedDestructorIsDeleted = true;
800 }
801
Richard Smithdd5619f2016-08-16 00:13:47 +0000802 // For an anonymous union member, our overload resolution will perform
803 // overload resolution for its members.
804 if (Field->isAnonymousStructOrUnion()) {
805 data().NeedOverloadResolutionForMoveConstructor |=
806 FieldRec->data().NeedOverloadResolutionForMoveConstructor;
807 data().NeedOverloadResolutionForMoveAssignment |=
808 FieldRec->data().NeedOverloadResolutionForMoveAssignment;
809 data().NeedOverloadResolutionForDestructor |=
810 FieldRec->data().NeedOverloadResolutionForDestructor;
811 }
812
Alexis Huntf479f1b2011-05-09 18:22:59 +0000813 // C++0x [class.ctor]p5:
Richard Smithcc36f692011-12-22 02:22:31 +0000814 // A default constructor is trivial [...] if:
Alexis Huntf479f1b2011-05-09 18:22:59 +0000815 // -- for all the non-static data members of its class that are of
816 // class type (or array thereof), each such class has a trivial
817 // default constructor.
818 if (!FieldRec->hasTrivialDefaultConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000819 data().HasTrivialSpecialMembers &= ~SMF_DefaultConstructor;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000820
821 // C++0x [class.copy]p13:
822 // A copy/move constructor for class X is trivial if [...]
823 // [...]
824 // -- for each non-static data member of X that is of class type (or
825 // an array thereof), the constructor selected to copy/move that
826 // member is trivial;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000827 if (!FieldRec->hasTrivialCopyConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000828 data().HasTrivialSpecialMembers &= ~SMF_CopyConstructor;
Richard Smith6b02d462012-12-08 08:32:28 +0000829 // If the field doesn't have a simple move constructor, we'll eagerly
830 // declare the move constructor for this class and we'll decide whether
831 // it's trivial then.
Richard Smith16488472012-11-16 00:53:38 +0000832 if (!FieldRec->hasTrivialMoveConstructor())
Richard Smith328aae52012-11-30 05:11:39 +0000833 data().HasTrivialSpecialMembers &= ~SMF_MoveConstructor;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000834
835 // C++0x [class.copy]p27:
836 // A copy/move assignment operator for class X is trivial if [...]
837 // [...]
838 // -- for each non-static data member of X that is of class type (or
839 // an array thereof), the assignment operator selected to
840 // copy/move that member is trivial;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000841 if (!FieldRec->hasTrivialCopyAssignment())
Richard Smith328aae52012-11-30 05:11:39 +0000842 data().HasTrivialSpecialMembers &= ~SMF_CopyAssignment;
Richard Smith6b02d462012-12-08 08:32:28 +0000843 // If the field doesn't have a simple move assignment, we'll eagerly
844 // declare the move assignment for this class and we'll decide whether
845 // it's trivial then.
Richard Smith16488472012-11-16 00:53:38 +0000846 if (!FieldRec->hasTrivialMoveAssignment())
Richard Smith328aae52012-11-30 05:11:39 +0000847 data().HasTrivialSpecialMembers &= ~SMF_MoveAssignment;
Chandler Carruthad7d4042011-04-23 23:10:33 +0000848
Douglas Gregor11c024b2010-09-28 20:50:54 +0000849 if (!FieldRec->hasTrivialDestructor())
Richard Smith328aae52012-11-30 05:11:39 +0000850 data().HasTrivialSpecialMembers &= ~SMF_Destructor;
Richard Smith561fb152012-02-25 07:33:38 +0000851 if (!FieldRec->hasIrrelevantDestructor())
852 data().HasIrrelevantDestructor = false;
John McCall31168b02011-06-15 23:02:42 +0000853 if (FieldRec->hasObjectMember())
854 setHasObjectMember(true);
Fariborz Jahanian78652202013-01-25 23:57:05 +0000855 if (FieldRec->hasVolatileMember())
856 setHasVolatileMember(true);
Chandler Carruthb1963742011-04-30 09:17:45 +0000857
858 // C++0x [class]p7:
859 // A standard-layout class is a class that:
860 // -- has no non-static data members of type non-standard-layout
861 // class (or array of such types) [...]
Chandler Carruth583edf82011-04-30 10:07:30 +0000862 if (!FieldRec->isStandardLayout())
863 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000864
865 // C++0x [class]p7:
866 // A standard-layout class is a class that:
867 // [...]
868 // -- has no base classes of the same type as the first non-static
869 // data member.
870 // We don't want to expend bits in the state of the record decl
871 // tracking whether this is the first non-static data member so we
872 // cheat a bit and use some of the existing state: the empty bit.
873 // Virtual bases and virtual methods make a class non-empty, but they
874 // also make it non-standard-layout so we needn't check here.
875 // A non-empty base class may leave the class standard-layout, but not
Richard Smithab44d5b2013-12-10 08:25:00 +0000876 // if we have arrived here, and have at least one non-static data
Chandler Carruth583edf82011-04-30 10:07:30 +0000877 // member. If IsStandardLayout remains true, then the first non-static
Chandler Carruthb1963742011-04-30 09:17:45 +0000878 // data member must come through here with Empty still true, and Empty
879 // will subsequently be set to false below.
Chandler Carruth583edf82011-04-30 10:07:30 +0000880 if (data().IsStandardLayout && data().Empty) {
Aaron Ballman574705e2014-03-13 15:41:46 +0000881 for (const auto &BI : bases()) {
882 if (Context.hasSameUnqualifiedType(BI.getType(), T)) {
Chandler Carruth583edf82011-04-30 10:07:30 +0000883 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000884 break;
885 }
886 }
887 }
Douglas Gregor61226d32011-05-13 01:05:07 +0000888
889 // Keep track of the presence of mutable fields.
890 if (FieldRec->hasMutableFields())
891 data().HasMutableFields = true;
Richard Smithcc36f692011-12-22 02:22:31 +0000892
893 // C++11 [class.copy]p13:
894 // If the implicitly-defined constructor would satisfy the
895 // requirements of a constexpr constructor, the implicitly-defined
896 // constructor is constexpr.
897 // C++11 [dcl.constexpr]p4:
898 // -- every constructor involved in initializing non-static data
899 // members [...] shall be a constexpr constructor
900 if (!Field->hasInClassInitializer() &&
Richard Smithe2648ba2012-05-07 01:07:30 +0000901 !FieldRec->hasConstexprDefaultConstructor() && !isUnion())
Richard Smithcc36f692011-12-22 02:22:31 +0000902 // The standard requires any in-class initializer to be a constant
903 // expression. We consider this to be a defect.
904 data().DefaultedDefaultConstructorIsConstexpr = false;
Richard Smith1c33fe82012-11-28 06:23:12 +0000905
906 // C++11 [class.copy]p8:
907 // The implicitly-declared copy constructor for a class X will have
908 // the form 'X::X(const X&)' if [...] for all the non-static data
909 // members of X that are of a class type M (or array thereof), each
910 // such class type has a copy constructor whose first parameter is
911 // of type 'const M&' or 'const volatile M&'.
912 if (!FieldRec->hasCopyConstructorWithConstParam())
913 data().ImplicitCopyConstructorHasConstParam = false;
914
915 // C++11 [class.copy]p18:
916 // The implicitly-declared copy assignment oeprator for a class X will
917 // have the form 'X& X::operator=(const X&)' if [...] for all the
918 // non-static data members of X that are of a class type M (or array
919 // thereof), each such class type has a copy assignment operator whose
920 // parameter is of type 'const M&', 'const volatile M&' or 'M'.
921 if (!FieldRec->hasCopyAssignmentWithConstParam())
922 data().ImplicitCopyAssignmentHasConstParam = false;
Richard Smith593f9932012-12-08 02:01:17 +0000923
924 if (FieldRec->hasUninitializedReferenceMember() &&
925 !Field->hasInClassInitializer())
926 data().HasUninitializedReferenceMember = true;
Richard Smithab44d5b2013-12-10 08:25:00 +0000927
928 // C++11 [class.union]p8, DR1460:
929 // a non-static data member of an anonymous union that is a member of
930 // X is also a variant member of X.
931 if (FieldRec->hasVariantMembers() &&
932 Field->isAnonymousStructOrUnion())
933 data().HasVariantMembers = true;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000934 }
Richard Smithcc36f692011-12-22 02:22:31 +0000935 } else {
936 // Base element type of field is a non-class type.
Richard Smithd9f663b2013-04-22 15:31:51 +0000937 if (!T->isLiteralType(Context) ||
Richard Smith4086a132012-06-10 07:07:24 +0000938 (!Field->hasInClassInitializer() && !isUnion()))
Richard Smithcc36f692011-12-22 02:22:31 +0000939 data().DefaultedDefaultConstructorIsConstexpr = false;
Richard Smith6b02d462012-12-08 08:32:28 +0000940
941 // C++11 [class.copy]p23:
942 // A defaulted copy/move assignment operator for a class X is defined
943 // as deleted if X has:
944 // -- a non-static data member of const non-class type (or array
945 // thereof)
946 if (T.isConstQualified())
947 data().DefaultedMoveAssignmentIsDeleted = true;
Douglas Gregor11c024b2010-09-28 20:50:54 +0000948 }
Chandler Carruthb1963742011-04-30 09:17:45 +0000949
950 // C++0x [class]p7:
951 // A standard-layout class is a class that:
952 // [...]
953 // -- either has no non-static data members in the most derived
954 // class and at most one base class with non-static data members,
955 // or has no base classes with non-static data members, and
956 // At this point we know that we have a non-static data member, so the last
957 // clause holds.
958 if (!data().HasNoNonEmptyBases)
Chandler Carruth583edf82011-04-30 10:07:30 +0000959 data().IsStandardLayout = false;
Chandler Carruthb1963742011-04-30 09:17:45 +0000960
David Majnemer5cfda6f2016-05-22 05:34:26 +0000961 // C++14 [meta.unary.prop]p4:
962 // T is a class type [...] with [...] no non-static data members other
963 // than bit-fields of length 0...
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000964 if (data().Empty) {
Richard Smithcaf33902011-10-10 18:28:20 +0000965 if (!Field->isBitField() ||
966 (!Field->getBitWidth()->isTypeDependent() &&
967 !Field->getBitWidth()->isValueDependent() &&
968 Field->getBitWidthValue(Context) != 0))
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000969 data().Empty = false;
Douglas Gregor9d5938a2010-09-28 20:38:10 +0000970 }
Douglas Gregora832d3e2010-09-28 19:45:33 +0000971 }
Douglas Gregor457104e2010-09-29 04:25:11 +0000972
973 // Handle using declarations of conversion functions.
Richard Smitha4ba74c2013-08-30 04:46:40 +0000974 if (UsingShadowDecl *Shadow = dyn_cast<UsingShadowDecl>(D)) {
Douglas Gregor457104e2010-09-29 04:25:11 +0000975 if (Shadow->getDeclName().getNameKind()
Richard Smitha4ba74c2013-08-30 04:46:40 +0000976 == DeclarationName::CXXConversionFunctionName) {
977 ASTContext &Ctx = getASTContext();
978 data().Conversions.get(Ctx).addDecl(Ctx, Shadow, Shadow->getAccess());
979 }
980 }
Richard Smith12e79312016-05-13 06:47:56 +0000981
982 if (UsingDecl *Using = dyn_cast<UsingDecl>(D)) {
983 if (Using->getDeclName().getNameKind() ==
Eric Fiselier283d8d42016-12-03 01:26:47 +0000984 DeclarationName::CXXConstructorName) {
Richard Smith12e79312016-05-13 06:47:56 +0000985 data().HasInheritedConstructor = true;
Eric Fiselier283d8d42016-12-03 01:26:47 +0000986 // C++1z [dcl.init.aggr]p1:
987 // An aggregate is [...] a class [...] with no inherited constructors
988 data().Aggregate = false;
989 }
Richard Smith12e79312016-05-13 06:47:56 +0000990
991 if (Using->getDeclName().getCXXOverloadedOperator() == OO_Equal)
992 data().HasInheritedAssignment = true;
993 }
Joao Matose9a3ed42012-08-31 22:18:20 +0000994}
995
Richard Smith92f241f2012-12-08 02:53:02 +0000996void CXXRecordDecl::finishedDefaultedOrDeletedMember(CXXMethodDecl *D) {
997 assert(!D->isImplicit() && !D->isUserProvided());
998
999 // The kind of special member this declaration is, if any.
1000 unsigned SMKind = 0;
1001
1002 if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(D)) {
1003 if (Constructor->isDefaultConstructor()) {
1004 SMKind |= SMF_DefaultConstructor;
1005 if (Constructor->isConstexpr())
1006 data().HasConstexprDefaultConstructor = true;
1007 }
1008 if (Constructor->isCopyConstructor())
1009 SMKind |= SMF_CopyConstructor;
1010 else if (Constructor->isMoveConstructor())
1011 SMKind |= SMF_MoveConstructor;
1012 else if (Constructor->isConstexpr())
1013 // We may now know that the constructor is constexpr.
1014 data().HasConstexprNonCopyMoveConstructor = true;
Stephan Tolksdorfd85fa232014-03-27 20:23:12 +00001015 } else if (isa<CXXDestructorDecl>(D)) {
Richard Smith92f241f2012-12-08 02:53:02 +00001016 SMKind |= SMF_Destructor;
Stephan Tolksdorfd85fa232014-03-27 20:23:12 +00001017 if (!D->isTrivial() || D->getAccess() != AS_public || D->isDeleted())
1018 data().HasIrrelevantDestructor = false;
1019 } else if (D->isCopyAssignmentOperator())
Richard Smith92f241f2012-12-08 02:53:02 +00001020 SMKind |= SMF_CopyAssignment;
1021 else if (D->isMoveAssignmentOperator())
1022 SMKind |= SMF_MoveAssignment;
1023
1024 // Update which trivial / non-trivial special members we have.
1025 // addedMember will have skipped this step for this member.
1026 if (D->isTrivial())
1027 data().HasTrivialSpecialMembers |= SMKind;
1028 else
1029 data().DeclaredNonTrivialSpecialMembers |= SMKind;
1030}
1031
Joao Matose9a3ed42012-08-31 22:18:20 +00001032bool CXXRecordDecl::isCLike() const {
1033 if (getTagKind() == TTK_Class || getTagKind() == TTK_Interface ||
1034 !TemplateOrInstantiation.isNull())
1035 return false;
1036 if (!hasDefinition())
1037 return true;
Argyrios Kyrtzidis5c4e0652012-01-23 16:58:45 +00001038
Argyrios Kyrtzidisc3c9ee52012-02-01 06:36:44 +00001039 return isPOD() && data().HasOnlyCMembers;
Argyrios Kyrtzidis5c4e0652012-01-23 16:58:45 +00001040}
Faisal Valic1a6dc42013-10-23 16:10:50 +00001041
Faisal Vali2b391ab2013-09-26 19:54:12 +00001042bool CXXRecordDecl::isGenericLambda() const {
Faisal Valic1a6dc42013-10-23 16:10:50 +00001043 if (!isLambda()) return false;
1044 return getLambdaData().IsGenericLambda;
Faisal Vali2b391ab2013-09-26 19:54:12 +00001045}
1046
1047CXXMethodDecl* CXXRecordDecl::getLambdaCallOperator() const {
Craig Topper36250ad2014-05-12 05:36:57 +00001048 if (!isLambda()) return nullptr;
Faisal Vali850da1a2013-09-29 17:08:32 +00001049 DeclarationName Name =
1050 getASTContext().DeclarationNames.getCXXOperatorName(OO_Call);
Richard Smithcf4bdde2015-02-21 02:45:19 +00001051 DeclContext::lookup_result Calls = lookup(Name);
Faisal Vali850da1a2013-09-29 17:08:32 +00001052
1053 assert(!Calls.empty() && "Missing lambda call operator!");
1054 assert(Calls.size() == 1 && "More than one lambda call operator!");
1055
1056 NamedDecl *CallOp = Calls.front();
1057 if (FunctionTemplateDecl *CallOpTmpl =
1058 dyn_cast<FunctionTemplateDecl>(CallOp))
1059 return cast<CXXMethodDecl>(CallOpTmpl->getTemplatedDecl());
Faisal Vali2b391ab2013-09-26 19:54:12 +00001060
1061 return cast<CXXMethodDecl>(CallOp);
1062}
1063
1064CXXMethodDecl* CXXRecordDecl::getLambdaStaticInvoker() const {
Craig Topper36250ad2014-05-12 05:36:57 +00001065 if (!isLambda()) return nullptr;
Faisal Vali850da1a2013-09-29 17:08:32 +00001066 DeclarationName Name =
1067 &getASTContext().Idents.get(getLambdaStaticInvokerName());
Richard Smithcf4bdde2015-02-21 02:45:19 +00001068 DeclContext::lookup_result Invoker = lookup(Name);
Craig Topper36250ad2014-05-12 05:36:57 +00001069 if (Invoker.empty()) return nullptr;
Faisal Vali850da1a2013-09-29 17:08:32 +00001070 assert(Invoker.size() == 1 && "More than one static invoker operator!");
1071 NamedDecl *InvokerFun = Invoker.front();
1072 if (FunctionTemplateDecl *InvokerTemplate =
1073 dyn_cast<FunctionTemplateDecl>(InvokerFun))
1074 return cast<CXXMethodDecl>(InvokerTemplate->getTemplatedDecl());
1075
Faisal Vali571df122013-09-29 08:45:24 +00001076 return cast<CXXMethodDecl>(InvokerFun);
Faisal Vali2b391ab2013-09-26 19:54:12 +00001077}
1078
Douglas Gregor9c702202012-02-10 07:45:31 +00001079void CXXRecordDecl::getCaptureFields(
1080 llvm::DenseMap<const VarDecl *, FieldDecl *> &Captures,
Eli Friedman7e7da2d2012-02-11 00:18:00 +00001081 FieldDecl *&ThisCapture) const {
Douglas Gregor9c702202012-02-10 07:45:31 +00001082 Captures.clear();
Craig Topper36250ad2014-05-12 05:36:57 +00001083 ThisCapture = nullptr;
Douglas Gregor9c702202012-02-10 07:45:31 +00001084
Douglas Gregorc8a73492012-02-13 15:44:47 +00001085 LambdaDefinitionData &Lambda = getLambdaData();
Douglas Gregor9c702202012-02-10 07:45:31 +00001086 RecordDecl::field_iterator Field = field_begin();
Benjamin Kramerf3ca26982014-05-10 16:31:55 +00001087 for (const LambdaCapture *C = Lambda.Captures, *CEnd = C + Lambda.NumCaptures;
Douglas Gregor9c702202012-02-10 07:45:31 +00001088 C != CEnd; ++C, ++Field) {
Richard Smithba71c082013-05-16 06:20:58 +00001089 if (C->capturesThis())
David Blaikie40ed2972012-06-06 20:45:41 +00001090 ThisCapture = *Field;
Richard Smithba71c082013-05-16 06:20:58 +00001091 else if (C->capturesVariable())
1092 Captures[C->getCapturedVar()] = *Field;
Douglas Gregor9c702202012-02-10 07:45:31 +00001093 }
Richard Smithbb13c9a2013-09-28 04:02:39 +00001094 assert(Field == field_end());
Douglas Gregor9c702202012-02-10 07:45:31 +00001095}
1096
Faisal Vali2b391ab2013-09-26 19:54:12 +00001097TemplateParameterList *
1098CXXRecordDecl::getGenericLambdaTemplateParameterList() const {
Craig Topper36250ad2014-05-12 05:36:57 +00001099 if (!isLambda()) return nullptr;
Faisal Vali2b391ab2013-09-26 19:54:12 +00001100 CXXMethodDecl *CallOp = getLambdaCallOperator();
1101 if (FunctionTemplateDecl *Tmpl = CallOp->getDescribedFunctionTemplate())
1102 return Tmpl->getTemplateParameters();
Craig Topper36250ad2014-05-12 05:36:57 +00001103 return nullptr;
Faisal Vali2b391ab2013-09-26 19:54:12 +00001104}
Douglas Gregor9c702202012-02-10 07:45:31 +00001105
Richard Smith0bae6242016-08-25 00:34:00 +00001106Decl *CXXRecordDecl::getLambdaContextDecl() const {
1107 assert(isLambda() && "Not a lambda closure type!");
1108 ExternalASTSource *Source = getParentASTContext().getExternalSource();
1109 return getLambdaData().ContextDecl.get(Source);
1110}
1111
John McCall1e3a1a72010-03-15 09:07:48 +00001112static CanQualType GetConversionType(ASTContext &Context, NamedDecl *Conv) {
Alp Tokera2794f92014-01-22 07:29:52 +00001113 QualType T =
1114 cast<CXXConversionDecl>(Conv->getUnderlyingDecl()->getAsFunction())
1115 ->getConversionType();
John McCall1e3a1a72010-03-15 09:07:48 +00001116 return Context.getCanonicalType(T);
Fariborz Jahanian3ee21f12009-10-07 20:43:36 +00001117}
1118
John McCall1e3a1a72010-03-15 09:07:48 +00001119/// Collect the visible conversions of a base class.
1120///
James Dennettb5d5f812012-06-15 22:28:09 +00001121/// \param Record a base class of the class we're considering
John McCall1e3a1a72010-03-15 09:07:48 +00001122/// \param InVirtual whether this base class is a virtual base (or a base
1123/// of a virtual base)
1124/// \param Access the access along the inheritance path to this base
1125/// \param ParentHiddenTypes the conversions provided by the inheritors
1126/// of this base
1127/// \param Output the set to which to add conversions from non-virtual bases
1128/// \param VOutput the set to which to add conversions from virtual bases
1129/// \param HiddenVBaseCs the set of conversions which were hidden in a
1130/// virtual base along some inheritance path
1131static void CollectVisibleConversions(ASTContext &Context,
1132 CXXRecordDecl *Record,
1133 bool InVirtual,
1134 AccessSpecifier Access,
1135 const llvm::SmallPtrSet<CanQualType, 8> &ParentHiddenTypes,
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001136 ASTUnresolvedSet &Output,
John McCall1e3a1a72010-03-15 09:07:48 +00001137 UnresolvedSetImpl &VOutput,
1138 llvm::SmallPtrSet<NamedDecl*, 8> &HiddenVBaseCs) {
1139 // The set of types which have conversions in this class or its
1140 // subclasses. As an optimization, we don't copy the derived set
1141 // unless it might change.
1142 const llvm::SmallPtrSet<CanQualType, 8> *HiddenTypes = &ParentHiddenTypes;
1143 llvm::SmallPtrSet<CanQualType, 8> HiddenTypesBuffer;
1144
1145 // Collect the direct conversions and figure out which conversions
1146 // will be hidden in the subclasses.
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001147 CXXRecordDecl::conversion_iterator ConvI = Record->conversion_begin();
1148 CXXRecordDecl::conversion_iterator ConvE = Record->conversion_end();
1149 if (ConvI != ConvE) {
John McCall1e3a1a72010-03-15 09:07:48 +00001150 HiddenTypesBuffer = ParentHiddenTypes;
1151 HiddenTypes = &HiddenTypesBuffer;
1152
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001153 for (CXXRecordDecl::conversion_iterator I = ConvI; I != ConvE; ++I) {
Richard Smith99fdf8d2012-05-06 00:04:32 +00001154 CanQualType ConvType(GetConversionType(Context, I.getDecl()));
1155 bool Hidden = ParentHiddenTypes.count(ConvType);
1156 if (!Hidden)
1157 HiddenTypesBuffer.insert(ConvType);
John McCall1e3a1a72010-03-15 09:07:48 +00001158
1159 // If this conversion is hidden and we're in a virtual base,
1160 // remember that it's hidden along some inheritance path.
1161 if (Hidden && InVirtual)
1162 HiddenVBaseCs.insert(cast<NamedDecl>(I.getDecl()->getCanonicalDecl()));
1163
1164 // If this conversion isn't hidden, add it to the appropriate output.
1165 else if (!Hidden) {
1166 AccessSpecifier IAccess
1167 = CXXRecordDecl::MergeAccess(Access, I.getAccess());
1168
1169 if (InVirtual)
1170 VOutput.addDecl(I.getDecl(), IAccess);
Fariborz Jahanianb394f502009-09-12 18:26:03 +00001171 else
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001172 Output.addDecl(Context, I.getDecl(), IAccess);
Fariborz Jahanianb54ccb22009-09-11 21:44:33 +00001173 }
1174 }
1175 }
Sebastian Redl1054fae2009-10-25 17:03:50 +00001176
John McCall1e3a1a72010-03-15 09:07:48 +00001177 // Collect information recursively from any base classes.
Aaron Ballman574705e2014-03-13 15:41:46 +00001178 for (const auto &I : Record->bases()) {
1179 const RecordType *RT = I.getType()->getAs<RecordType>();
John McCall1e3a1a72010-03-15 09:07:48 +00001180 if (!RT) continue;
Sebastian Redl1054fae2009-10-25 17:03:50 +00001181
John McCall1e3a1a72010-03-15 09:07:48 +00001182 AccessSpecifier BaseAccess
Aaron Ballman574705e2014-03-13 15:41:46 +00001183 = CXXRecordDecl::MergeAccess(Access, I.getAccessSpecifier());
1184 bool BaseInVirtual = InVirtual || I.isVirtual();
Sebastian Redl1054fae2009-10-25 17:03:50 +00001185
John McCall1e3a1a72010-03-15 09:07:48 +00001186 CXXRecordDecl *Base = cast<CXXRecordDecl>(RT->getDecl());
1187 CollectVisibleConversions(Context, Base, BaseInVirtual, BaseAccess,
1188 *HiddenTypes, Output, VOutput, HiddenVBaseCs);
Fariborz Jahanianb54ccb22009-09-11 21:44:33 +00001189 }
John McCall1e3a1a72010-03-15 09:07:48 +00001190}
Sebastian Redl1054fae2009-10-25 17:03:50 +00001191
John McCall1e3a1a72010-03-15 09:07:48 +00001192/// Collect the visible conversions of a class.
1193///
1194/// This would be extremely straightforward if it weren't for virtual
1195/// bases. It might be worth special-casing that, really.
1196static void CollectVisibleConversions(ASTContext &Context,
1197 CXXRecordDecl *Record,
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001198 ASTUnresolvedSet &Output) {
John McCall1e3a1a72010-03-15 09:07:48 +00001199 // The collection of all conversions in virtual bases that we've
1200 // found. These will be added to the output as long as they don't
1201 // appear in the hidden-conversions set.
1202 UnresolvedSet<8> VBaseCs;
1203
1204 // The set of conversions in virtual bases that we've determined to
1205 // be hidden.
1206 llvm::SmallPtrSet<NamedDecl*, 8> HiddenVBaseCs;
1207
1208 // The set of types hidden by classes derived from this one.
1209 llvm::SmallPtrSet<CanQualType, 8> HiddenTypes;
1210
1211 // Go ahead and collect the direct conversions and add them to the
1212 // hidden-types set.
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001213 CXXRecordDecl::conversion_iterator ConvI = Record->conversion_begin();
1214 CXXRecordDecl::conversion_iterator ConvE = Record->conversion_end();
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001215 Output.append(Context, ConvI, ConvE);
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001216 for (; ConvI != ConvE; ++ConvI)
1217 HiddenTypes.insert(GetConversionType(Context, ConvI.getDecl()));
John McCall1e3a1a72010-03-15 09:07:48 +00001218
1219 // Recursively collect conversions from base classes.
Aaron Ballman574705e2014-03-13 15:41:46 +00001220 for (const auto &I : Record->bases()) {
1221 const RecordType *RT = I.getType()->getAs<RecordType>();
John McCall1e3a1a72010-03-15 09:07:48 +00001222 if (!RT) continue;
1223
1224 CollectVisibleConversions(Context, cast<CXXRecordDecl>(RT->getDecl()),
Aaron Ballman574705e2014-03-13 15:41:46 +00001225 I.isVirtual(), I.getAccessSpecifier(),
John McCall1e3a1a72010-03-15 09:07:48 +00001226 HiddenTypes, Output, VBaseCs, HiddenVBaseCs);
1227 }
1228
1229 // Add any unhidden conversions provided by virtual bases.
1230 for (UnresolvedSetIterator I = VBaseCs.begin(), E = VBaseCs.end();
1231 I != E; ++I) {
1232 if (!HiddenVBaseCs.count(cast<NamedDecl>(I.getDecl()->getCanonicalDecl())))
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001233 Output.addDecl(Context, I.getDecl(), I.getAccess());
Fariborz Jahanianb54ccb22009-09-11 21:44:33 +00001234 }
Fariborz Jahanianb394f502009-09-12 18:26:03 +00001235}
1236
1237/// getVisibleConversionFunctions - get all conversion functions visible
1238/// in current class; including conversion function templates.
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00001239llvm::iterator_range<CXXRecordDecl::conversion_iterator>
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001240CXXRecordDecl::getVisibleConversionFunctions() {
Richard Smitha4ba74c2013-08-30 04:46:40 +00001241 ASTContext &Ctx = getASTContext();
1242
1243 ASTUnresolvedSet *Set;
1244 if (bases_begin() == bases_end()) {
1245 // If root class, all conversions are visible.
1246 Set = &data().Conversions.get(Ctx);
1247 } else {
1248 Set = &data().VisibleConversions.get(Ctx);
1249 // If visible conversion list is not evaluated, evaluate it.
1250 if (!data().ComputedVisibleConversions) {
1251 CollectVisibleConversions(Ctx, this, *Set);
1252 data().ComputedVisibleConversions = true;
1253 }
Argyrios Kyrtzidisa6567c42012-11-28 03:56:09 +00001254 }
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00001255 return llvm::make_range(Set->begin(), Set->end());
Fariborz Jahanianb54ccb22009-09-11 21:44:33 +00001256}
1257
John McCallda4458e2010-03-31 01:36:47 +00001258void CXXRecordDecl::removeConversion(const NamedDecl *ConvDecl) {
1259 // This operation is O(N) but extremely rare. Sema only uses it to
1260 // remove UsingShadowDecls in a class that were followed by a direct
1261 // declaration, e.g.:
1262 // class A : B {
1263 // using B::operator int;
1264 // operator int();
1265 // };
1266 // This is uncommon by itself and even more uncommon in conjunction
1267 // with sufficiently large numbers of directly-declared conversions
1268 // that asymptotic behavior matters.
1269
Richard Smitha4ba74c2013-08-30 04:46:40 +00001270 ASTUnresolvedSet &Convs = data().Conversions.get(getASTContext());
John McCallda4458e2010-03-31 01:36:47 +00001271 for (unsigned I = 0, E = Convs.size(); I != E; ++I) {
1272 if (Convs[I].getDecl() == ConvDecl) {
1273 Convs.erase(I);
1274 assert(std::find(Convs.begin(), Convs.end(), ConvDecl) == Convs.end()
1275 && "conversion was found multiple times in unresolved set");
1276 return;
1277 }
1278 }
1279
1280 llvm_unreachable("conversion not found in set!");
Douglas Gregor05155d82009-08-21 23:19:43 +00001281}
Fariborz Jahanian423a81f2009-06-19 19:55:27 +00001282
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001283CXXRecordDecl *CXXRecordDecl::getInstantiatedFromMemberClass() const {
Douglas Gregor06db9f52009-10-12 20:18:28 +00001284 if (MemberSpecializationInfo *MSInfo = getMemberSpecializationInfo())
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001285 return cast<CXXRecordDecl>(MSInfo->getInstantiatedFrom());
Craig Topper36250ad2014-05-12 05:36:57 +00001286
1287 return nullptr;
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001288}
1289
Chandler Carruth21c90602015-12-30 03:24:14 +00001290MemberSpecializationInfo *CXXRecordDecl::getMemberSpecializationInfo() const {
1291 return TemplateOrInstantiation.dyn_cast<MemberSpecializationInfo *>();
1292}
1293
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001294void
1295CXXRecordDecl::setInstantiationOfMemberClass(CXXRecordDecl *RD,
1296 TemplateSpecializationKind TSK) {
1297 assert(TemplateOrInstantiation.isNull() &&
1298 "Previous template or instantiation?");
Richard Smith8a0dde72013-12-14 01:04:22 +00001299 assert(!isa<ClassTemplatePartialSpecializationDecl>(this));
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001300 TemplateOrInstantiation
1301 = new (getASTContext()) MemberSpecializationInfo(RD, TSK);
1302}
1303
Chandler Carruth21c90602015-12-30 03:24:14 +00001304ClassTemplateDecl *CXXRecordDecl::getDescribedClassTemplate() const {
1305 return TemplateOrInstantiation.dyn_cast<ClassTemplateDecl *>();
1306}
1307
1308void CXXRecordDecl::setDescribedClassTemplate(ClassTemplateDecl *Template) {
1309 TemplateOrInstantiation = Template;
1310}
1311
Anders Carlsson27cfc6e2009-12-07 06:33:48 +00001312TemplateSpecializationKind CXXRecordDecl::getTemplateSpecializationKind() const{
1313 if (const ClassTemplateSpecializationDecl *Spec
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001314 = dyn_cast<ClassTemplateSpecializationDecl>(this))
1315 return Spec->getSpecializationKind();
1316
Douglas Gregor06db9f52009-10-12 20:18:28 +00001317 if (MemberSpecializationInfo *MSInfo = getMemberSpecializationInfo())
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001318 return MSInfo->getTemplateSpecializationKind();
1319
1320 return TSK_Undeclared;
1321}
1322
1323void
1324CXXRecordDecl::setTemplateSpecializationKind(TemplateSpecializationKind TSK) {
1325 if (ClassTemplateSpecializationDecl *Spec
1326 = dyn_cast<ClassTemplateSpecializationDecl>(this)) {
1327 Spec->setSpecializationKind(TSK);
1328 return;
1329 }
1330
Douglas Gregor06db9f52009-10-12 20:18:28 +00001331 if (MemberSpecializationInfo *MSInfo = getMemberSpecializationInfo()) {
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001332 MSInfo->setTemplateSpecializationKind(TSK);
1333 return;
1334 }
1335
David Blaikie83d382b2011-09-23 05:06:16 +00001336 llvm_unreachable("Not a class template or member class specialization");
Douglas Gregorbbe8f462009-10-08 15:14:33 +00001337}
1338
Reid Klecknere7367d62014-10-14 20:28:40 +00001339const CXXRecordDecl *CXXRecordDecl::getTemplateInstantiationPattern() const {
1340 // If it's a class template specialization, find the template or partial
1341 // specialization from which it was instantiated.
1342 if (auto *TD = dyn_cast<ClassTemplateSpecializationDecl>(this)) {
1343 auto From = TD->getInstantiatedFrom();
1344 if (auto *CTD = From.dyn_cast<ClassTemplateDecl *>()) {
1345 while (auto *NewCTD = CTD->getInstantiatedFromMemberTemplate()) {
1346 if (NewCTD->isMemberSpecialization())
1347 break;
1348 CTD = NewCTD;
1349 }
Richard Smith7a591a42015-07-08 02:22:15 +00001350 return CTD->getTemplatedDecl()->getDefinition();
Reid Klecknere7367d62014-10-14 20:28:40 +00001351 }
1352 if (auto *CTPSD =
1353 From.dyn_cast<ClassTemplatePartialSpecializationDecl *>()) {
1354 while (auto *NewCTPSD = CTPSD->getInstantiatedFromMember()) {
1355 if (NewCTPSD->isMemberSpecialization())
1356 break;
1357 CTPSD = NewCTPSD;
1358 }
Richard Smith7a591a42015-07-08 02:22:15 +00001359 return CTPSD->getDefinition();
Reid Klecknere7367d62014-10-14 20:28:40 +00001360 }
1361 }
1362
1363 if (MemberSpecializationInfo *MSInfo = getMemberSpecializationInfo()) {
1364 if (isTemplateInstantiation(MSInfo->getTemplateSpecializationKind())) {
1365 const CXXRecordDecl *RD = this;
1366 while (auto *NewRD = RD->getInstantiatedFromMemberClass())
1367 RD = NewRD;
Richard Smith7a591a42015-07-08 02:22:15 +00001368 return RD->getDefinition();
Reid Klecknere7367d62014-10-14 20:28:40 +00001369 }
1370 }
1371
1372 assert(!isTemplateInstantiation(this->getTemplateSpecializationKind()) &&
1373 "couldn't find pattern for class template instantiation");
1374 return nullptr;
1375}
1376
Douglas Gregorbac74902010-07-01 14:13:13 +00001377CXXDestructorDecl *CXXRecordDecl::getDestructor() const {
1378 ASTContext &Context = getASTContext();
Anders Carlsson0a637412009-05-29 21:03:38 +00001379 QualType ClassType = Context.getTypeDeclType(this);
Mike Stump11289f42009-09-09 15:08:12 +00001380
1381 DeclarationName Name
Douglas Gregor2211d342009-08-05 05:36:45 +00001382 = Context.DeclarationNames.getCXXDestructorName(
1383 Context.getCanonicalType(ClassType));
Anders Carlsson0a637412009-05-29 21:03:38 +00001384
Richard Smithcf4bdde2015-02-21 02:45:19 +00001385 DeclContext::lookup_result R = lookup(Name);
David Blaikieff7d47a2012-12-19 00:45:41 +00001386 if (R.empty())
Craig Topper36250ad2014-05-12 05:36:57 +00001387 return nullptr;
Mike Stump11289f42009-09-09 15:08:12 +00001388
David Blaikieff7d47a2012-12-19 00:45:41 +00001389 CXXDestructorDecl *Dtor = cast<CXXDestructorDecl>(R.front());
Anders Carlsson0a637412009-05-29 21:03:38 +00001390 return Dtor;
1391}
1392
Richard Trieu95a192a2015-05-28 00:14:02 +00001393bool CXXRecordDecl::isAnyDestructorNoReturn() const {
1394 // Destructor is noreturn.
1395 if (const CXXDestructorDecl *Destructor = getDestructor())
1396 if (Destructor->isNoReturn())
1397 return true;
1398
1399 // Check base classes destructor for noreturn.
1400 for (const auto &Base : bases())
1401 if (Base.getType()->getAsCXXRecordDecl()->isAnyDestructorNoReturn())
1402 return true;
1403
1404 // Check fields for noreturn.
1405 for (const auto *Field : fields())
1406 if (const CXXRecordDecl *RD =
1407 Field->getType()->getBaseElementTypeUnsafe()->getAsCXXRecordDecl())
1408 if (RD->isAnyDestructorNoReturn())
1409 return true;
1410
1411 // All destructors are not noreturn.
1412 return false;
1413}
1414
Douglas Gregorb11aad82011-02-19 18:51:44 +00001415void CXXRecordDecl::completeDefinition() {
Craig Topper36250ad2014-05-12 05:36:57 +00001416 completeDefinition(nullptr);
Douglas Gregorb11aad82011-02-19 18:51:44 +00001417}
1418
1419void CXXRecordDecl::completeDefinition(CXXFinalOverriderMap *FinalOverriders) {
1420 RecordDecl::completeDefinition();
1421
Douglas Gregor8fb95122010-09-29 00:15:42 +00001422 // If the class may be abstract (but hasn't been marked as such), check for
1423 // any pure final overriders.
1424 if (mayBeAbstract()) {
1425 CXXFinalOverriderMap MyFinalOverriders;
1426 if (!FinalOverriders) {
1427 getFinalOverriders(MyFinalOverriders);
1428 FinalOverriders = &MyFinalOverriders;
1429 }
1430
1431 bool Done = false;
1432 for (CXXFinalOverriderMap::iterator M = FinalOverriders->begin(),
1433 MEnd = FinalOverriders->end();
1434 M != MEnd && !Done; ++M) {
1435 for (OverridingMethods::iterator SO = M->second.begin(),
1436 SOEnd = M->second.end();
1437 SO != SOEnd && !Done; ++SO) {
1438 assert(SO->second.size() > 0 &&
1439 "All virtual functions have overridding virtual functions");
1440
1441 // C++ [class.abstract]p4:
1442 // A class is abstract if it contains or inherits at least one
1443 // pure virtual function for which the final overrider is pure
1444 // virtual.
1445 if (SO->second.front().Method->isPure()) {
1446 data().Abstract = true;
1447 Done = true;
1448 break;
1449 }
1450 }
1451 }
1452 }
Douglas Gregor457104e2010-09-29 04:25:11 +00001453
1454 // Set access bits correctly on the directly-declared conversions.
Richard Smitha4ba74c2013-08-30 04:46:40 +00001455 for (conversion_iterator I = conversion_begin(), E = conversion_end();
Douglas Gregor457104e2010-09-29 04:25:11 +00001456 I != E; ++I)
Argyrios Kyrtzidis0f05fb92012-11-28 03:56:16 +00001457 I.setAccess((*I)->getAccess());
Douglas Gregor8fb95122010-09-29 00:15:42 +00001458}
1459
1460bool CXXRecordDecl::mayBeAbstract() const {
1461 if (data().Abstract || isInvalidDecl() || !data().Polymorphic ||
1462 isDependentContext())
1463 return false;
1464
Aaron Ballman574705e2014-03-13 15:41:46 +00001465 for (const auto &B : bases()) {
Douglas Gregor8fb95122010-09-29 00:15:42 +00001466 CXXRecordDecl *BaseDecl
Aaron Ballman574705e2014-03-13 15:41:46 +00001467 = cast<CXXRecordDecl>(B.getType()->getAs<RecordType>()->getDecl());
Douglas Gregor8fb95122010-09-29 00:15:42 +00001468 if (BaseDecl->isAbstract())
1469 return true;
1470 }
1471
1472 return false;
1473}
1474
Richard Smithbc491202017-02-17 20:05:37 +00001475void CXXDeductionGuideDecl::anchor() { }
1476
1477CXXDeductionGuideDecl *CXXDeductionGuideDecl::Create(
1478 ASTContext &C, DeclContext *DC, SourceLocation StartLoc, bool IsExplicit,
1479 const DeclarationNameInfo &NameInfo, QualType T, TypeSourceInfo *TInfo,
1480 SourceLocation EndLocation) {
1481 return new (C, DC) CXXDeductionGuideDecl(C, DC, StartLoc, IsExplicit,
1482 NameInfo, T, TInfo, EndLocation);
1483}
1484
1485CXXDeductionGuideDecl *CXXDeductionGuideDecl::CreateDeserialized(ASTContext &C,
1486 unsigned ID) {
1487 return new (C, ID) CXXDeductionGuideDecl(C, nullptr, SourceLocation(), false,
1488 DeclarationNameInfo(), QualType(),
1489 nullptr, SourceLocation());
1490}
1491
David Blaikie68e081d2011-12-20 02:48:34 +00001492void CXXMethodDecl::anchor() { }
1493
Rafael Espindola6ae7e502013-04-03 19:27:57 +00001494bool CXXMethodDecl::isStatic() const {
Rafael Espindola29cda592013-04-15 12:38:20 +00001495 const CXXMethodDecl *MD = getCanonicalDecl();
Rafael Espindola6ae7e502013-04-03 19:27:57 +00001496
1497 if (MD->getStorageClass() == SC_Static)
1498 return true;
1499
Reid Kleckner9a7f3e62013-10-08 00:58:57 +00001500 OverloadedOperatorKind OOK = getDeclName().getCXXOverloadedOperator();
1501 return isStaticOverloadedOperator(OOK);
Rafael Espindola6ae7e502013-04-03 19:27:57 +00001502}
1503
Rafael Espindola49e860b2012-06-26 17:45:31 +00001504static bool recursivelyOverrides(const CXXMethodDecl *DerivedMD,
1505 const CXXMethodDecl *BaseMD) {
1506 for (CXXMethodDecl::method_iterator I = DerivedMD->begin_overridden_methods(),
1507 E = DerivedMD->end_overridden_methods(); I != E; ++I) {
1508 const CXXMethodDecl *MD = *I;
1509 if (MD->getCanonicalDecl() == BaseMD->getCanonicalDecl())
1510 return true;
1511 if (recursivelyOverrides(MD, BaseMD))
1512 return true;
1513 }
1514 return false;
1515}
1516
1517CXXMethodDecl *
Jordan Rose5fc5da02012-08-15 20:07:17 +00001518CXXMethodDecl::getCorrespondingMethodInClass(const CXXRecordDecl *RD,
1519 bool MayBeBase) {
Rafael Espindola49e860b2012-06-26 17:45:31 +00001520 if (this->getParent()->getCanonicalDecl() == RD->getCanonicalDecl())
1521 return this;
1522
1523 // Lookup doesn't work for destructors, so handle them separately.
1524 if (isa<CXXDestructorDecl>(this)) {
1525 CXXMethodDecl *MD = RD->getDestructor();
Jordan Rose5fc5da02012-08-15 20:07:17 +00001526 if (MD) {
1527 if (recursivelyOverrides(MD, this))
1528 return MD;
1529 if (MayBeBase && recursivelyOverrides(this, MD))
1530 return MD;
1531 }
Craig Topper36250ad2014-05-12 05:36:57 +00001532 return nullptr;
Rafael Espindola49e860b2012-06-26 17:45:31 +00001533 }
1534
Richard Smith40c78062015-02-21 02:31:57 +00001535 for (auto *ND : RD->lookup(getDeclName())) {
1536 CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(ND);
Rafael Espindola49e860b2012-06-26 17:45:31 +00001537 if (!MD)
1538 continue;
1539 if (recursivelyOverrides(MD, this))
1540 return MD;
Jordan Rose5fc5da02012-08-15 20:07:17 +00001541 if (MayBeBase && recursivelyOverrides(this, MD))
1542 return MD;
Rafael Espindola49e860b2012-06-26 17:45:31 +00001543 }
1544
Aaron Ballman574705e2014-03-13 15:41:46 +00001545 for (const auto &I : RD->bases()) {
1546 const RecordType *RT = I.getType()->getAs<RecordType>();
Rafael Espindola49e860b2012-06-26 17:45:31 +00001547 if (!RT)
1548 continue;
1549 const CXXRecordDecl *Base = cast<CXXRecordDecl>(RT->getDecl());
1550 CXXMethodDecl *T = this->getCorrespondingMethodInClass(Base);
1551 if (T)
1552 return T;
1553 }
1554
Craig Topper36250ad2014-05-12 05:36:57 +00001555 return nullptr;
Rafael Espindola49e860b2012-06-26 17:45:31 +00001556}
1557
Ted Kremenek21475702008-09-05 17:16:31 +00001558CXXMethodDecl *
1559CXXMethodDecl::Create(ASTContext &C, CXXRecordDecl *RD,
Abramo Bagnaradff19302011-03-08 08:55:46 +00001560 SourceLocation StartLoc,
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001561 const DeclarationNameInfo &NameInfo,
John McCallbcd03502009-12-07 02:54:59 +00001562 QualType T, TypeSourceInfo *TInfo,
Rafael Espindola6ae7e502013-04-03 19:27:57 +00001563 StorageClass SC, bool isInline,
Richard Smitha77a0a62011-08-15 21:04:07 +00001564 bool isConstexpr, SourceLocation EndLocation) {
Richard Smith053f6c62014-05-16 23:01:30 +00001565 return new (C, RD) CXXMethodDecl(CXXMethod, C, RD, StartLoc, NameInfo,
1566 T, TInfo, SC, isInline, isConstexpr,
1567 EndLocation);
Ted Kremenek21475702008-09-05 17:16:31 +00001568}
1569
Douglas Gregor72172e92012-01-05 21:55:30 +00001570CXXMethodDecl *CXXMethodDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith053f6c62014-05-16 23:01:30 +00001571 return new (C, ID) CXXMethodDecl(CXXMethod, C, nullptr, SourceLocation(),
Craig Topper36250ad2014-05-12 05:36:57 +00001572 DeclarationNameInfo(), QualType(), nullptr,
Richard Smithf7981722013-11-22 09:01:48 +00001573 SC_None, false, false, SourceLocation());
Douglas Gregor72172e92012-01-05 21:55:30 +00001574}
1575
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001576bool CXXMethodDecl::isUsualDeallocationFunction() const {
1577 if (getOverloadedOperator() != OO_Delete &&
1578 getOverloadedOperator() != OO_Array_Delete)
1579 return false;
Douglas Gregor6642ca22010-02-26 05:06:18 +00001580
1581 // C++ [basic.stc.dynamic.deallocation]p2:
1582 // A template instance is never a usual deallocation function,
1583 // regardless of its signature.
1584 if (getPrimaryTemplate())
1585 return false;
1586
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001587 // C++ [basic.stc.dynamic.deallocation]p2:
1588 // If a class T has a member deallocation function named operator delete
1589 // with exactly one parameter, then that function is a usual (non-placement)
1590 // deallocation function. [...]
1591 if (getNumParams() == 1)
1592 return true;
Richard Smithb2f0f052016-10-10 18:54:32 +00001593 unsigned UsualParams = 1;
Richard Smith96269c52016-09-29 22:49:46 +00001594
Richard Smithb2f0f052016-10-10 18:54:32 +00001595 // C++ <=14 [basic.stc.dynamic.deallocation]p2:
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001596 // [...] If class T does not declare such an operator delete but does
1597 // declare a member deallocation function named operator delete with
1598 // exactly two parameters, the second of which has type std::size_t (18.1),
1599 // then this function is a usual deallocation function.
Richard Smithb2f0f052016-10-10 18:54:32 +00001600 //
1601 // C++17 says a usual deallocation function is one with the signature
1602 // (void* [, size_t] [, std::align_val_t] [, ...])
1603 // and all such functions are usual deallocation functions. It's not clear
1604 // that allowing varargs functions was intentional.
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001605 ASTContext &Context = getASTContext();
Richard Smithb2f0f052016-10-10 18:54:32 +00001606 if (UsualParams < getNumParams() &&
1607 Context.hasSameUnqualifiedType(getParamDecl(UsualParams)->getType(),
1608 Context.getSizeType()))
1609 ++UsualParams;
1610
1611 if (UsualParams < getNumParams() &&
1612 getParamDecl(UsualParams)->getType()->isAlignValT())
1613 ++UsualParams;
1614
1615 if (UsualParams != getNumParams())
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001616 return false;
Richard Smithb2f0f052016-10-10 18:54:32 +00001617
1618 // In C++17 onwards, all potential usual deallocation functions are actual
1619 // usual deallocation functions.
1620 if (Context.getLangOpts().AlignedAllocation)
1621 return true;
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001622
1623 // This function is a usual deallocation function if there are no
1624 // single-parameter deallocation functions of the same kind.
Richard Smithcf4bdde2015-02-21 02:45:19 +00001625 DeclContext::lookup_result R = getDeclContext()->lookup(getDeclName());
1626 for (DeclContext::lookup_result::iterator I = R.begin(), E = R.end();
David Blaikieff7d47a2012-12-19 00:45:41 +00001627 I != E; ++I) {
1628 if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(*I))
Douglas Gregorbb3e12f2009-09-29 18:16:17 +00001629 if (FD->getNumParams() == 1)
1630 return false;
1631 }
1632
1633 return true;
1634}
1635
Douglas Gregorb139cd52010-05-01 20:49:11 +00001636bool CXXMethodDecl::isCopyAssignmentOperator() const {
Alexis Huntfcaeae42011-05-25 20:50:04 +00001637 // C++0x [class.copy]p17:
Douglas Gregorb139cd52010-05-01 20:49:11 +00001638 // A user-declared copy assignment operator X::operator= is a non-static
1639 // non-template member function of class X with exactly one parameter of
1640 // type X, X&, const X&, volatile X& or const volatile X&.
1641 if (/*operator=*/getOverloadedOperator() != OO_Equal ||
1642 /*non-static*/ isStatic() ||
Eli Friedman84c0143e2013-07-11 23:55:07 +00001643 /*non-template*/getPrimaryTemplate() || getDescribedFunctionTemplate() ||
1644 getNumParams() != 1)
Douglas Gregorb139cd52010-05-01 20:49:11 +00001645 return false;
1646
1647 QualType ParamType = getParamDecl(0)->getType();
1648 if (const LValueReferenceType *Ref = ParamType->getAs<LValueReferenceType>())
1649 ParamType = Ref->getPointeeType();
1650
1651 ASTContext &Context = getASTContext();
1652 QualType ClassType
1653 = Context.getCanonicalType(Context.getTypeDeclType(getParent()));
1654 return Context.hasSameUnqualifiedType(ClassType, ParamType);
1655}
1656
Alexis Huntfcaeae42011-05-25 20:50:04 +00001657bool CXXMethodDecl::isMoveAssignmentOperator() const {
1658 // C++0x [class.copy]p19:
1659 // A user-declared move assignment operator X::operator= is a non-static
1660 // non-template member function of class X with exactly one parameter of type
1661 // X&&, const X&&, volatile X&&, or const volatile X&&.
1662 if (getOverloadedOperator() != OO_Equal || isStatic() ||
Eli Friedman84c0143e2013-07-11 23:55:07 +00001663 getPrimaryTemplate() || getDescribedFunctionTemplate() ||
1664 getNumParams() != 1)
Alexis Huntfcaeae42011-05-25 20:50:04 +00001665 return false;
1666
1667 QualType ParamType = getParamDecl(0)->getType();
1668 if (!isa<RValueReferenceType>(ParamType))
1669 return false;
1670 ParamType = ParamType->getPointeeType();
1671
1672 ASTContext &Context = getASTContext();
1673 QualType ClassType
1674 = Context.getCanonicalType(Context.getTypeDeclType(getParent()));
1675 return Context.hasSameUnqualifiedType(ClassType, ParamType);
1676}
1677
Anders Carlsson36d87e12009-05-16 23:58:37 +00001678void CXXMethodDecl::addOverriddenMethod(const CXXMethodDecl *MD) {
Anders Carlssonf3935b42009-12-04 05:51:56 +00001679 assert(MD->isCanonicalDecl() && "Method is not canonical!");
Anders Carlssonbd32c432010-01-30 17:42:34 +00001680 assert(!MD->getParent()->isDependentContext() &&
1681 "Can't add an overridden method to a class template!");
Eli Friedman91359022012-03-10 01:39:01 +00001682 assert(MD->isVirtual() && "Method is not virtual!");
Anders Carlssonbd32c432010-01-30 17:42:34 +00001683
Douglas Gregor832940b2010-03-02 23:58:15 +00001684 getASTContext().addOverriddenMethod(this, MD);
Anders Carlsson36d87e12009-05-16 23:58:37 +00001685}
1686
1687CXXMethodDecl::method_iterator CXXMethodDecl::begin_overridden_methods() const {
Craig Topper36250ad2014-05-12 05:36:57 +00001688 if (isa<CXXConstructorDecl>(this)) return nullptr;
Douglas Gregor832940b2010-03-02 23:58:15 +00001689 return getASTContext().overridden_methods_begin(this);
Anders Carlsson36d87e12009-05-16 23:58:37 +00001690}
1691
1692CXXMethodDecl::method_iterator CXXMethodDecl::end_overridden_methods() const {
Craig Topper36250ad2014-05-12 05:36:57 +00001693 if (isa<CXXConstructorDecl>(this)) return nullptr;
Douglas Gregor832940b2010-03-02 23:58:15 +00001694 return getASTContext().overridden_methods_end(this);
Anders Carlsson36d87e12009-05-16 23:58:37 +00001695}
1696
Argyrios Kyrtzidis6685e8a2010-07-04 21:44:35 +00001697unsigned CXXMethodDecl::size_overridden_methods() const {
Eli Friedman91359022012-03-10 01:39:01 +00001698 if (isa<CXXConstructorDecl>(this)) return 0;
Argyrios Kyrtzidis6685e8a2010-07-04 21:44:35 +00001699 return getASTContext().overridden_methods_size(this);
1700}
1701
Clement Courbet6ecaec82016-07-05 07:49:31 +00001702CXXMethodDecl::overridden_method_range
1703CXXMethodDecl::overridden_methods() const {
1704 if (isa<CXXConstructorDecl>(this))
1705 return overridden_method_range(nullptr, nullptr);
1706 return getASTContext().overridden_methods(this);
1707}
1708
Ted Kremenek21475702008-09-05 17:16:31 +00001709QualType CXXMethodDecl::getThisType(ASTContext &C) const {
Argyrios Kyrtzidis962c20e2008-10-24 22:28:18 +00001710 // C++ 9.3.2p1: The type of this in a member function of a class X is X*.
1711 // If the member function is declared const, the type of this is const X*,
1712 // if the member function is declared volatile, the type of this is
1713 // volatile X*, and if the member function is declared const volatile,
1714 // the type of this is const volatile X*.
1715
Ted Kremenek21475702008-09-05 17:16:31 +00001716 assert(isInstance() && "No 'this' for static methods!");
Anders Carlsson20ee0ed2009-06-13 02:59:33 +00001717
John McCalle78aac42010-03-10 03:28:59 +00001718 QualType ClassTy = C.getTypeDeclType(getParent());
John McCall8ccfcb52009-09-24 19:53:00 +00001719 ClassTy = C.getQualifiedType(ClassTy,
Andrey Bokhanko67a41862016-05-26 10:06:01 +00001720 Qualifiers::fromCVRUMask(getTypeQualifiers()));
Anders Carlsson7ca3f6f2009-07-10 21:35:09 +00001721 return C.getPointerType(ClassTy);
Ted Kremenek21475702008-09-05 17:16:31 +00001722}
1723
Eli Friedman71a26d82009-12-06 20:50:05 +00001724bool CXXMethodDecl::hasInlineBody() const {
Douglas Gregora318efd2010-01-05 19:06:31 +00001725 // If this function is a template instantiation, look at the template from
1726 // which it was instantiated.
1727 const FunctionDecl *CheckFn = getTemplateInstantiationPattern();
1728 if (!CheckFn)
1729 CheckFn = this;
1730
Eli Friedman71a26d82009-12-06 20:50:05 +00001731 const FunctionDecl *fn;
Argyrios Kyrtzidis36ea3222010-07-07 11:31:19 +00001732 return CheckFn->hasBody(fn) && !fn->isOutOfLine();
Eli Friedman71a26d82009-12-06 20:50:05 +00001733}
1734
Douglas Gregor355efbb2012-02-17 03:02:34 +00001735bool CXXMethodDecl::isLambdaStaticInvoker() const {
Faisal Vali571df122013-09-29 08:45:24 +00001736 const CXXRecordDecl *P = getParent();
1737 if (P->isLambda()) {
1738 if (const CXXMethodDecl *StaticInvoker = P->getLambdaStaticInvoker()) {
1739 if (StaticInvoker == this) return true;
1740 if (P->isGenericLambda() && this->isFunctionTemplateSpecialization())
1741 return StaticInvoker == this->getPrimaryTemplate()->getTemplatedDecl();
1742 }
1743 }
1744 return false;
Douglas Gregor355efbb2012-02-17 03:02:34 +00001745}
1746
Alexis Hunt1d792652011-01-08 20:30:50 +00001747CXXCtorInitializer::CXXCtorInitializer(ASTContext &Context,
1748 TypeSourceInfo *TInfo, bool IsVirtual,
1749 SourceLocation L, Expr *Init,
1750 SourceLocation R,
1751 SourceLocation EllipsisLoc)
Alexis Hunta50dd462011-01-08 23:01:16 +00001752 : Initializee(TInfo), MemberOrEllipsisLocation(EllipsisLoc), Init(Init),
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001753 LParenLoc(L), RParenLoc(R), IsDelegating(false), IsVirtual(IsVirtual),
Richard Smith30e304e2016-12-14 00:03:17 +00001754 IsWritten(false), SourceOrder(0)
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001755{
Douglas Gregore8381c02008-11-05 04:29:56 +00001756}
1757
Alexis Hunt1d792652011-01-08 20:30:50 +00001758CXXCtorInitializer::CXXCtorInitializer(ASTContext &Context,
1759 FieldDecl *Member,
1760 SourceLocation MemberLoc,
1761 SourceLocation L, Expr *Init,
1762 SourceLocation R)
Alexis Hunta50dd462011-01-08 23:01:16 +00001763 : Initializee(Member), MemberOrEllipsisLocation(MemberLoc), Init(Init),
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001764 LParenLoc(L), RParenLoc(R), IsDelegating(false), IsVirtual(false),
Richard Smith30e304e2016-12-14 00:03:17 +00001765 IsWritten(false), SourceOrder(0)
Francois Pichetd583da02010-12-04 09:14:42 +00001766{
1767}
1768
Alexis Hunt1d792652011-01-08 20:30:50 +00001769CXXCtorInitializer::CXXCtorInitializer(ASTContext &Context,
1770 IndirectFieldDecl *Member,
1771 SourceLocation MemberLoc,
1772 SourceLocation L, Expr *Init,
1773 SourceLocation R)
Alexis Hunta50dd462011-01-08 23:01:16 +00001774 : Initializee(Member), MemberOrEllipsisLocation(MemberLoc), Init(Init),
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001775 LParenLoc(L), RParenLoc(R), IsDelegating(false), IsVirtual(false),
Richard Smith30e304e2016-12-14 00:03:17 +00001776 IsWritten(false), SourceOrder(0)
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001777{
Douglas Gregore8381c02008-11-05 04:29:56 +00001778}
1779
Alexis Hunt1d792652011-01-08 20:30:50 +00001780CXXCtorInitializer::CXXCtorInitializer(ASTContext &Context,
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001781 TypeSourceInfo *TInfo,
1782 SourceLocation L, Expr *Init,
Alexis Huntc5575cc2011-02-26 19:13:13 +00001783 SourceLocation R)
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001784 : Initializee(TInfo), MemberOrEllipsisLocation(), Init(Init),
1785 LParenLoc(L), RParenLoc(R), IsDelegating(true), IsVirtual(false),
Richard Smith30e304e2016-12-14 00:03:17 +00001786 IsWritten(false), SourceOrder(0)
Alexis Huntc5575cc2011-02-26 19:13:13 +00001787{
1788}
1789
Alexis Hunt1d792652011-01-08 20:30:50 +00001790TypeLoc CXXCtorInitializer::getBaseClassLoc() const {
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001791 if (isBaseInitializer())
Alexis Hunta50dd462011-01-08 23:01:16 +00001792 return Initializee.get<TypeSourceInfo*>()->getTypeLoc();
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001793 else
1794 return TypeLoc();
1795}
1796
Alexis Hunt1d792652011-01-08 20:30:50 +00001797const Type *CXXCtorInitializer::getBaseClass() const {
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001798 if (isBaseInitializer())
Alexis Hunta50dd462011-01-08 23:01:16 +00001799 return Initializee.get<TypeSourceInfo*>()->getType().getTypePtr();
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001800 else
Craig Topper36250ad2014-05-12 05:36:57 +00001801 return nullptr;
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001802}
1803
Alexis Hunt1d792652011-01-08 20:30:50 +00001804SourceLocation CXXCtorInitializer::getSourceLocation() const {
Richard Smith938f40b2011-06-11 17:19:42 +00001805 if (isInClassMemberInitializer())
1806 return getAnyMember()->getLocation();
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001807
David Blaikiea81d4102015-01-18 00:12:58 +00001808 if (isAnyMemberInitializer())
1809 return getMemberLocation();
1810
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001811 if (TypeSourceInfo *TSInfo = Initializee.get<TypeSourceInfo*>())
1812 return TSInfo->getTypeLoc().getLocalSourceRange().getBegin();
1813
1814 return SourceLocation();
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001815}
1816
Alexis Hunt1d792652011-01-08 20:30:50 +00001817SourceRange CXXCtorInitializer::getSourceRange() const {
Richard Smith938f40b2011-06-11 17:19:42 +00001818 if (isInClassMemberInitializer()) {
1819 FieldDecl *D = getAnyMember();
1820 if (Expr *I = D->getInClassInitializer())
1821 return I->getSourceRange();
1822 return SourceRange();
1823 }
1824
Douglas Gregorc8c44b5d2009-12-02 22:36:29 +00001825 return SourceRange(getSourceLocation(), getRParenLoc());
Douglas Gregore8381c02008-11-05 04:29:56 +00001826}
1827
David Blaikie68e081d2011-12-20 02:48:34 +00001828void CXXConstructorDecl::anchor() { }
1829
Richard Smith5179eb72016-06-28 19:03:57 +00001830CXXConstructorDecl *CXXConstructorDecl::CreateDeserialized(ASTContext &C,
1831 unsigned ID,
1832 bool Inherited) {
1833 unsigned Extra = additionalSizeToAlloc<InheritedConstructor>(Inherited);
1834 auto *Result = new (C, ID, Extra) CXXConstructorDecl(
1835 C, nullptr, SourceLocation(), DeclarationNameInfo(), QualType(), nullptr,
1836 false, false, false, false, InheritedConstructor());
1837 Result->IsInheritingConstructor = Inherited;
1838 return Result;
Chris Lattnerca025db2010-05-07 21:43:38 +00001839}
1840
1841CXXConstructorDecl *
Douglas Gregor61956c42008-10-31 09:07:45 +00001842CXXConstructorDecl::Create(ASTContext &C, CXXRecordDecl *RD,
Abramo Bagnaradff19302011-03-08 08:55:46 +00001843 SourceLocation StartLoc,
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001844 const DeclarationNameInfo &NameInfo,
John McCallbcd03502009-12-07 02:54:59 +00001845 QualType T, TypeSourceInfo *TInfo,
Richard Smitha77a0a62011-08-15 21:04:07 +00001846 bool isExplicit, bool isInline,
Richard Smith5179eb72016-06-28 19:03:57 +00001847 bool isImplicitlyDeclared, bool isConstexpr,
1848 InheritedConstructor Inherited) {
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001849 assert(NameInfo.getName().getNameKind()
1850 == DeclarationName::CXXConstructorName &&
Douglas Gregor77324f32008-11-17 14:58:09 +00001851 "Name must refer to a constructor");
Richard Smith5179eb72016-06-28 19:03:57 +00001852 unsigned Extra =
1853 additionalSizeToAlloc<InheritedConstructor>(Inherited ? 1 : 0);
1854 return new (C, RD, Extra) CXXConstructorDecl(
1855 C, RD, StartLoc, NameInfo, T, TInfo, isExplicit, isInline,
1856 isImplicitlyDeclared, isConstexpr, Inherited);
Douglas Gregor61956c42008-10-31 09:07:45 +00001857}
1858
Richard Smithc2bb8182015-03-24 06:36:48 +00001859CXXConstructorDecl::init_const_iterator CXXConstructorDecl::init_begin() const {
1860 return CtorInitializers.get(getASTContext().getExternalSource());
1861}
1862
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001863CXXConstructorDecl *CXXConstructorDecl::getTargetConstructor() const {
1864 assert(isDelegatingConstructor() && "Not a delegating constructor!");
1865 Expr *E = (*init_begin())->getInit()->IgnoreImplicit();
1866 if (CXXConstructExpr *Construct = dyn_cast<CXXConstructExpr>(E))
1867 return Construct->getConstructor();
Craig Topper36250ad2014-05-12 05:36:57 +00001868
1869 return nullptr;
Douglas Gregord73f3dd2011-11-01 01:16:03 +00001870}
1871
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001872bool CXXConstructorDecl::isDefaultConstructor() const {
1873 // C++ [class.ctor]p5:
Douglas Gregorcfd8ddc2008-11-05 16:20:31 +00001874 // A default constructor for a class X is a constructor of class
1875 // X that can be called without an argument.
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001876 return (getNumParams() == 0) ||
Anders Carlsson6eb55572009-08-25 05:12:04 +00001877 (getNumParams() > 0 && getParamDecl(0)->hasDefaultArg());
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001878}
1879
Mike Stump11289f42009-09-09 15:08:12 +00001880bool
Douglas Gregor507eb872009-12-22 00:34:07 +00001881CXXConstructorDecl::isCopyConstructor(unsigned &TypeQuals) const {
Douglas Gregorf282a762011-01-21 19:38:21 +00001882 return isCopyOrMoveConstructor(TypeQuals) &&
1883 getParamDecl(0)->getType()->isLValueReferenceType();
1884}
1885
1886bool CXXConstructorDecl::isMoveConstructor(unsigned &TypeQuals) const {
1887 return isCopyOrMoveConstructor(TypeQuals) &&
1888 getParamDecl(0)->getType()->isRValueReferenceType();
1889}
1890
1891/// \brief Determine whether this is a copy or move constructor.
1892bool CXXConstructorDecl::isCopyOrMoveConstructor(unsigned &TypeQuals) const {
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001893 // C++ [class.copy]p2:
Douglas Gregorcfd8ddc2008-11-05 16:20:31 +00001894 // A non-template constructor for class X is a copy constructor
1895 // if its first parameter is of type X&, const X&, volatile X& or
1896 // const volatile X&, and either there are no other parameters
1897 // or else all other parameters have default arguments (8.3.6).
Douglas Gregorf282a762011-01-21 19:38:21 +00001898 // C++0x [class.copy]p3:
1899 // A non-template constructor for class X is a move constructor if its
1900 // first parameter is of type X&&, const X&&, volatile X&&, or
1901 // const volatile X&&, and either there are no other parameters or else
1902 // all other parameters have default arguments.
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001903 if ((getNumParams() < 1) ||
Douglas Gregora14b43b2009-10-13 23:45:19 +00001904 (getNumParams() > 1 && !getParamDecl(1)->hasDefaultArg()) ||
Craig Topper36250ad2014-05-12 05:36:57 +00001905 (getPrimaryTemplate() != nullptr) ||
1906 (getDescribedFunctionTemplate() != nullptr))
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001907 return false;
Douglas Gregorf282a762011-01-21 19:38:21 +00001908
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001909 const ParmVarDecl *Param = getParamDecl(0);
Douglas Gregorf282a762011-01-21 19:38:21 +00001910
1911 // Do we have a reference type?
1912 const ReferenceType *ParamRefType = Param->getType()->getAs<ReferenceType>();
Douglas Gregorff7028a2009-11-13 23:59:09 +00001913 if (!ParamRefType)
1914 return false;
Douglas Gregorf282a762011-01-21 19:38:21 +00001915
Douglas Gregorff7028a2009-11-13 23:59:09 +00001916 // Is it a reference to our class type?
Douglas Gregor507eb872009-12-22 00:34:07 +00001917 ASTContext &Context = getASTContext();
1918
Douglas Gregorff7028a2009-11-13 23:59:09 +00001919 CanQualType PointeeType
1920 = Context.getCanonicalType(ParamRefType->getPointeeType());
Douglas Gregorf70b2b42009-09-15 20:50:23 +00001921 CanQualType ClassTy
1922 = Context.getCanonicalType(Context.getTagDeclType(getParent()));
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001923 if (PointeeType.getUnqualifiedType() != ClassTy)
1924 return false;
Douglas Gregorf282a762011-01-21 19:38:21 +00001925
John McCall8ccfcb52009-09-24 19:53:00 +00001926 // FIXME: other qualifiers?
Douglas Gregorf282a762011-01-21 19:38:21 +00001927
1928 // We have a copy or move constructor.
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001929 TypeQuals = PointeeType.getCVRQualifiers();
Douglas Gregorf282a762011-01-21 19:38:21 +00001930 return true;
Douglas Gregoreebb5c12008-10-31 20:25:05 +00001931}
1932
Anders Carlssond20e7952009-08-28 16:57:08 +00001933bool CXXConstructorDecl::isConvertingConstructor(bool AllowExplicit) const {
Douglas Gregor26bee0b2008-10-31 16:23:19 +00001934 // C++ [class.conv.ctor]p1:
1935 // A constructor declared without the function-specifier explicit
1936 // that can be called with a single parameter specifies a
1937 // conversion from the type of its first parameter to the type of
1938 // its class. Such a constructor is called a converting
1939 // constructor.
Anders Carlssond20e7952009-08-28 16:57:08 +00001940 if (isExplicit() && !AllowExplicit)
Douglas Gregor26bee0b2008-10-31 16:23:19 +00001941 return false;
1942
Mike Stump11289f42009-09-09 15:08:12 +00001943 return (getNumParams() == 0 &&
John McCall9dd450b2009-09-21 23:43:11 +00001944 getType()->getAs<FunctionProtoType>()->isVariadic()) ||
Douglas Gregor26bee0b2008-10-31 16:23:19 +00001945 (getNumParams() == 1) ||
Douglas Gregorc65e1592012-06-05 23:44:51 +00001946 (getNumParams() > 1 &&
1947 (getParamDecl(1)->hasDefaultArg() ||
1948 getParamDecl(1)->isParameterPack()));
Douglas Gregor26bee0b2008-10-31 16:23:19 +00001949}
Douglas Gregor61956c42008-10-31 09:07:45 +00001950
Douglas Gregorbd6b17f2010-11-08 17:16:59 +00001951bool CXXConstructorDecl::isSpecializationCopyingObject() const {
Douglas Gregorffe14e32009-11-14 01:20:54 +00001952 if ((getNumParams() < 1) ||
1953 (getNumParams() > 1 && !getParamDecl(1)->hasDefaultArg()) ||
Craig Topper36250ad2014-05-12 05:36:57 +00001954 (getDescribedFunctionTemplate() != nullptr))
Douglas Gregorffe14e32009-11-14 01:20:54 +00001955 return false;
1956
1957 const ParmVarDecl *Param = getParamDecl(0);
1958
1959 ASTContext &Context = getASTContext();
1960 CanQualType ParamType = Context.getCanonicalType(Param->getType());
1961
Douglas Gregorffe14e32009-11-14 01:20:54 +00001962 // Is it the same as our our class type?
1963 CanQualType ClassTy
1964 = Context.getCanonicalType(Context.getTagDeclType(getParent()));
1965 if (ParamType.getUnqualifiedType() != ClassTy)
1966 return false;
1967
1968 return true;
1969}
1970
David Blaikie68e081d2011-12-20 02:48:34 +00001971void CXXDestructorDecl::anchor() { }
1972
Douglas Gregor831c93f2008-11-05 20:51:48 +00001973CXXDestructorDecl *
Douglas Gregor72172e92012-01-05 21:55:30 +00001974CXXDestructorDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith053f6c62014-05-16 23:01:30 +00001975 return new (C, ID)
1976 CXXDestructorDecl(C, nullptr, SourceLocation(), DeclarationNameInfo(),
1977 QualType(), nullptr, false, false);
Chris Lattnerca025db2010-05-07 21:43:38 +00001978}
1979
1980CXXDestructorDecl *
Douglas Gregor831c93f2008-11-05 20:51:48 +00001981CXXDestructorDecl::Create(ASTContext &C, CXXRecordDecl *RD,
Abramo Bagnaradff19302011-03-08 08:55:46 +00001982 SourceLocation StartLoc,
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001983 const DeclarationNameInfo &NameInfo,
Craig Silversteinaf8808d2010-10-21 00:44:50 +00001984 QualType T, TypeSourceInfo *TInfo,
Richard Smitha77a0a62011-08-15 21:04:07 +00001985 bool isInline, bool isImplicitlyDeclared) {
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001986 assert(NameInfo.getName().getNameKind()
1987 == DeclarationName::CXXDestructorName &&
Douglas Gregor77324f32008-11-17 14:58:09 +00001988 "Name must refer to a destructor");
Richard Smith053f6c62014-05-16 23:01:30 +00001989 return new (C, RD) CXXDestructorDecl(C, RD, StartLoc, NameInfo, T, TInfo,
Richard Smithf7981722013-11-22 09:01:48 +00001990 isInline, isImplicitlyDeclared);
Douglas Gregor831c93f2008-11-05 20:51:48 +00001991}
1992
Richard Smithf8134002015-03-10 01:41:22 +00001993void CXXDestructorDecl::setOperatorDelete(FunctionDecl *OD) {
1994 auto *First = cast<CXXDestructorDecl>(getFirstDecl());
1995 if (OD && !First->OperatorDelete) {
1996 First->OperatorDelete = OD;
1997 if (auto *L = getASTMutationListener())
1998 L->ResolvedOperatorDelete(First, OD);
1999 }
2000}
2001
David Blaikie68e081d2011-12-20 02:48:34 +00002002void CXXConversionDecl::anchor() { }
2003
Douglas Gregordbc5daf2008-11-07 20:08:42 +00002004CXXConversionDecl *
Douglas Gregor72172e92012-01-05 21:55:30 +00002005CXXConversionDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith053f6c62014-05-16 23:01:30 +00002006 return new (C, ID) CXXConversionDecl(C, nullptr, SourceLocation(),
Richard Smithf7981722013-11-22 09:01:48 +00002007 DeclarationNameInfo(), QualType(),
Craig Topper36250ad2014-05-12 05:36:57 +00002008 nullptr, false, false, false,
Richard Smithf7981722013-11-22 09:01:48 +00002009 SourceLocation());
Chris Lattnerca025db2010-05-07 21:43:38 +00002010}
2011
2012CXXConversionDecl *
Douglas Gregordbc5daf2008-11-07 20:08:42 +00002013CXXConversionDecl::Create(ASTContext &C, CXXRecordDecl *RD,
Abramo Bagnaradff19302011-03-08 08:55:46 +00002014 SourceLocation StartLoc,
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002015 const DeclarationNameInfo &NameInfo,
John McCallbcd03502009-12-07 02:54:59 +00002016 QualType T, TypeSourceInfo *TInfo,
Douglas Gregorf2f08062011-03-08 17:10:18 +00002017 bool isInline, bool isExplicit,
Richard Smitha77a0a62011-08-15 21:04:07 +00002018 bool isConstexpr, SourceLocation EndLocation) {
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002019 assert(NameInfo.getName().getNameKind()
2020 == DeclarationName::CXXConversionFunctionName &&
Douglas Gregor77324f32008-11-17 14:58:09 +00002021 "Name must refer to a conversion function");
Richard Smith053f6c62014-05-16 23:01:30 +00002022 return new (C, RD) CXXConversionDecl(C, RD, StartLoc, NameInfo, T, TInfo,
Richard Smithf7981722013-11-22 09:01:48 +00002023 isInline, isExplicit, isConstexpr,
2024 EndLocation);
Douglas Gregordbc5daf2008-11-07 20:08:42 +00002025}
2026
Douglas Gregord3b672c2012-02-16 01:06:16 +00002027bool CXXConversionDecl::isLambdaToBlockPointerConversion() const {
2028 return isImplicit() && getParent()->isLambda() &&
2029 getConversionType()->isBlockPointerType();
2030}
2031
David Blaikie68e081d2011-12-20 02:48:34 +00002032void LinkageSpecDecl::anchor() { }
2033
Chris Lattnerb8c18fa2008-11-04 16:51:42 +00002034LinkageSpecDecl *LinkageSpecDecl::Create(ASTContext &C,
Mike Stump11289f42009-09-09 15:08:12 +00002035 DeclContext *DC,
Abramo Bagnaraea947882011-03-08 16:41:52 +00002036 SourceLocation ExternLoc,
2037 SourceLocation LangLoc,
Abramo Bagnara4a8cda82011-03-03 14:52:38 +00002038 LanguageIDs Lang,
Rafael Espindola327be3c2013-04-26 01:30:23 +00002039 bool HasBraces) {
Richard Smithf7981722013-11-22 09:01:48 +00002040 return new (C, DC) LinkageSpecDecl(DC, ExternLoc, LangLoc, Lang, HasBraces);
Douglas Gregor29ff7d02008-12-16 22:23:02 +00002041}
Douglas Gregor889ceb72009-02-03 19:21:40 +00002042
Richard Smithf7981722013-11-22 09:01:48 +00002043LinkageSpecDecl *LinkageSpecDecl::CreateDeserialized(ASTContext &C,
2044 unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002045 return new (C, ID) LinkageSpecDecl(nullptr, SourceLocation(),
2046 SourceLocation(), lang_c, false);
Douglas Gregor72172e92012-01-05 21:55:30 +00002047}
2048
David Blaikie68e081d2011-12-20 02:48:34 +00002049void UsingDirectiveDecl::anchor() { }
2050
Douglas Gregor889ceb72009-02-03 19:21:40 +00002051UsingDirectiveDecl *UsingDirectiveDecl::Create(ASTContext &C, DeclContext *DC,
2052 SourceLocation L,
2053 SourceLocation NamespaceLoc,
Douglas Gregor12441b32011-02-25 16:33:46 +00002054 NestedNameSpecifierLoc QualifierLoc,
Douglas Gregor889ceb72009-02-03 19:21:40 +00002055 SourceLocation IdentLoc,
Sebastian Redla6602e92009-11-23 15:34:23 +00002056 NamedDecl *Used,
Douglas Gregor889ceb72009-02-03 19:21:40 +00002057 DeclContext *CommonAncestor) {
Sebastian Redla6602e92009-11-23 15:34:23 +00002058 if (NamespaceDecl *NS = dyn_cast_or_null<NamespaceDecl>(Used))
2059 Used = NS->getOriginalNamespace();
Richard Smithf7981722013-11-22 09:01:48 +00002060 return new (C, DC) UsingDirectiveDecl(DC, L, NamespaceLoc, QualifierLoc,
2061 IdentLoc, Used, CommonAncestor);
Douglas Gregor889ceb72009-02-03 19:21:40 +00002062}
2063
Richard Smithf7981722013-11-22 09:01:48 +00002064UsingDirectiveDecl *UsingDirectiveDecl::CreateDeserialized(ASTContext &C,
2065 unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002066 return new (C, ID) UsingDirectiveDecl(nullptr, SourceLocation(),
2067 SourceLocation(),
Richard Smithf7981722013-11-22 09:01:48 +00002068 NestedNameSpecifierLoc(),
Craig Topper36250ad2014-05-12 05:36:57 +00002069 SourceLocation(), nullptr, nullptr);
Douglas Gregor72172e92012-01-05 21:55:30 +00002070}
2071
Sebastian Redla6602e92009-11-23 15:34:23 +00002072NamespaceDecl *UsingDirectiveDecl::getNominatedNamespace() {
2073 if (NamespaceAliasDecl *NA =
2074 dyn_cast_or_null<NamespaceAliasDecl>(NominatedNamespace))
2075 return NA->getNamespace();
2076 return cast_or_null<NamespaceDecl>(NominatedNamespace);
2077}
2078
Richard Smith053f6c62014-05-16 23:01:30 +00002079NamespaceDecl::NamespaceDecl(ASTContext &C, DeclContext *DC, bool Inline,
2080 SourceLocation StartLoc, SourceLocation IdLoc,
2081 IdentifierInfo *Id, NamespaceDecl *PrevDecl)
2082 : NamedDecl(Namespace, DC, IdLoc, Id), DeclContext(Namespace),
2083 redeclarable_base(C), LocStart(StartLoc), RBraceLoc(),
2084 AnonOrFirstNamespaceAndInline(nullptr, Inline) {
Rafael Espindola8db352d2013-10-17 15:37:26 +00002085 setPreviousDecl(PrevDecl);
Richard Smith053f6c62014-05-16 23:01:30 +00002086
Douglas Gregore57e7522012-01-07 09:11:48 +00002087 if (PrevDecl)
2088 AnonOrFirstNamespaceAndInline.setPointer(PrevDecl->getOriginalNamespace());
2089}
2090
Douglas Gregor72172e92012-01-05 21:55:30 +00002091NamespaceDecl *NamespaceDecl::Create(ASTContext &C, DeclContext *DC,
Douglas Gregore57e7522012-01-07 09:11:48 +00002092 bool Inline, SourceLocation StartLoc,
2093 SourceLocation IdLoc, IdentifierInfo *Id,
2094 NamespaceDecl *PrevDecl) {
Richard Smith053f6c62014-05-16 23:01:30 +00002095 return new (C, DC) NamespaceDecl(C, DC, Inline, StartLoc, IdLoc, Id,
2096 PrevDecl);
Douglas Gregor72172e92012-01-05 21:55:30 +00002097}
2098
2099NamespaceDecl *NamespaceDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith053f6c62014-05-16 23:01:30 +00002100 return new (C, ID) NamespaceDecl(C, nullptr, false, SourceLocation(),
Craig Topper36250ad2014-05-12 05:36:57 +00002101 SourceLocation(), nullptr, nullptr);
Douglas Gregor72172e92012-01-05 21:55:30 +00002102}
2103
Chandler Carruth21c90602015-12-30 03:24:14 +00002104NamespaceDecl *NamespaceDecl::getOriginalNamespace() {
2105 if (isFirstDecl())
2106 return this;
2107
2108 return AnonOrFirstNamespaceAndInline.getPointer();
2109}
2110
2111const NamespaceDecl *NamespaceDecl::getOriginalNamespace() const {
2112 if (isFirstDecl())
2113 return this;
2114
2115 return AnonOrFirstNamespaceAndInline.getPointer();
2116}
2117
2118bool NamespaceDecl::isOriginalNamespace() const { return isFirstDecl(); }
2119
Richard Smithd7af8a32014-05-10 01:17:36 +00002120NamespaceDecl *NamespaceDecl::getNextRedeclarationImpl() {
2121 return getNextRedeclaration();
Rafael Espindola8ef7f682013-11-26 15:12:20 +00002122}
2123NamespaceDecl *NamespaceDecl::getPreviousDeclImpl() {
2124 return getPreviousDecl();
2125}
2126NamespaceDecl *NamespaceDecl::getMostRecentDeclImpl() {
2127 return getMostRecentDecl();
2128}
2129
David Blaikie68e081d2011-12-20 02:48:34 +00002130void NamespaceAliasDecl::anchor() { }
2131
Richard Smithf4634362014-09-03 23:11:22 +00002132NamespaceAliasDecl *NamespaceAliasDecl::getNextRedeclarationImpl() {
2133 return getNextRedeclaration();
2134}
2135NamespaceAliasDecl *NamespaceAliasDecl::getPreviousDeclImpl() {
2136 return getPreviousDecl();
2137}
2138NamespaceAliasDecl *NamespaceAliasDecl::getMostRecentDeclImpl() {
2139 return getMostRecentDecl();
2140}
2141
Mike Stump11289f42009-09-09 15:08:12 +00002142NamespaceAliasDecl *NamespaceAliasDecl::Create(ASTContext &C, DeclContext *DC,
Douglas Gregor01a430132010-09-01 03:07:18 +00002143 SourceLocation UsingLoc,
Mike Stump11289f42009-09-09 15:08:12 +00002144 SourceLocation AliasLoc,
2145 IdentifierInfo *Alias,
Douglas Gregorc05ba2e2011-02-25 17:08:07 +00002146 NestedNameSpecifierLoc QualifierLoc,
Mike Stump11289f42009-09-09 15:08:12 +00002147 SourceLocation IdentLoc,
Anders Carlssonff25fdf2009-03-28 22:58:02 +00002148 NamedDecl *Namespace) {
Richard Smithf4634362014-09-03 23:11:22 +00002149 // FIXME: Preserve the aliased namespace as written.
Sebastian Redla6602e92009-11-23 15:34:23 +00002150 if (NamespaceDecl *NS = dyn_cast_or_null<NamespaceDecl>(Namespace))
2151 Namespace = NS->getOriginalNamespace();
Richard Smithf4634362014-09-03 23:11:22 +00002152 return new (C, DC) NamespaceAliasDecl(C, DC, UsingLoc, AliasLoc, Alias,
Richard Smithf7981722013-11-22 09:01:48 +00002153 QualifierLoc, IdentLoc, Namespace);
Anders Carlssonff25fdf2009-03-28 22:58:02 +00002154}
2155
Douglas Gregor72172e92012-01-05 21:55:30 +00002156NamespaceAliasDecl *
2157NamespaceAliasDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smithf4634362014-09-03 23:11:22 +00002158 return new (C, ID) NamespaceAliasDecl(C, nullptr, SourceLocation(),
Craig Topper36250ad2014-05-12 05:36:57 +00002159 SourceLocation(), nullptr,
2160 NestedNameSpecifierLoc(),
2161 SourceLocation(), nullptr);
Douglas Gregor72172e92012-01-05 21:55:30 +00002162}
2163
David Blaikie68e081d2011-12-20 02:48:34 +00002164void UsingShadowDecl::anchor() { }
2165
Richard Smith5179eb72016-06-28 19:03:57 +00002166UsingShadowDecl::UsingShadowDecl(Kind K, ASTContext &C, DeclContext *DC,
2167 SourceLocation Loc, UsingDecl *Using,
2168 NamedDecl *Target)
2169 : NamedDecl(K, DC, Loc, Using ? Using->getDeclName() : DeclarationName()),
2170 redeclarable_base(C), Underlying(Target),
2171 UsingOrNextShadow(cast<NamedDecl>(Using)) {
2172 if (Target)
2173 IdentifierNamespace = Target->getIdentifierNamespace();
2174 setImplicit();
2175}
2176
2177UsingShadowDecl::UsingShadowDecl(Kind K, ASTContext &C, EmptyShell Empty)
2178 : NamedDecl(K, nullptr, SourceLocation(), DeclarationName()),
2179 redeclarable_base(C), Underlying(), UsingOrNextShadow() {}
2180
Douglas Gregor72172e92012-01-05 21:55:30 +00002181UsingShadowDecl *
2182UsingShadowDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith5179eb72016-06-28 19:03:57 +00002183 return new (C, ID) UsingShadowDecl(UsingShadow, C, EmptyShell());
Douglas Gregor72172e92012-01-05 21:55:30 +00002184}
2185
Argyrios Kyrtzidis2703beb2010-11-10 05:40:41 +00002186UsingDecl *UsingShadowDecl::getUsingDecl() const {
2187 const UsingShadowDecl *Shadow = this;
2188 while (const UsingShadowDecl *NextShadow =
2189 dyn_cast<UsingShadowDecl>(Shadow->UsingOrNextShadow))
2190 Shadow = NextShadow;
2191 return cast<UsingDecl>(Shadow->UsingOrNextShadow);
2192}
2193
Richard Smith5179eb72016-06-28 19:03:57 +00002194void ConstructorUsingShadowDecl::anchor() { }
2195
2196ConstructorUsingShadowDecl *
2197ConstructorUsingShadowDecl::Create(ASTContext &C, DeclContext *DC,
2198 SourceLocation Loc, UsingDecl *Using,
2199 NamedDecl *Target, bool IsVirtual) {
2200 return new (C, DC) ConstructorUsingShadowDecl(C, DC, Loc, Using, Target,
2201 IsVirtual);
2202}
2203
2204ConstructorUsingShadowDecl *
2205ConstructorUsingShadowDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
2206 return new (C, ID) ConstructorUsingShadowDecl(C, EmptyShell());
2207}
2208
2209CXXRecordDecl *ConstructorUsingShadowDecl::getNominatedBaseClass() const {
2210 return getUsingDecl()->getQualifier()->getAsRecordDecl();
2211}
2212
David Blaikie68e081d2011-12-20 02:48:34 +00002213void UsingDecl::anchor() { }
2214
Argyrios Kyrtzidis2703beb2010-11-10 05:40:41 +00002215void UsingDecl::addShadowDecl(UsingShadowDecl *S) {
2216 assert(std::find(shadow_begin(), shadow_end(), S) == shadow_end() &&
2217 "declaration already in set");
2218 assert(S->getUsingDecl() == this);
2219
Benjamin Kramere78f8ee2012-01-07 19:09:05 +00002220 if (FirstUsingShadow.getPointer())
2221 S->UsingOrNextShadow = FirstUsingShadow.getPointer();
2222 FirstUsingShadow.setPointer(S);
Argyrios Kyrtzidis2703beb2010-11-10 05:40:41 +00002223}
2224
2225void UsingDecl::removeShadowDecl(UsingShadowDecl *S) {
2226 assert(std::find(shadow_begin(), shadow_end(), S) != shadow_end() &&
2227 "declaration not in set");
2228 assert(S->getUsingDecl() == this);
2229
2230 // Remove S from the shadow decl chain. This is O(n) but hopefully rare.
2231
Benjamin Kramere78f8ee2012-01-07 19:09:05 +00002232 if (FirstUsingShadow.getPointer() == S) {
2233 FirstUsingShadow.setPointer(
2234 dyn_cast<UsingShadowDecl>(S->UsingOrNextShadow));
Argyrios Kyrtzidis2703beb2010-11-10 05:40:41 +00002235 S->UsingOrNextShadow = this;
2236 return;
2237 }
2238
Benjamin Kramere78f8ee2012-01-07 19:09:05 +00002239 UsingShadowDecl *Prev = FirstUsingShadow.getPointer();
Argyrios Kyrtzidis2703beb2010-11-10 05:40:41 +00002240 while (Prev->UsingOrNextShadow != S)
2241 Prev = cast<UsingShadowDecl>(Prev->UsingOrNextShadow);
2242 Prev->UsingOrNextShadow = S->UsingOrNextShadow;
2243 S->UsingOrNextShadow = this;
2244}
2245
Douglas Gregora9d87bc2011-02-25 00:36:19 +00002246UsingDecl *UsingDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation UL,
2247 NestedNameSpecifierLoc QualifierLoc,
Abramo Bagnara8de74e92010-08-12 11:46:03 +00002248 const DeclarationNameInfo &NameInfo,
Enea Zaffanellae05a3cf2013-07-22 10:54:09 +00002249 bool HasTypename) {
Richard Smithf7981722013-11-22 09:01:48 +00002250 return new (C, DC) UsingDecl(DC, UL, QualifierLoc, NameInfo, HasTypename);
Douglas Gregorfec52632009-06-20 00:51:54 +00002251}
2252
Douglas Gregor72172e92012-01-05 21:55:30 +00002253UsingDecl *UsingDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002254 return new (C, ID) UsingDecl(nullptr, SourceLocation(),
2255 NestedNameSpecifierLoc(), DeclarationNameInfo(),
2256 false);
Douglas Gregor72172e92012-01-05 21:55:30 +00002257}
2258
Enea Zaffanellac70b2512013-07-17 17:28:56 +00002259SourceRange UsingDecl::getSourceRange() const {
2260 SourceLocation Begin = isAccessDeclaration()
2261 ? getQualifierLoc().getBeginLoc() : UsingLocation;
2262 return SourceRange(Begin, getNameInfo().getEndLoc());
2263}
2264
Richard Smith151c4562016-12-20 21:35:28 +00002265void UsingPackDecl::anchor() { }
2266
2267UsingPackDecl *UsingPackDecl::Create(ASTContext &C, DeclContext *DC,
2268 NamedDecl *InstantiatedFrom,
2269 ArrayRef<NamedDecl *> UsingDecls) {
2270 size_t Extra = additionalSizeToAlloc<NamedDecl *>(UsingDecls.size());
2271 return new (C, DC, Extra) UsingPackDecl(DC, InstantiatedFrom, UsingDecls);
2272}
2273
2274UsingPackDecl *UsingPackDecl::CreateDeserialized(ASTContext &C, unsigned ID,
2275 unsigned NumExpansions) {
2276 size_t Extra = additionalSizeToAlloc<NamedDecl *>(NumExpansions);
2277 auto *Result = new (C, ID, Extra) UsingPackDecl(nullptr, nullptr, None);
2278 Result->NumExpansions = NumExpansions;
2279 auto *Trail = Result->getTrailingObjects<NamedDecl *>();
2280 for (unsigned I = 0; I != NumExpansions; ++I)
2281 new (Trail + I) NamedDecl*(nullptr);
2282 return Result;
2283}
2284
David Blaikie68e081d2011-12-20 02:48:34 +00002285void UnresolvedUsingValueDecl::anchor() { }
2286
John McCalle61f2ba2009-11-18 02:36:19 +00002287UnresolvedUsingValueDecl *
2288UnresolvedUsingValueDecl::Create(ASTContext &C, DeclContext *DC,
2289 SourceLocation UsingLoc,
Douglas Gregora9d87bc2011-02-25 00:36:19 +00002290 NestedNameSpecifierLoc QualifierLoc,
Richard Smith151c4562016-12-20 21:35:28 +00002291 const DeclarationNameInfo &NameInfo,
2292 SourceLocation EllipsisLoc) {
Richard Smithf7981722013-11-22 09:01:48 +00002293 return new (C, DC) UnresolvedUsingValueDecl(DC, C.DependentTy, UsingLoc,
Richard Smith151c4562016-12-20 21:35:28 +00002294 QualifierLoc, NameInfo,
2295 EllipsisLoc);
John McCalle61f2ba2009-11-18 02:36:19 +00002296}
2297
Douglas Gregor72172e92012-01-05 21:55:30 +00002298UnresolvedUsingValueDecl *
2299UnresolvedUsingValueDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002300 return new (C, ID) UnresolvedUsingValueDecl(nullptr, QualType(),
2301 SourceLocation(),
Richard Smithf7981722013-11-22 09:01:48 +00002302 NestedNameSpecifierLoc(),
Richard Smith151c4562016-12-20 21:35:28 +00002303 DeclarationNameInfo(),
2304 SourceLocation());
Douglas Gregor72172e92012-01-05 21:55:30 +00002305}
2306
Enea Zaffanellac70b2512013-07-17 17:28:56 +00002307SourceRange UnresolvedUsingValueDecl::getSourceRange() const {
2308 SourceLocation Begin = isAccessDeclaration()
2309 ? getQualifierLoc().getBeginLoc() : UsingLocation;
2310 return SourceRange(Begin, getNameInfo().getEndLoc());
2311}
2312
David Blaikie68e081d2011-12-20 02:48:34 +00002313void UnresolvedUsingTypenameDecl::anchor() { }
2314
John McCalle61f2ba2009-11-18 02:36:19 +00002315UnresolvedUsingTypenameDecl *
2316UnresolvedUsingTypenameDecl::Create(ASTContext &C, DeclContext *DC,
2317 SourceLocation UsingLoc,
2318 SourceLocation TypenameLoc,
Douglas Gregora9d87bc2011-02-25 00:36:19 +00002319 NestedNameSpecifierLoc QualifierLoc,
John McCalle61f2ba2009-11-18 02:36:19 +00002320 SourceLocation TargetNameLoc,
Richard Smith151c4562016-12-20 21:35:28 +00002321 DeclarationName TargetName,
2322 SourceLocation EllipsisLoc) {
Richard Smithf7981722013-11-22 09:01:48 +00002323 return new (C, DC) UnresolvedUsingTypenameDecl(
2324 DC, UsingLoc, TypenameLoc, QualifierLoc, TargetNameLoc,
Richard Smith151c4562016-12-20 21:35:28 +00002325 TargetName.getAsIdentifierInfo(), EllipsisLoc);
Anders Carlsson8305c1f2009-08-28 05:30:28 +00002326}
2327
Douglas Gregor72172e92012-01-05 21:55:30 +00002328UnresolvedUsingTypenameDecl *
2329UnresolvedUsingTypenameDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smithf7981722013-11-22 09:01:48 +00002330 return new (C, ID) UnresolvedUsingTypenameDecl(
Craig Topper36250ad2014-05-12 05:36:57 +00002331 nullptr, SourceLocation(), SourceLocation(), NestedNameSpecifierLoc(),
Richard Smith151c4562016-12-20 21:35:28 +00002332 SourceLocation(), nullptr, SourceLocation());
Douglas Gregor72172e92012-01-05 21:55:30 +00002333}
2334
David Blaikie68e081d2011-12-20 02:48:34 +00002335void StaticAssertDecl::anchor() { }
2336
Anders Carlsson5bbe1d72009-03-14 00:25:26 +00002337StaticAssertDecl *StaticAssertDecl::Create(ASTContext &C, DeclContext *DC,
Abramo Bagnaraea947882011-03-08 16:41:52 +00002338 SourceLocation StaticAssertLoc,
2339 Expr *AssertExpr,
2340 StringLiteral *Message,
Richard Smithded9c2e2012-07-11 22:37:56 +00002341 SourceLocation RParenLoc,
2342 bool Failed) {
Richard Smithf7981722013-11-22 09:01:48 +00002343 return new (C, DC) StaticAssertDecl(DC, StaticAssertLoc, AssertExpr, Message,
2344 RParenLoc, Failed);
Anders Carlsson5bbe1d72009-03-14 00:25:26 +00002345}
2346
Richard Smithf7981722013-11-22 09:01:48 +00002347StaticAssertDecl *StaticAssertDecl::CreateDeserialized(ASTContext &C,
Douglas Gregor72172e92012-01-05 21:55:30 +00002348 unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002349 return new (C, ID) StaticAssertDecl(nullptr, SourceLocation(), nullptr,
2350 nullptr, SourceLocation(), false);
Richard Smithf7981722013-11-22 09:01:48 +00002351}
2352
Richard Smithbdb84f32016-07-22 23:36:59 +00002353void BindingDecl::anchor() {}
2354
2355BindingDecl *BindingDecl::Create(ASTContext &C, DeclContext *DC,
2356 SourceLocation IdLoc, IdentifierInfo *Id) {
Richard Smith32cb8c92016-08-12 00:53:41 +00002357 return new (C, DC) BindingDecl(DC, IdLoc, Id);
Richard Smithbdb84f32016-07-22 23:36:59 +00002358}
2359
2360BindingDecl *BindingDecl::CreateDeserialized(ASTContext &C, unsigned ID) {
Richard Smith32cb8c92016-08-12 00:53:41 +00002361 return new (C, ID) BindingDecl(nullptr, SourceLocation(), nullptr);
Richard Smithbdb84f32016-07-22 23:36:59 +00002362}
2363
Richard Smith97fcf4b2016-08-14 23:15:52 +00002364VarDecl *BindingDecl::getHoldingVar() const {
2365 Expr *B = getBinding();
2366 if (!B)
2367 return nullptr;
2368 auto *DRE = dyn_cast<DeclRefExpr>(B->IgnoreImplicit());
2369 if (!DRE)
2370 return nullptr;
2371
2372 auto *VD = dyn_cast<VarDecl>(DRE->getDecl());
2373 assert(VD->isImplicit() && "holding var for binding decl not implicit");
2374 return VD;
2375}
2376
Richard Smithbdb84f32016-07-22 23:36:59 +00002377void DecompositionDecl::anchor() {}
2378
2379DecompositionDecl *DecompositionDecl::Create(ASTContext &C, DeclContext *DC,
2380 SourceLocation StartLoc,
2381 SourceLocation LSquareLoc,
2382 QualType T, TypeSourceInfo *TInfo,
2383 StorageClass SC,
2384 ArrayRef<BindingDecl *> Bindings) {
2385 size_t Extra = additionalSizeToAlloc<BindingDecl *>(Bindings.size());
2386 return new (C, DC, Extra)
2387 DecompositionDecl(C, DC, StartLoc, LSquareLoc, T, TInfo, SC, Bindings);
2388}
2389
2390DecompositionDecl *DecompositionDecl::CreateDeserialized(ASTContext &C,
2391 unsigned ID,
2392 unsigned NumBindings) {
2393 size_t Extra = additionalSizeToAlloc<BindingDecl *>(NumBindings);
Richard Smith7b76d812016-08-12 02:21:25 +00002394 auto *Result = new (C, ID, Extra)
2395 DecompositionDecl(C, nullptr, SourceLocation(), SourceLocation(),
2396 QualType(), nullptr, StorageClass(), None);
Richard Smithbdb84f32016-07-22 23:36:59 +00002397 // Set up and clean out the bindings array.
2398 Result->NumBindings = NumBindings;
2399 auto *Trail = Result->getTrailingObjects<BindingDecl *>();
2400 for (unsigned I = 0; I != NumBindings; ++I)
2401 new (Trail + I) BindingDecl*(nullptr);
2402 return Result;
2403}
2404
Richard Smith7873de02016-08-11 22:25:46 +00002405void DecompositionDecl::printName(llvm::raw_ostream &os) const {
2406 os << '[';
2407 bool Comma = false;
2408 for (auto *B : bindings()) {
2409 if (Comma)
2410 os << ", ";
2411 B->printName(os);
2412 Comma = true;
2413 }
2414 os << ']';
2415}
2416
Richard Smithf7981722013-11-22 09:01:48 +00002417MSPropertyDecl *MSPropertyDecl::Create(ASTContext &C, DeclContext *DC,
2418 SourceLocation L, DeclarationName N,
2419 QualType T, TypeSourceInfo *TInfo,
2420 SourceLocation StartL,
2421 IdentifierInfo *Getter,
2422 IdentifierInfo *Setter) {
2423 return new (C, DC) MSPropertyDecl(DC, L, N, T, TInfo, StartL, Getter, Setter);
2424}
2425
2426MSPropertyDecl *MSPropertyDecl::CreateDeserialized(ASTContext &C,
2427 unsigned ID) {
Craig Topper36250ad2014-05-12 05:36:57 +00002428 return new (C, ID) MSPropertyDecl(nullptr, SourceLocation(),
2429 DeclarationName(), QualType(), nullptr,
2430 SourceLocation(), nullptr, nullptr);
Douglas Gregor72172e92012-01-05 21:55:30 +00002431}
2432
Anders Carlsson6750d162009-03-26 23:46:50 +00002433static const char *getAccessName(AccessSpecifier AS) {
2434 switch (AS) {
Anders Carlsson6750d162009-03-26 23:46:50 +00002435 case AS_none:
David Blaikie83d382b2011-09-23 05:06:16 +00002436 llvm_unreachable("Invalid access specifier!");
Anders Carlsson6750d162009-03-26 23:46:50 +00002437 case AS_public:
2438 return "public";
2439 case AS_private:
2440 return "private";
2441 case AS_protected:
2442 return "protected";
2443 }
David Blaikief47fa302012-01-17 02:30:50 +00002444 llvm_unreachable("Invalid access specifier!");
Anders Carlsson6750d162009-03-26 23:46:50 +00002445}
2446
2447const DiagnosticBuilder &clang::operator<<(const DiagnosticBuilder &DB,
2448 AccessSpecifier AS) {
2449 return DB << getAccessName(AS);
2450}
Richard Smith84f6dcf2012-02-02 01:16:57 +00002451
2452const PartialDiagnostic &clang::operator<<(const PartialDiagnostic &DB,
2453 AccessSpecifier AS) {
2454 return DB << getAccessName(AS);
2455}