blob: e6776ac1b871066a8f9bc330fd8bdb1565a0df8a [file] [log] [blame]
Douglas Gregor96e578d2010-02-05 17:54:41 +00001//===--- ASTImporter.cpp - Importing ASTs from other Contexts ---*- C++ -*-===//
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 defines the ASTImporter class which imports AST nodes from one
11// context into another context.
12//
13//===----------------------------------------------------------------------===//
14#include "clang/AST/ASTImporter.h"
Douglas Gregor96e578d2010-02-05 17:54:41 +000015#include "clang/AST/ASTContext.h"
Douglas Gregor811663e2010-02-10 00:15:17 +000016#include "clang/AST/ASTDiagnostic.h"
Douglas Gregor5c73e912010-02-11 00:48:18 +000017#include "clang/AST/DeclCXX.h"
Douglas Gregor96e578d2010-02-05 17:54:41 +000018#include "clang/AST/DeclObjC.h"
Douglas Gregor3aed6cd2010-02-08 21:09:39 +000019#include "clang/AST/DeclVisitor.h"
Douglas Gregor7eeb5972010-02-11 19:21:55 +000020#include "clang/AST/StmtVisitor.h"
Douglas Gregor96e578d2010-02-05 17:54:41 +000021#include "clang/AST/TypeVisitor.h"
Douglas Gregor811663e2010-02-10 00:15:17 +000022#include "clang/Basic/FileManager.h"
23#include "clang/Basic/SourceManager.h"
24#include "llvm/Support/MemoryBuffer.h"
Douglas Gregor3996e242010-02-15 22:01:00 +000025#include <deque>
Douglas Gregor96e578d2010-02-05 17:54:41 +000026
Douglas Gregor3c2404b2011-11-03 18:07:07 +000027namespace clang {
Douglas Gregor3aed6cd2010-02-08 21:09:39 +000028 class ASTNodeImporter : public TypeVisitor<ASTNodeImporter, QualType>,
Douglas Gregor7eeb5972010-02-11 19:21:55 +000029 public DeclVisitor<ASTNodeImporter, Decl *>,
30 public StmtVisitor<ASTNodeImporter, Stmt *> {
Douglas Gregor96e578d2010-02-05 17:54:41 +000031 ASTImporter &Importer;
32
33 public:
34 explicit ASTNodeImporter(ASTImporter &Importer) : Importer(Importer) { }
35
36 using TypeVisitor<ASTNodeImporter, QualType>::Visit;
Douglas Gregor62d311f2010-02-09 19:21:46 +000037 using DeclVisitor<ASTNodeImporter, Decl *>::Visit;
Douglas Gregor7eeb5972010-02-11 19:21:55 +000038 using StmtVisitor<ASTNodeImporter, Stmt *>::Visit;
Douglas Gregor96e578d2010-02-05 17:54:41 +000039
40 // Importing types
John McCall424cec92011-01-19 06:33:43 +000041 QualType VisitType(const Type *T);
42 QualType VisitBuiltinType(const BuiltinType *T);
43 QualType VisitComplexType(const ComplexType *T);
44 QualType VisitPointerType(const PointerType *T);
45 QualType VisitBlockPointerType(const BlockPointerType *T);
46 QualType VisitLValueReferenceType(const LValueReferenceType *T);
47 QualType VisitRValueReferenceType(const RValueReferenceType *T);
48 QualType VisitMemberPointerType(const MemberPointerType *T);
49 QualType VisitConstantArrayType(const ConstantArrayType *T);
50 QualType VisitIncompleteArrayType(const IncompleteArrayType *T);
51 QualType VisitVariableArrayType(const VariableArrayType *T);
Douglas Gregor96e578d2010-02-05 17:54:41 +000052 // FIXME: DependentSizedArrayType
53 // FIXME: DependentSizedExtVectorType
John McCall424cec92011-01-19 06:33:43 +000054 QualType VisitVectorType(const VectorType *T);
55 QualType VisitExtVectorType(const ExtVectorType *T);
56 QualType VisitFunctionNoProtoType(const FunctionNoProtoType *T);
57 QualType VisitFunctionProtoType(const FunctionProtoType *T);
Douglas Gregor96e578d2010-02-05 17:54:41 +000058 // FIXME: UnresolvedUsingType
Sean Callananda6df8a2011-08-11 16:56:07 +000059 QualType VisitParenType(const ParenType *T);
John McCall424cec92011-01-19 06:33:43 +000060 QualType VisitTypedefType(const TypedefType *T);
61 QualType VisitTypeOfExprType(const TypeOfExprType *T);
Douglas Gregor96e578d2010-02-05 17:54:41 +000062 // FIXME: DependentTypeOfExprType
John McCall424cec92011-01-19 06:33:43 +000063 QualType VisitTypeOfType(const TypeOfType *T);
64 QualType VisitDecltypeType(const DecltypeType *T);
Alexis Hunte852b102011-05-24 22:41:36 +000065 QualType VisitUnaryTransformType(const UnaryTransformType *T);
Richard Smith30482bc2011-02-20 03:19:35 +000066 QualType VisitAutoType(const AutoType *T);
Douglas Gregor96e578d2010-02-05 17:54:41 +000067 // FIXME: DependentDecltypeType
John McCall424cec92011-01-19 06:33:43 +000068 QualType VisitRecordType(const RecordType *T);
69 QualType VisitEnumType(const EnumType *T);
Douglas Gregor96e578d2010-02-05 17:54:41 +000070 // FIXME: TemplateTypeParmType
71 // FIXME: SubstTemplateTypeParmType
John McCall424cec92011-01-19 06:33:43 +000072 QualType VisitTemplateSpecializationType(const TemplateSpecializationType *T);
73 QualType VisitElaboratedType(const ElaboratedType *T);
Douglas Gregorc1d2d8a2010-03-31 17:34:00 +000074 // FIXME: DependentNameType
John McCallc392f372010-06-11 00:33:02 +000075 // FIXME: DependentTemplateSpecializationType
John McCall424cec92011-01-19 06:33:43 +000076 QualType VisitObjCInterfaceType(const ObjCInterfaceType *T);
77 QualType VisitObjCObjectType(const ObjCObjectType *T);
78 QualType VisitObjCObjectPointerType(const ObjCObjectPointerType *T);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +000079
Douglas Gregor95d82832012-01-24 18:36:04 +000080 // Importing declarations
Douglas Gregorbb7930c2010-02-10 19:54:31 +000081 bool ImportDeclParts(NamedDecl *D, DeclContext *&DC,
82 DeclContext *&LexicalDC, DeclarationName &Name,
Douglas Gregorf18a2c72010-02-21 18:26:36 +000083 SourceLocation &Loc);
Douglas Gregord451ea92011-07-29 23:31:30 +000084 void ImportDefinitionIfNeeded(Decl *FromD, Decl *ToD = 0);
Abramo Bagnarad6d2f182010-08-11 22:01:17 +000085 void ImportDeclarationNameLoc(const DeclarationNameInfo &From,
86 DeclarationNameInfo& To);
Douglas Gregor0a791672011-01-18 03:11:38 +000087 void ImportDeclContext(DeclContext *FromDC, bool ForceImport = false);
Douglas Gregor2e15c842012-02-01 21:00:38 +000088
Douglas Gregor95d82832012-01-24 18:36:04 +000089 /// \brief What we should import from the definition.
90 enum ImportDefinitionKind {
91 /// \brief Import the default subset of the definition, which might be
92 /// nothing (if minimal import is set) or might be everything (if minimal
93 /// import is not set).
94 IDK_Default,
95 /// \brief Import everything.
96 IDK_Everything,
97 /// \brief Import only the bare bones needed to establish a valid
98 /// DeclContext.
99 IDK_Basic
100 };
101
Douglas Gregor2e15c842012-02-01 21:00:38 +0000102 bool shouldForceImportDeclContext(ImportDefinitionKind IDK) {
103 return IDK == IDK_Everything ||
104 (IDK == IDK_Default && !Importer.isMinimalImport());
105 }
106
Douglas Gregord451ea92011-07-29 23:31:30 +0000107 bool ImportDefinition(RecordDecl *From, RecordDecl *To,
Douglas Gregor95d82832012-01-24 18:36:04 +0000108 ImportDefinitionKind Kind = IDK_Default);
Larisse Voufo39a1e502013-08-06 01:03:05 +0000109 bool ImportDefinition(VarDecl *From, VarDecl *To,
110 ImportDefinitionKind Kind = IDK_Default);
Douglas Gregord451ea92011-07-29 23:31:30 +0000111 bool ImportDefinition(EnumDecl *From, EnumDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +0000112 ImportDefinitionKind Kind = IDK_Default);
Douglas Gregor2aa53772012-01-24 17:42:07 +0000113 bool ImportDefinition(ObjCInterfaceDecl *From, ObjCInterfaceDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +0000114 ImportDefinitionKind Kind = IDK_Default);
Douglas Gregor2aa53772012-01-24 17:42:07 +0000115 bool ImportDefinition(ObjCProtocolDecl *From, ObjCProtocolDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +0000116 ImportDefinitionKind Kind = IDK_Default);
Douglas Gregora082a492010-11-30 19:14:50 +0000117 TemplateParameterList *ImportTemplateParameterList(
118 TemplateParameterList *Params);
Douglas Gregore2e50d332010-12-01 01:36:18 +0000119 TemplateArgument ImportTemplateArgument(const TemplateArgument &From);
120 bool ImportTemplateArguments(const TemplateArgument *FromArgs,
121 unsigned NumFromArgs,
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000122 SmallVectorImpl<TemplateArgument> &ToArgs);
Douglas Gregordd6006f2012-07-17 21:16:27 +0000123 bool IsStructuralMatch(RecordDecl *FromRecord, RecordDecl *ToRecord,
124 bool Complain = true);
Larisse Voufo39a1e502013-08-06 01:03:05 +0000125 bool IsStructuralMatch(VarDecl *FromVar, VarDecl *ToVar,
126 bool Complain = true);
Douglas Gregor3996e242010-02-15 22:01:00 +0000127 bool IsStructuralMatch(EnumDecl *FromEnum, EnumDecl *ToRecord);
Douglas Gregor91155082012-11-14 22:29:20 +0000128 bool IsStructuralMatch(EnumConstantDecl *FromEC, EnumConstantDecl *ToEC);
Douglas Gregora082a492010-11-30 19:14:50 +0000129 bool IsStructuralMatch(ClassTemplateDecl *From, ClassTemplateDecl *To);
Larisse Voufo39a1e502013-08-06 01:03:05 +0000130 bool IsStructuralMatch(VarTemplateDecl *From, VarTemplateDecl *To);
Douglas Gregore4c83e42010-02-09 22:48:33 +0000131 Decl *VisitDecl(Decl *D);
Sean Callanan65198272011-11-17 23:20:56 +0000132 Decl *VisitTranslationUnitDecl(TranslationUnitDecl *D);
Douglas Gregorf18a2c72010-02-21 18:26:36 +0000133 Decl *VisitNamespaceDecl(NamespaceDecl *D);
Richard Smithdda56e42011-04-15 14:24:37 +0000134 Decl *VisitTypedefNameDecl(TypedefNameDecl *D, bool IsAlias);
Douglas Gregor5fa74c32010-02-10 21:10:29 +0000135 Decl *VisitTypedefDecl(TypedefDecl *D);
Richard Smithdda56e42011-04-15 14:24:37 +0000136 Decl *VisitTypeAliasDecl(TypeAliasDecl *D);
Douglas Gregor98c10182010-02-12 22:17:39 +0000137 Decl *VisitEnumDecl(EnumDecl *D);
Douglas Gregor5c73e912010-02-11 00:48:18 +0000138 Decl *VisitRecordDecl(RecordDecl *D);
Douglas Gregor98c10182010-02-12 22:17:39 +0000139 Decl *VisitEnumConstantDecl(EnumConstantDecl *D);
Douglas Gregorbb7930c2010-02-10 19:54:31 +0000140 Decl *VisitFunctionDecl(FunctionDecl *D);
Douglas Gregor00eace12010-02-21 18:29:16 +0000141 Decl *VisitCXXMethodDecl(CXXMethodDecl *D);
142 Decl *VisitCXXConstructorDecl(CXXConstructorDecl *D);
143 Decl *VisitCXXDestructorDecl(CXXDestructorDecl *D);
144 Decl *VisitCXXConversionDecl(CXXConversionDecl *D);
Douglas Gregor5c73e912010-02-11 00:48:18 +0000145 Decl *VisitFieldDecl(FieldDecl *D);
Francois Pichet783dd6e2010-11-21 06:08:52 +0000146 Decl *VisitIndirectFieldDecl(IndirectFieldDecl *D);
Douglas Gregor7244b0b2010-02-17 00:34:30 +0000147 Decl *VisitObjCIvarDecl(ObjCIvarDecl *D);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +0000148 Decl *VisitVarDecl(VarDecl *D);
Douglas Gregor8b228d72010-02-17 21:22:52 +0000149 Decl *VisitImplicitParamDecl(ImplicitParamDecl *D);
Douglas Gregorbb7930c2010-02-10 19:54:31 +0000150 Decl *VisitParmVarDecl(ParmVarDecl *D);
Douglas Gregor43f54792010-02-17 02:12:47 +0000151 Decl *VisitObjCMethodDecl(ObjCMethodDecl *D);
Douglas Gregor84c51c32010-02-18 01:47:50 +0000152 Decl *VisitObjCCategoryDecl(ObjCCategoryDecl *D);
Douglas Gregor98d156a2010-02-17 16:12:00 +0000153 Decl *VisitObjCProtocolDecl(ObjCProtocolDecl *D);
Douglas Gregor45635322010-02-16 01:20:57 +0000154 Decl *VisitObjCInterfaceDecl(ObjCInterfaceDecl *D);
Douglas Gregor4da9d682010-12-07 15:32:12 +0000155 Decl *VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D);
Douglas Gregorda8025c2010-12-07 01:26:03 +0000156 Decl *VisitObjCImplementationDecl(ObjCImplementationDecl *D);
Douglas Gregora11c4582010-02-17 18:02:10 +0000157 Decl *VisitObjCPropertyDecl(ObjCPropertyDecl *D);
Douglas Gregor14a49e22010-12-07 18:32:03 +0000158 Decl *VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D);
Douglas Gregora082a492010-11-30 19:14:50 +0000159 Decl *VisitTemplateTypeParmDecl(TemplateTypeParmDecl *D);
160 Decl *VisitNonTypeTemplateParmDecl(NonTypeTemplateParmDecl *D);
161 Decl *VisitTemplateTemplateParmDecl(TemplateTemplateParmDecl *D);
162 Decl *VisitClassTemplateDecl(ClassTemplateDecl *D);
Douglas Gregore2e50d332010-12-01 01:36:18 +0000163 Decl *VisitClassTemplateSpecializationDecl(
164 ClassTemplateSpecializationDecl *D);
Larisse Voufo39a1e502013-08-06 01:03:05 +0000165 Decl *VisitVarTemplateDecl(VarTemplateDecl *D);
166 Decl *VisitVarTemplateSpecializationDecl(VarTemplateSpecializationDecl *D);
167
Douglas Gregor7eeb5972010-02-11 19:21:55 +0000168 // Importing statements
169 Stmt *VisitStmt(Stmt *S);
170
171 // Importing expressions
172 Expr *VisitExpr(Expr *E);
Douglas Gregor52f820e2010-02-19 01:17:02 +0000173 Expr *VisitDeclRefExpr(DeclRefExpr *E);
Douglas Gregor7eeb5972010-02-11 19:21:55 +0000174 Expr *VisitIntegerLiteral(IntegerLiteral *E);
Douglas Gregor623421d2010-02-18 02:21:22 +0000175 Expr *VisitCharacterLiteral(CharacterLiteral *E);
Douglas Gregorc74247e2010-02-19 01:07:06 +0000176 Expr *VisitParenExpr(ParenExpr *E);
177 Expr *VisitUnaryOperator(UnaryOperator *E);
Peter Collingbournee190dee2011-03-11 19:24:49 +0000178 Expr *VisitUnaryExprOrTypeTraitExpr(UnaryExprOrTypeTraitExpr *E);
Douglas Gregorc74247e2010-02-19 01:07:06 +0000179 Expr *VisitBinaryOperator(BinaryOperator *E);
180 Expr *VisitCompoundAssignOperator(CompoundAssignOperator *E);
Douglas Gregor98c10182010-02-12 22:17:39 +0000181 Expr *VisitImplicitCastExpr(ImplicitCastExpr *E);
Douglas Gregor5481d322010-02-19 01:32:14 +0000182 Expr *VisitCStyleCastExpr(CStyleCastExpr *E);
Douglas Gregor96e578d2010-02-05 17:54:41 +0000183 };
184}
Douglas Gregor3c2404b2011-11-03 18:07:07 +0000185using namespace clang;
Douglas Gregor96e578d2010-02-05 17:54:41 +0000186
187//----------------------------------------------------------------------------
Douglas Gregor3996e242010-02-15 22:01:00 +0000188// Structural Equivalence
189//----------------------------------------------------------------------------
190
191namespace {
192 struct StructuralEquivalenceContext {
193 /// \brief AST contexts for which we are checking structural equivalence.
194 ASTContext &C1, &C2;
195
Douglas Gregor3996e242010-02-15 22:01:00 +0000196 /// \brief The set of "tentative" equivalences between two canonical
197 /// declarations, mapping from a declaration in the first context to the
198 /// declaration in the second context that we believe to be equivalent.
199 llvm::DenseMap<Decl *, Decl *> TentativeEquivalences;
200
201 /// \brief Queue of declarations in the first context whose equivalence
202 /// with a declaration in the second context still needs to be verified.
203 std::deque<Decl *> DeclsToCheck;
204
Douglas Gregorb4964f72010-02-15 23:54:17 +0000205 /// \brief Declaration (from, to) pairs that are known not to be equivalent
206 /// (which we have already complained about).
207 llvm::DenseSet<std::pair<Decl *, Decl *> > &NonEquivalentDecls;
208
Douglas Gregor3996e242010-02-15 22:01:00 +0000209 /// \brief Whether we're being strict about the spelling of types when
210 /// unifying two types.
211 bool StrictTypeSpelling;
Douglas Gregordd6006f2012-07-17 21:16:27 +0000212
213 /// \brief Whether to complain about failures.
214 bool Complain;
215
Richard Smith5bb4cdf2012-12-20 02:22:15 +0000216 /// \brief \c true if the last diagnostic came from C2.
217 bool LastDiagFromC2;
218
Douglas Gregor3996e242010-02-15 22:01:00 +0000219 StructuralEquivalenceContext(ASTContext &C1, ASTContext &C2,
Douglas Gregorb4964f72010-02-15 23:54:17 +0000220 llvm::DenseSet<std::pair<Decl *, Decl *> > &NonEquivalentDecls,
Douglas Gregordd6006f2012-07-17 21:16:27 +0000221 bool StrictTypeSpelling = false,
222 bool Complain = true)
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +0000223 : C1(C1), C2(C2), NonEquivalentDecls(NonEquivalentDecls),
Richard Smith5bb4cdf2012-12-20 02:22:15 +0000224 StrictTypeSpelling(StrictTypeSpelling), Complain(Complain),
225 LastDiagFromC2(false) {}
Douglas Gregor3996e242010-02-15 22:01:00 +0000226
227 /// \brief Determine whether the two declarations are structurally
228 /// equivalent.
229 bool IsStructurallyEquivalent(Decl *D1, Decl *D2);
230
231 /// \brief Determine whether the two types are structurally equivalent.
232 bool IsStructurallyEquivalent(QualType T1, QualType T2);
233
234 private:
235 /// \brief Finish checking all of the structural equivalences.
236 ///
237 /// \returns true if an error occurred, false otherwise.
238 bool Finish();
239
240 public:
241 DiagnosticBuilder Diag1(SourceLocation Loc, unsigned DiagID) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000242 assert(Complain && "Not allowed to complain");
Richard Smith5bb4cdf2012-12-20 02:22:15 +0000243 if (LastDiagFromC2)
244 C1.getDiagnostics().notePriorDiagnosticFrom(C2.getDiagnostics());
245 LastDiagFromC2 = false;
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +0000246 return C1.getDiagnostics().Report(Loc, DiagID);
Douglas Gregor3996e242010-02-15 22:01:00 +0000247 }
248
249 DiagnosticBuilder Diag2(SourceLocation Loc, unsigned DiagID) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000250 assert(Complain && "Not allowed to complain");
Richard Smith5bb4cdf2012-12-20 02:22:15 +0000251 if (!LastDiagFromC2)
252 C2.getDiagnostics().notePriorDiagnosticFrom(C1.getDiagnostics());
253 LastDiagFromC2 = true;
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +0000254 return C2.getDiagnostics().Report(Loc, DiagID);
Douglas Gregor3996e242010-02-15 22:01:00 +0000255 }
256 };
257}
258
259static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
260 QualType T1, QualType T2);
261static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
262 Decl *D1, Decl *D2);
263
Douglas Gregor3996e242010-02-15 22:01:00 +0000264/// \brief Determine structural equivalence of two expressions.
265static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
266 Expr *E1, Expr *E2) {
267 if (!E1 || !E2)
268 return E1 == E2;
269
270 // FIXME: Actually perform a structural comparison!
271 return true;
272}
273
274/// \brief Determine whether two identifiers are equivalent.
275static bool IsStructurallyEquivalent(const IdentifierInfo *Name1,
276 const IdentifierInfo *Name2) {
277 if (!Name1 || !Name2)
278 return Name1 == Name2;
279
280 return Name1->getName() == Name2->getName();
281}
282
283/// \brief Determine whether two nested-name-specifiers are equivalent.
284static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
285 NestedNameSpecifier *NNS1,
286 NestedNameSpecifier *NNS2) {
287 // FIXME: Implement!
288 return true;
289}
290
291/// \brief Determine whether two template arguments are equivalent.
292static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
293 const TemplateArgument &Arg1,
294 const TemplateArgument &Arg2) {
Douglas Gregore2e50d332010-12-01 01:36:18 +0000295 if (Arg1.getKind() != Arg2.getKind())
296 return false;
297
298 switch (Arg1.getKind()) {
299 case TemplateArgument::Null:
300 return true;
301
302 case TemplateArgument::Type:
303 return Context.IsStructurallyEquivalent(Arg1.getAsType(), Arg2.getAsType());
Eli Friedmanb826a002012-09-26 02:36:12 +0000304
Douglas Gregore2e50d332010-12-01 01:36:18 +0000305 case TemplateArgument::Integral:
306 if (!Context.IsStructurallyEquivalent(Arg1.getIntegralType(),
307 Arg2.getIntegralType()))
308 return false;
309
Eric Christopher6dcc3762012-07-15 00:23:57 +0000310 return llvm::APSInt::isSameValue(Arg1.getAsIntegral(), Arg2.getAsIntegral());
Douglas Gregore2e50d332010-12-01 01:36:18 +0000311
312 case TemplateArgument::Declaration:
313 return Context.IsStructurallyEquivalent(Arg1.getAsDecl(), Arg2.getAsDecl());
Eli Friedmanb826a002012-09-26 02:36:12 +0000314
315 case TemplateArgument::NullPtr:
316 return true; // FIXME: Is this correct?
317
Douglas Gregore2e50d332010-12-01 01:36:18 +0000318 case TemplateArgument::Template:
319 return IsStructurallyEquivalent(Context,
320 Arg1.getAsTemplate(),
321 Arg2.getAsTemplate());
Douglas Gregore4ff4b52011-01-05 18:58:31 +0000322
323 case TemplateArgument::TemplateExpansion:
324 return IsStructurallyEquivalent(Context,
325 Arg1.getAsTemplateOrTemplatePattern(),
326 Arg2.getAsTemplateOrTemplatePattern());
327
Douglas Gregore2e50d332010-12-01 01:36:18 +0000328 case TemplateArgument::Expression:
329 return IsStructurallyEquivalent(Context,
330 Arg1.getAsExpr(), Arg2.getAsExpr());
331
332 case TemplateArgument::Pack:
333 if (Arg1.pack_size() != Arg2.pack_size())
334 return false;
335
336 for (unsigned I = 0, N = Arg1.pack_size(); I != N; ++I)
337 if (!IsStructurallyEquivalent(Context,
338 Arg1.pack_begin()[I],
339 Arg2.pack_begin()[I]))
340 return false;
341
342 return true;
343 }
344
345 llvm_unreachable("Invalid template argument kind");
Douglas Gregor3996e242010-02-15 22:01:00 +0000346}
347
348/// \brief Determine structural equivalence for the common part of array
349/// types.
350static bool IsArrayStructurallyEquivalent(StructuralEquivalenceContext &Context,
351 const ArrayType *Array1,
352 const ArrayType *Array2) {
353 if (!IsStructurallyEquivalent(Context,
354 Array1->getElementType(),
355 Array2->getElementType()))
356 return false;
357 if (Array1->getSizeModifier() != Array2->getSizeModifier())
358 return false;
359 if (Array1->getIndexTypeQualifiers() != Array2->getIndexTypeQualifiers())
360 return false;
361
362 return true;
363}
364
365/// \brief Determine structural equivalence of two types.
366static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
367 QualType T1, QualType T2) {
368 if (T1.isNull() || T2.isNull())
369 return T1.isNull() && T2.isNull();
370
371 if (!Context.StrictTypeSpelling) {
372 // We aren't being strict about token-to-token equivalence of types,
373 // so map down to the canonical type.
374 T1 = Context.C1.getCanonicalType(T1);
375 T2 = Context.C2.getCanonicalType(T2);
376 }
377
378 if (T1.getQualifiers() != T2.getQualifiers())
379 return false;
380
Douglas Gregorb4964f72010-02-15 23:54:17 +0000381 Type::TypeClass TC = T1->getTypeClass();
Douglas Gregor3996e242010-02-15 22:01:00 +0000382
Douglas Gregorb4964f72010-02-15 23:54:17 +0000383 if (T1->getTypeClass() != T2->getTypeClass()) {
384 // Compare function types with prototypes vs. without prototypes as if
385 // both did not have prototypes.
386 if (T1->getTypeClass() == Type::FunctionProto &&
387 T2->getTypeClass() == Type::FunctionNoProto)
388 TC = Type::FunctionNoProto;
389 else if (T1->getTypeClass() == Type::FunctionNoProto &&
390 T2->getTypeClass() == Type::FunctionProto)
391 TC = Type::FunctionNoProto;
392 else
393 return false;
394 }
395
396 switch (TC) {
397 case Type::Builtin:
Douglas Gregor3996e242010-02-15 22:01:00 +0000398 // FIXME: Deal with Char_S/Char_U.
399 if (cast<BuiltinType>(T1)->getKind() != cast<BuiltinType>(T2)->getKind())
400 return false;
401 break;
402
403 case Type::Complex:
404 if (!IsStructurallyEquivalent(Context,
405 cast<ComplexType>(T1)->getElementType(),
406 cast<ComplexType>(T2)->getElementType()))
407 return false;
408 break;
409
Reid Kleckner0503a872013-12-05 01:23:43 +0000410 case Type::Adjusted:
Reid Kleckner8a365022013-06-24 17:51:48 +0000411 case Type::Decayed:
412 if (!IsStructurallyEquivalent(Context,
Reid Kleckner0503a872013-12-05 01:23:43 +0000413 cast<AdjustedType>(T1)->getOriginalType(),
414 cast<AdjustedType>(T2)->getOriginalType()))
Reid Kleckner8a365022013-06-24 17:51:48 +0000415 return false;
416 break;
417
Douglas Gregor3996e242010-02-15 22:01:00 +0000418 case Type::Pointer:
419 if (!IsStructurallyEquivalent(Context,
420 cast<PointerType>(T1)->getPointeeType(),
421 cast<PointerType>(T2)->getPointeeType()))
422 return false;
423 break;
424
425 case Type::BlockPointer:
426 if (!IsStructurallyEquivalent(Context,
427 cast<BlockPointerType>(T1)->getPointeeType(),
428 cast<BlockPointerType>(T2)->getPointeeType()))
429 return false;
430 break;
431
432 case Type::LValueReference:
433 case Type::RValueReference: {
434 const ReferenceType *Ref1 = cast<ReferenceType>(T1);
435 const ReferenceType *Ref2 = cast<ReferenceType>(T2);
436 if (Ref1->isSpelledAsLValue() != Ref2->isSpelledAsLValue())
437 return false;
438 if (Ref1->isInnerRef() != Ref2->isInnerRef())
439 return false;
440 if (!IsStructurallyEquivalent(Context,
441 Ref1->getPointeeTypeAsWritten(),
442 Ref2->getPointeeTypeAsWritten()))
443 return false;
444 break;
445 }
446
447 case Type::MemberPointer: {
448 const MemberPointerType *MemPtr1 = cast<MemberPointerType>(T1);
449 const MemberPointerType *MemPtr2 = cast<MemberPointerType>(T2);
450 if (!IsStructurallyEquivalent(Context,
451 MemPtr1->getPointeeType(),
452 MemPtr2->getPointeeType()))
453 return false;
454 if (!IsStructurallyEquivalent(Context,
455 QualType(MemPtr1->getClass(), 0),
456 QualType(MemPtr2->getClass(), 0)))
457 return false;
458 break;
459 }
460
461 case Type::ConstantArray: {
462 const ConstantArrayType *Array1 = cast<ConstantArrayType>(T1);
463 const ConstantArrayType *Array2 = cast<ConstantArrayType>(T2);
Eric Christopher6dcc3762012-07-15 00:23:57 +0000464 if (!llvm::APInt::isSameValue(Array1->getSize(), Array2->getSize()))
Douglas Gregor3996e242010-02-15 22:01:00 +0000465 return false;
466
467 if (!IsArrayStructurallyEquivalent(Context, Array1, Array2))
468 return false;
469 break;
470 }
471
472 case Type::IncompleteArray:
473 if (!IsArrayStructurallyEquivalent(Context,
474 cast<ArrayType>(T1),
475 cast<ArrayType>(T2)))
476 return false;
477 break;
478
479 case Type::VariableArray: {
480 const VariableArrayType *Array1 = cast<VariableArrayType>(T1);
481 const VariableArrayType *Array2 = cast<VariableArrayType>(T2);
482 if (!IsStructurallyEquivalent(Context,
483 Array1->getSizeExpr(), Array2->getSizeExpr()))
484 return false;
485
486 if (!IsArrayStructurallyEquivalent(Context, Array1, Array2))
487 return false;
488
489 break;
490 }
491
492 case Type::DependentSizedArray: {
493 const DependentSizedArrayType *Array1 = cast<DependentSizedArrayType>(T1);
494 const DependentSizedArrayType *Array2 = cast<DependentSizedArrayType>(T2);
495 if (!IsStructurallyEquivalent(Context,
496 Array1->getSizeExpr(), Array2->getSizeExpr()))
497 return false;
498
499 if (!IsArrayStructurallyEquivalent(Context, Array1, Array2))
500 return false;
501
502 break;
503 }
504
505 case Type::DependentSizedExtVector: {
506 const DependentSizedExtVectorType *Vec1
507 = cast<DependentSizedExtVectorType>(T1);
508 const DependentSizedExtVectorType *Vec2
509 = cast<DependentSizedExtVectorType>(T2);
510 if (!IsStructurallyEquivalent(Context,
511 Vec1->getSizeExpr(), Vec2->getSizeExpr()))
512 return false;
513 if (!IsStructurallyEquivalent(Context,
514 Vec1->getElementType(),
515 Vec2->getElementType()))
516 return false;
517 break;
518 }
519
520 case Type::Vector:
521 case Type::ExtVector: {
522 const VectorType *Vec1 = cast<VectorType>(T1);
523 const VectorType *Vec2 = cast<VectorType>(T2);
524 if (!IsStructurallyEquivalent(Context,
525 Vec1->getElementType(),
526 Vec2->getElementType()))
527 return false;
528 if (Vec1->getNumElements() != Vec2->getNumElements())
529 return false;
Bob Wilsonaeb56442010-11-10 21:56:12 +0000530 if (Vec1->getVectorKind() != Vec2->getVectorKind())
Douglas Gregor3996e242010-02-15 22:01:00 +0000531 return false;
Douglas Gregor01cc4372010-02-19 01:36:36 +0000532 break;
Douglas Gregor3996e242010-02-15 22:01:00 +0000533 }
534
535 case Type::FunctionProto: {
536 const FunctionProtoType *Proto1 = cast<FunctionProtoType>(T1);
537 const FunctionProtoType *Proto2 = cast<FunctionProtoType>(T2);
Alp Toker9cacbab2014-01-20 20:26:09 +0000538 if (Proto1->getNumParams() != Proto2->getNumParams())
Douglas Gregor3996e242010-02-15 22:01:00 +0000539 return false;
Alp Toker9cacbab2014-01-20 20:26:09 +0000540 for (unsigned I = 0, N = Proto1->getNumParams(); I != N; ++I) {
541 if (!IsStructurallyEquivalent(Context, Proto1->getParamType(I),
542 Proto2->getParamType(I)))
Douglas Gregor3996e242010-02-15 22:01:00 +0000543 return false;
544 }
545 if (Proto1->isVariadic() != Proto2->isVariadic())
546 return false;
Sebastian Redlfa453cf2011-03-12 11:50:43 +0000547 if (Proto1->getExceptionSpecType() != Proto2->getExceptionSpecType())
Douglas Gregor3996e242010-02-15 22:01:00 +0000548 return false;
Sebastian Redlfa453cf2011-03-12 11:50:43 +0000549 if (Proto1->getExceptionSpecType() == EST_Dynamic) {
550 if (Proto1->getNumExceptions() != Proto2->getNumExceptions())
551 return false;
552 for (unsigned I = 0, N = Proto1->getNumExceptions(); I != N; ++I) {
553 if (!IsStructurallyEquivalent(Context,
554 Proto1->getExceptionType(I),
555 Proto2->getExceptionType(I)))
556 return false;
557 }
558 } else if (Proto1->getExceptionSpecType() == EST_ComputedNoexcept) {
Douglas Gregor3996e242010-02-15 22:01:00 +0000559 if (!IsStructurallyEquivalent(Context,
Sebastian Redlfa453cf2011-03-12 11:50:43 +0000560 Proto1->getNoexceptExpr(),
561 Proto2->getNoexceptExpr()))
Douglas Gregor3996e242010-02-15 22:01:00 +0000562 return false;
563 }
564 if (Proto1->getTypeQuals() != Proto2->getTypeQuals())
565 return false;
566
567 // Fall through to check the bits common with FunctionNoProtoType.
568 }
569
570 case Type::FunctionNoProto: {
571 const FunctionType *Function1 = cast<FunctionType>(T1);
572 const FunctionType *Function2 = cast<FunctionType>(T2);
573 if (!IsStructurallyEquivalent(Context,
574 Function1->getResultType(),
575 Function2->getResultType()))
576 return false;
Rafael Espindolac50c27c2010-03-30 20:24:48 +0000577 if (Function1->getExtInfo() != Function2->getExtInfo())
578 return false;
Douglas Gregor3996e242010-02-15 22:01:00 +0000579 break;
580 }
581
582 case Type::UnresolvedUsing:
583 if (!IsStructurallyEquivalent(Context,
584 cast<UnresolvedUsingType>(T1)->getDecl(),
585 cast<UnresolvedUsingType>(T2)->getDecl()))
586 return false;
587
588 break;
John McCall81904512011-01-06 01:58:22 +0000589
590 case Type::Attributed:
591 if (!IsStructurallyEquivalent(Context,
592 cast<AttributedType>(T1)->getModifiedType(),
593 cast<AttributedType>(T2)->getModifiedType()))
594 return false;
595 if (!IsStructurallyEquivalent(Context,
596 cast<AttributedType>(T1)->getEquivalentType(),
597 cast<AttributedType>(T2)->getEquivalentType()))
598 return false;
599 break;
Douglas Gregor3996e242010-02-15 22:01:00 +0000600
Abramo Bagnara924a8f32010-12-10 16:29:40 +0000601 case Type::Paren:
602 if (!IsStructurallyEquivalent(Context,
603 cast<ParenType>(T1)->getInnerType(),
604 cast<ParenType>(T2)->getInnerType()))
605 return false;
606 break;
607
Douglas Gregor3996e242010-02-15 22:01:00 +0000608 case Type::Typedef:
609 if (!IsStructurallyEquivalent(Context,
610 cast<TypedefType>(T1)->getDecl(),
611 cast<TypedefType>(T2)->getDecl()))
612 return false;
613 break;
614
615 case Type::TypeOfExpr:
616 if (!IsStructurallyEquivalent(Context,
617 cast<TypeOfExprType>(T1)->getUnderlyingExpr(),
618 cast<TypeOfExprType>(T2)->getUnderlyingExpr()))
619 return false;
620 break;
621
622 case Type::TypeOf:
623 if (!IsStructurallyEquivalent(Context,
624 cast<TypeOfType>(T1)->getUnderlyingType(),
625 cast<TypeOfType>(T2)->getUnderlyingType()))
626 return false;
627 break;
Alexis Hunte852b102011-05-24 22:41:36 +0000628
629 case Type::UnaryTransform:
630 if (!IsStructurallyEquivalent(Context,
631 cast<UnaryTransformType>(T1)->getUnderlyingType(),
632 cast<UnaryTransformType>(T1)->getUnderlyingType()))
633 return false;
634 break;
635
Douglas Gregor3996e242010-02-15 22:01:00 +0000636 case Type::Decltype:
637 if (!IsStructurallyEquivalent(Context,
638 cast<DecltypeType>(T1)->getUnderlyingExpr(),
639 cast<DecltypeType>(T2)->getUnderlyingExpr()))
640 return false;
641 break;
642
Richard Smith30482bc2011-02-20 03:19:35 +0000643 case Type::Auto:
644 if (!IsStructurallyEquivalent(Context,
645 cast<AutoType>(T1)->getDeducedType(),
646 cast<AutoType>(T2)->getDeducedType()))
647 return false;
648 break;
649
Douglas Gregor3996e242010-02-15 22:01:00 +0000650 case Type::Record:
651 case Type::Enum:
652 if (!IsStructurallyEquivalent(Context,
653 cast<TagType>(T1)->getDecl(),
654 cast<TagType>(T2)->getDecl()))
655 return false;
656 break;
Abramo Bagnara6150c882010-05-11 21:36:43 +0000657
Douglas Gregor3996e242010-02-15 22:01:00 +0000658 case Type::TemplateTypeParm: {
659 const TemplateTypeParmType *Parm1 = cast<TemplateTypeParmType>(T1);
660 const TemplateTypeParmType *Parm2 = cast<TemplateTypeParmType>(T2);
661 if (Parm1->getDepth() != Parm2->getDepth())
662 return false;
663 if (Parm1->getIndex() != Parm2->getIndex())
664 return false;
665 if (Parm1->isParameterPack() != Parm2->isParameterPack())
666 return false;
667
668 // Names of template type parameters are never significant.
669 break;
670 }
671
672 case Type::SubstTemplateTypeParm: {
673 const SubstTemplateTypeParmType *Subst1
674 = cast<SubstTemplateTypeParmType>(T1);
675 const SubstTemplateTypeParmType *Subst2
676 = cast<SubstTemplateTypeParmType>(T2);
677 if (!IsStructurallyEquivalent(Context,
678 QualType(Subst1->getReplacedParameter(), 0),
679 QualType(Subst2->getReplacedParameter(), 0)))
680 return false;
681 if (!IsStructurallyEquivalent(Context,
682 Subst1->getReplacementType(),
683 Subst2->getReplacementType()))
684 return false;
685 break;
686 }
687
Douglas Gregorfb322d82011-01-14 05:11:40 +0000688 case Type::SubstTemplateTypeParmPack: {
689 const SubstTemplateTypeParmPackType *Subst1
690 = cast<SubstTemplateTypeParmPackType>(T1);
691 const SubstTemplateTypeParmPackType *Subst2
692 = cast<SubstTemplateTypeParmPackType>(T2);
693 if (!IsStructurallyEquivalent(Context,
694 QualType(Subst1->getReplacedParameter(), 0),
695 QualType(Subst2->getReplacedParameter(), 0)))
696 return false;
697 if (!IsStructurallyEquivalent(Context,
698 Subst1->getArgumentPack(),
699 Subst2->getArgumentPack()))
700 return false;
701 break;
702 }
Douglas Gregor3996e242010-02-15 22:01:00 +0000703 case Type::TemplateSpecialization: {
704 const TemplateSpecializationType *Spec1
705 = cast<TemplateSpecializationType>(T1);
706 const TemplateSpecializationType *Spec2
707 = cast<TemplateSpecializationType>(T2);
708 if (!IsStructurallyEquivalent(Context,
709 Spec1->getTemplateName(),
710 Spec2->getTemplateName()))
711 return false;
712 if (Spec1->getNumArgs() != Spec2->getNumArgs())
713 return false;
714 for (unsigned I = 0, N = Spec1->getNumArgs(); I != N; ++I) {
715 if (!IsStructurallyEquivalent(Context,
716 Spec1->getArg(I), Spec2->getArg(I)))
717 return false;
718 }
719 break;
720 }
721
Abramo Bagnara6150c882010-05-11 21:36:43 +0000722 case Type::Elaborated: {
723 const ElaboratedType *Elab1 = cast<ElaboratedType>(T1);
724 const ElaboratedType *Elab2 = cast<ElaboratedType>(T2);
725 // CHECKME: what if a keyword is ETK_None or ETK_typename ?
726 if (Elab1->getKeyword() != Elab2->getKeyword())
727 return false;
Douglas Gregor3996e242010-02-15 22:01:00 +0000728 if (!IsStructurallyEquivalent(Context,
Abramo Bagnara6150c882010-05-11 21:36:43 +0000729 Elab1->getQualifier(),
730 Elab2->getQualifier()))
Douglas Gregor3996e242010-02-15 22:01:00 +0000731 return false;
732 if (!IsStructurallyEquivalent(Context,
Abramo Bagnara6150c882010-05-11 21:36:43 +0000733 Elab1->getNamedType(),
734 Elab2->getNamedType()))
Douglas Gregor3996e242010-02-15 22:01:00 +0000735 return false;
736 break;
737 }
738
John McCalle78aac42010-03-10 03:28:59 +0000739 case Type::InjectedClassName: {
740 const InjectedClassNameType *Inj1 = cast<InjectedClassNameType>(T1);
741 const InjectedClassNameType *Inj2 = cast<InjectedClassNameType>(T2);
742 if (!IsStructurallyEquivalent(Context,
John McCall2408e322010-04-27 00:57:59 +0000743 Inj1->getInjectedSpecializationType(),
744 Inj2->getInjectedSpecializationType()))
John McCalle78aac42010-03-10 03:28:59 +0000745 return false;
746 break;
747 }
748
Douglas Gregorc1d2d8a2010-03-31 17:34:00 +0000749 case Type::DependentName: {
750 const DependentNameType *Typename1 = cast<DependentNameType>(T1);
751 const DependentNameType *Typename2 = cast<DependentNameType>(T2);
Douglas Gregor3996e242010-02-15 22:01:00 +0000752 if (!IsStructurallyEquivalent(Context,
753 Typename1->getQualifier(),
754 Typename2->getQualifier()))
755 return false;
756 if (!IsStructurallyEquivalent(Typename1->getIdentifier(),
757 Typename2->getIdentifier()))
758 return false;
Douglas Gregor3996e242010-02-15 22:01:00 +0000759
760 break;
761 }
762
John McCallc392f372010-06-11 00:33:02 +0000763 case Type::DependentTemplateSpecialization: {
764 const DependentTemplateSpecializationType *Spec1 =
765 cast<DependentTemplateSpecializationType>(T1);
766 const DependentTemplateSpecializationType *Spec2 =
767 cast<DependentTemplateSpecializationType>(T2);
768 if (!IsStructurallyEquivalent(Context,
769 Spec1->getQualifier(),
770 Spec2->getQualifier()))
771 return false;
772 if (!IsStructurallyEquivalent(Spec1->getIdentifier(),
773 Spec2->getIdentifier()))
774 return false;
775 if (Spec1->getNumArgs() != Spec2->getNumArgs())
776 return false;
777 for (unsigned I = 0, N = Spec1->getNumArgs(); I != N; ++I) {
778 if (!IsStructurallyEquivalent(Context,
779 Spec1->getArg(I), Spec2->getArg(I)))
780 return false;
781 }
782 break;
783 }
Douglas Gregord2fa7662010-12-20 02:24:11 +0000784
785 case Type::PackExpansion:
786 if (!IsStructurallyEquivalent(Context,
787 cast<PackExpansionType>(T1)->getPattern(),
788 cast<PackExpansionType>(T2)->getPattern()))
789 return false;
790 break;
791
Douglas Gregor3996e242010-02-15 22:01:00 +0000792 case Type::ObjCInterface: {
793 const ObjCInterfaceType *Iface1 = cast<ObjCInterfaceType>(T1);
794 const ObjCInterfaceType *Iface2 = cast<ObjCInterfaceType>(T2);
795 if (!IsStructurallyEquivalent(Context,
796 Iface1->getDecl(), Iface2->getDecl()))
797 return false;
John McCall8b07ec22010-05-15 11:32:37 +0000798 break;
799 }
800
801 case Type::ObjCObject: {
802 const ObjCObjectType *Obj1 = cast<ObjCObjectType>(T1);
803 const ObjCObjectType *Obj2 = cast<ObjCObjectType>(T2);
804 if (!IsStructurallyEquivalent(Context,
805 Obj1->getBaseType(),
806 Obj2->getBaseType()))
Douglas Gregor3996e242010-02-15 22:01:00 +0000807 return false;
John McCall8b07ec22010-05-15 11:32:37 +0000808 if (Obj1->getNumProtocols() != Obj2->getNumProtocols())
809 return false;
810 for (unsigned I = 0, N = Obj1->getNumProtocols(); I != N; ++I) {
Douglas Gregor3996e242010-02-15 22:01:00 +0000811 if (!IsStructurallyEquivalent(Context,
John McCall8b07ec22010-05-15 11:32:37 +0000812 Obj1->getProtocol(I),
813 Obj2->getProtocol(I)))
Douglas Gregor3996e242010-02-15 22:01:00 +0000814 return false;
815 }
816 break;
817 }
818
819 case Type::ObjCObjectPointer: {
820 const ObjCObjectPointerType *Ptr1 = cast<ObjCObjectPointerType>(T1);
821 const ObjCObjectPointerType *Ptr2 = cast<ObjCObjectPointerType>(T2);
822 if (!IsStructurallyEquivalent(Context,
823 Ptr1->getPointeeType(),
824 Ptr2->getPointeeType()))
825 return false;
Douglas Gregor3996e242010-02-15 22:01:00 +0000826 break;
827 }
Eli Friedman0dfb8892011-10-06 23:00:33 +0000828
829 case Type::Atomic: {
830 if (!IsStructurallyEquivalent(Context,
831 cast<AtomicType>(T1)->getValueType(),
832 cast<AtomicType>(T2)->getValueType()))
833 return false;
834 break;
835 }
836
Douglas Gregor3996e242010-02-15 22:01:00 +0000837 } // end switch
838
839 return true;
840}
841
Douglas Gregor03d1ed32011-10-14 21:54:42 +0000842/// \brief Determine structural equivalence of two fields.
843static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
844 FieldDecl *Field1, FieldDecl *Field2) {
845 RecordDecl *Owner2 = cast<RecordDecl>(Field2->getDeclContext());
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000846
847 // For anonymous structs/unions, match up the anonymous struct/union type
848 // declarations directly, so that we don't go off searching for anonymous
849 // types
850 if (Field1->isAnonymousStructOrUnion() &&
851 Field2->isAnonymousStructOrUnion()) {
852 RecordDecl *D1 = Field1->getType()->castAs<RecordType>()->getDecl();
853 RecordDecl *D2 = Field2->getType()->castAs<RecordType>()->getDecl();
854 return IsStructurallyEquivalent(Context, D1, D2);
855 }
Sean Callanan969c5bd2013-04-26 22:49:25 +0000856
857 // Check for equivalent field names.
858 IdentifierInfo *Name1 = Field1->getIdentifier();
859 IdentifierInfo *Name2 = Field2->getIdentifier();
860 if (!::IsStructurallyEquivalent(Name1, Name2))
861 return false;
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000862
863 if (!IsStructurallyEquivalent(Context,
Douglas Gregor03d1ed32011-10-14 21:54:42 +0000864 Field1->getType(), Field2->getType())) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000865 if (Context.Complain) {
866 Context.Diag2(Owner2->getLocation(), diag::warn_odr_tag_type_inconsistent)
867 << Context.C2.getTypeDeclType(Owner2);
868 Context.Diag2(Field2->getLocation(), diag::note_odr_field)
869 << Field2->getDeclName() << Field2->getType();
870 Context.Diag1(Field1->getLocation(), diag::note_odr_field)
871 << Field1->getDeclName() << Field1->getType();
872 }
Douglas Gregor03d1ed32011-10-14 21:54:42 +0000873 return false;
874 }
875
876 if (Field1->isBitField() != Field2->isBitField()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000877 if (Context.Complain) {
878 Context.Diag2(Owner2->getLocation(), diag::warn_odr_tag_type_inconsistent)
879 << Context.C2.getTypeDeclType(Owner2);
880 if (Field1->isBitField()) {
881 Context.Diag1(Field1->getLocation(), diag::note_odr_bit_field)
882 << Field1->getDeclName() << Field1->getType()
883 << Field1->getBitWidthValue(Context.C1);
884 Context.Diag2(Field2->getLocation(), diag::note_odr_not_bit_field)
885 << Field2->getDeclName();
886 } else {
887 Context.Diag2(Field2->getLocation(), diag::note_odr_bit_field)
888 << Field2->getDeclName() << Field2->getType()
889 << Field2->getBitWidthValue(Context.C2);
890 Context.Diag1(Field1->getLocation(), diag::note_odr_not_bit_field)
891 << Field1->getDeclName();
892 }
Douglas Gregor03d1ed32011-10-14 21:54:42 +0000893 }
894 return false;
895 }
896
897 if (Field1->isBitField()) {
898 // Make sure that the bit-fields are the same length.
899 unsigned Bits1 = Field1->getBitWidthValue(Context.C1);
900 unsigned Bits2 = Field2->getBitWidthValue(Context.C2);
901
902 if (Bits1 != Bits2) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000903 if (Context.Complain) {
904 Context.Diag2(Owner2->getLocation(), diag::warn_odr_tag_type_inconsistent)
905 << Context.C2.getTypeDeclType(Owner2);
906 Context.Diag2(Field2->getLocation(), diag::note_odr_bit_field)
907 << Field2->getDeclName() << Field2->getType() << Bits2;
908 Context.Diag1(Field1->getLocation(), diag::note_odr_bit_field)
909 << Field1->getDeclName() << Field1->getType() << Bits1;
910 }
Douglas Gregor03d1ed32011-10-14 21:54:42 +0000911 return false;
912 }
913 }
914
915 return true;
916}
917
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000918/// \brief Find the index of the given anonymous struct/union within its
919/// context.
920///
921/// \returns Returns the index of this anonymous struct/union in its context,
922/// including the next assigned index (if none of them match). Returns an
923/// empty option if the context is not a record, i.e.. if the anonymous
924/// struct/union is at namespace or block scope.
David Blaikie05785d12013-02-20 22:23:23 +0000925static Optional<unsigned> findAnonymousStructOrUnionIndex(RecordDecl *Anon) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000926 ASTContext &Context = Anon->getASTContext();
927 QualType AnonTy = Context.getRecordType(Anon);
928
929 RecordDecl *Owner = dyn_cast<RecordDecl>(Anon->getDeclContext());
930 if (!Owner)
David Blaikie7a30dc52013-02-21 01:47:18 +0000931 return None;
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000932
933 unsigned Index = 0;
934 for (DeclContext::decl_iterator D = Owner->noload_decls_begin(),
935 DEnd = Owner->noload_decls_end();
936 D != DEnd; ++D) {
937 FieldDecl *F = dyn_cast<FieldDecl>(*D);
938 if (!F || !F->isAnonymousStructOrUnion())
939 continue;
940
941 if (Context.hasSameType(F->getType(), AnonTy))
942 break;
943
944 ++Index;
945 }
946
947 return Index;
948}
949
Douglas Gregor3996e242010-02-15 22:01:00 +0000950/// \brief Determine structural equivalence of two records.
951static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
952 RecordDecl *D1, RecordDecl *D2) {
953 if (D1->isUnion() != D2->isUnion()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +0000954 if (Context.Complain) {
955 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
956 << Context.C2.getTypeDeclType(D2);
957 Context.Diag1(D1->getLocation(), diag::note_odr_tag_kind_here)
958 << D1->getDeclName() << (unsigned)D1->getTagKind();
959 }
Douglas Gregor3996e242010-02-15 22:01:00 +0000960 return false;
961 }
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000962
963 if (D1->isAnonymousStructOrUnion() && D2->isAnonymousStructOrUnion()) {
964 // If both anonymous structs/unions are in a record context, make sure
965 // they occur in the same location in the context records.
David Blaikie05785d12013-02-20 22:23:23 +0000966 if (Optional<unsigned> Index1 = findAnonymousStructOrUnionIndex(D1)) {
967 if (Optional<unsigned> Index2 = findAnonymousStructOrUnionIndex(D2)) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +0000968 if (*Index1 != *Index2)
969 return false;
970 }
971 }
972 }
973
Douglas Gregore2e50d332010-12-01 01:36:18 +0000974 // If both declarations are class template specializations, we know
975 // the ODR applies, so check the template and template arguments.
976 ClassTemplateSpecializationDecl *Spec1
977 = dyn_cast<ClassTemplateSpecializationDecl>(D1);
978 ClassTemplateSpecializationDecl *Spec2
979 = dyn_cast<ClassTemplateSpecializationDecl>(D2);
980 if (Spec1 && Spec2) {
981 // Check that the specialized templates are the same.
982 if (!IsStructurallyEquivalent(Context, Spec1->getSpecializedTemplate(),
983 Spec2->getSpecializedTemplate()))
984 return false;
985
986 // Check that the template arguments are the same.
987 if (Spec1->getTemplateArgs().size() != Spec2->getTemplateArgs().size())
988 return false;
989
990 for (unsigned I = 0, N = Spec1->getTemplateArgs().size(); I != N; ++I)
991 if (!IsStructurallyEquivalent(Context,
992 Spec1->getTemplateArgs().get(I),
993 Spec2->getTemplateArgs().get(I)))
994 return false;
995 }
996 // If one is a class template specialization and the other is not, these
Chris Lattner57540c52011-04-15 05:22:18 +0000997 // structures are different.
Douglas Gregore2e50d332010-12-01 01:36:18 +0000998 else if (Spec1 || Spec2)
999 return false;
1000
Douglas Gregorb4964f72010-02-15 23:54:17 +00001001 // Compare the definitions of these two records. If either or both are
1002 // incomplete, we assume that they are equivalent.
1003 D1 = D1->getDefinition();
1004 D2 = D2->getDefinition();
1005 if (!D1 || !D2)
1006 return true;
1007
Douglas Gregor3996e242010-02-15 22:01:00 +00001008 if (CXXRecordDecl *D1CXX = dyn_cast<CXXRecordDecl>(D1)) {
1009 if (CXXRecordDecl *D2CXX = dyn_cast<CXXRecordDecl>(D2)) {
1010 if (D1CXX->getNumBases() != D2CXX->getNumBases()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001011 if (Context.Complain) {
1012 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1013 << Context.C2.getTypeDeclType(D2);
1014 Context.Diag2(D2->getLocation(), diag::note_odr_number_of_bases)
1015 << D2CXX->getNumBases();
1016 Context.Diag1(D1->getLocation(), diag::note_odr_number_of_bases)
1017 << D1CXX->getNumBases();
1018 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001019 return false;
1020 }
1021
1022 // Check the base classes.
1023 for (CXXRecordDecl::base_class_iterator Base1 = D1CXX->bases_begin(),
1024 BaseEnd1 = D1CXX->bases_end(),
1025 Base2 = D2CXX->bases_begin();
1026 Base1 != BaseEnd1;
1027 ++Base1, ++Base2) {
1028 if (!IsStructurallyEquivalent(Context,
1029 Base1->getType(), Base2->getType())) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001030 if (Context.Complain) {
1031 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1032 << Context.C2.getTypeDeclType(D2);
1033 Context.Diag2(Base2->getLocStart(), diag::note_odr_base)
1034 << Base2->getType()
1035 << Base2->getSourceRange();
1036 Context.Diag1(Base1->getLocStart(), diag::note_odr_base)
1037 << Base1->getType()
1038 << Base1->getSourceRange();
1039 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001040 return false;
1041 }
1042
1043 // Check virtual vs. non-virtual inheritance mismatch.
1044 if (Base1->isVirtual() != Base2->isVirtual()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001045 if (Context.Complain) {
1046 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1047 << Context.C2.getTypeDeclType(D2);
1048 Context.Diag2(Base2->getLocStart(),
1049 diag::note_odr_virtual_base)
1050 << Base2->isVirtual() << Base2->getSourceRange();
1051 Context.Diag1(Base1->getLocStart(), diag::note_odr_base)
1052 << Base1->isVirtual()
1053 << Base1->getSourceRange();
1054 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001055 return false;
1056 }
1057 }
1058 } else if (D1CXX->getNumBases() > 0) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001059 if (Context.Complain) {
1060 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1061 << Context.C2.getTypeDeclType(D2);
1062 const CXXBaseSpecifier *Base1 = D1CXX->bases_begin();
1063 Context.Diag1(Base1->getLocStart(), diag::note_odr_base)
1064 << Base1->getType()
1065 << Base1->getSourceRange();
1066 Context.Diag2(D2->getLocation(), diag::note_odr_missing_base);
1067 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001068 return false;
1069 }
1070 }
1071
1072 // Check the fields for consistency.
Dmitri Gribenko898cff02012-05-19 17:17:26 +00001073 RecordDecl::field_iterator Field2 = D2->field_begin(),
Douglas Gregor3996e242010-02-15 22:01:00 +00001074 Field2End = D2->field_end();
Dmitri Gribenko898cff02012-05-19 17:17:26 +00001075 for (RecordDecl::field_iterator Field1 = D1->field_begin(),
Douglas Gregor3996e242010-02-15 22:01:00 +00001076 Field1End = D1->field_end();
1077 Field1 != Field1End;
1078 ++Field1, ++Field2) {
1079 if (Field2 == Field2End) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001080 if (Context.Complain) {
1081 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1082 << Context.C2.getTypeDeclType(D2);
1083 Context.Diag1(Field1->getLocation(), diag::note_odr_field)
1084 << Field1->getDeclName() << Field1->getType();
1085 Context.Diag2(D2->getLocation(), diag::note_odr_missing_field);
1086 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001087 return false;
1088 }
1089
David Blaikie40ed2972012-06-06 20:45:41 +00001090 if (!IsStructurallyEquivalent(Context, *Field1, *Field2))
Douglas Gregor03d1ed32011-10-14 21:54:42 +00001091 return false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001092 }
1093
1094 if (Field2 != Field2End) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001095 if (Context.Complain) {
1096 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1097 << Context.C2.getTypeDeclType(D2);
1098 Context.Diag2(Field2->getLocation(), diag::note_odr_field)
1099 << Field2->getDeclName() << Field2->getType();
1100 Context.Diag1(D1->getLocation(), diag::note_odr_missing_field);
1101 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001102 return false;
1103 }
1104
1105 return true;
1106}
1107
1108/// \brief Determine structural equivalence of two enums.
1109static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1110 EnumDecl *D1, EnumDecl *D2) {
1111 EnumDecl::enumerator_iterator EC2 = D2->enumerator_begin(),
1112 EC2End = D2->enumerator_end();
1113 for (EnumDecl::enumerator_iterator EC1 = D1->enumerator_begin(),
1114 EC1End = D1->enumerator_end();
1115 EC1 != EC1End; ++EC1, ++EC2) {
1116 if (EC2 == EC2End) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001117 if (Context.Complain) {
1118 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1119 << Context.C2.getTypeDeclType(D2);
1120 Context.Diag1(EC1->getLocation(), diag::note_odr_enumerator)
1121 << EC1->getDeclName()
1122 << EC1->getInitVal().toString(10);
1123 Context.Diag2(D2->getLocation(), diag::note_odr_missing_enumerator);
1124 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001125 return false;
1126 }
1127
1128 llvm::APSInt Val1 = EC1->getInitVal();
1129 llvm::APSInt Val2 = EC2->getInitVal();
Eric Christopher6dcc3762012-07-15 00:23:57 +00001130 if (!llvm::APSInt::isSameValue(Val1, Val2) ||
Douglas Gregor3996e242010-02-15 22:01:00 +00001131 !IsStructurallyEquivalent(EC1->getIdentifier(), EC2->getIdentifier())) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001132 if (Context.Complain) {
1133 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1134 << Context.C2.getTypeDeclType(D2);
1135 Context.Diag2(EC2->getLocation(), diag::note_odr_enumerator)
1136 << EC2->getDeclName()
1137 << EC2->getInitVal().toString(10);
1138 Context.Diag1(EC1->getLocation(), diag::note_odr_enumerator)
1139 << EC1->getDeclName()
1140 << EC1->getInitVal().toString(10);
1141 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001142 return false;
1143 }
1144 }
1145
1146 if (EC2 != EC2End) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001147 if (Context.Complain) {
1148 Context.Diag2(D2->getLocation(), diag::warn_odr_tag_type_inconsistent)
1149 << Context.C2.getTypeDeclType(D2);
1150 Context.Diag2(EC2->getLocation(), diag::note_odr_enumerator)
1151 << EC2->getDeclName()
1152 << EC2->getInitVal().toString(10);
1153 Context.Diag1(D1->getLocation(), diag::note_odr_missing_enumerator);
1154 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001155 return false;
1156 }
1157
1158 return true;
1159}
Douglas Gregora082a492010-11-30 19:14:50 +00001160
1161static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1162 TemplateParameterList *Params1,
1163 TemplateParameterList *Params2) {
1164 if (Params1->size() != Params2->size()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001165 if (Context.Complain) {
1166 Context.Diag2(Params2->getTemplateLoc(),
1167 diag::err_odr_different_num_template_parameters)
1168 << Params1->size() << Params2->size();
1169 Context.Diag1(Params1->getTemplateLoc(),
1170 diag::note_odr_template_parameter_list);
1171 }
Douglas Gregora082a492010-11-30 19:14:50 +00001172 return false;
1173 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001174
Douglas Gregora082a492010-11-30 19:14:50 +00001175 for (unsigned I = 0, N = Params1->size(); I != N; ++I) {
1176 if (Params1->getParam(I)->getKind() != Params2->getParam(I)->getKind()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001177 if (Context.Complain) {
1178 Context.Diag2(Params2->getParam(I)->getLocation(),
1179 diag::err_odr_different_template_parameter_kind);
1180 Context.Diag1(Params1->getParam(I)->getLocation(),
1181 diag::note_odr_template_parameter_here);
1182 }
Douglas Gregora082a492010-11-30 19:14:50 +00001183 return false;
1184 }
1185
1186 if (!Context.IsStructurallyEquivalent(Params1->getParam(I),
1187 Params2->getParam(I))) {
1188
1189 return false;
1190 }
1191 }
1192
1193 return true;
1194}
1195
1196static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1197 TemplateTypeParmDecl *D1,
1198 TemplateTypeParmDecl *D2) {
1199 if (D1->isParameterPack() != D2->isParameterPack()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001200 if (Context.Complain) {
1201 Context.Diag2(D2->getLocation(), diag::err_odr_parameter_pack_non_pack)
1202 << D2->isParameterPack();
1203 Context.Diag1(D1->getLocation(), diag::note_odr_parameter_pack_non_pack)
1204 << D1->isParameterPack();
1205 }
Douglas Gregora082a492010-11-30 19:14:50 +00001206 return false;
1207 }
1208
1209 return true;
1210}
1211
1212static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1213 NonTypeTemplateParmDecl *D1,
1214 NonTypeTemplateParmDecl *D2) {
Douglas Gregora082a492010-11-30 19:14:50 +00001215 if (D1->isParameterPack() != D2->isParameterPack()) {
Douglas Gregor3c7380b2012-10-26 15:36:15 +00001216 if (Context.Complain) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001217 Context.Diag2(D2->getLocation(), diag::err_odr_parameter_pack_non_pack)
1218 << D2->isParameterPack();
1219 Context.Diag1(D1->getLocation(), diag::note_odr_parameter_pack_non_pack)
1220 << D1->isParameterPack();
1221 }
Douglas Gregora082a492010-11-30 19:14:50 +00001222 return false;
1223 }
Douglas Gregora082a492010-11-30 19:14:50 +00001224
1225 // Check types.
1226 if (!Context.IsStructurallyEquivalent(D1->getType(), D2->getType())) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001227 if (Context.Complain) {
1228 Context.Diag2(D2->getLocation(),
1229 diag::err_odr_non_type_parameter_type_inconsistent)
1230 << D2->getType() << D1->getType();
1231 Context.Diag1(D1->getLocation(), diag::note_odr_value_here)
1232 << D1->getType();
1233 }
Douglas Gregora082a492010-11-30 19:14:50 +00001234 return false;
1235 }
1236
1237 return true;
1238}
1239
1240static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1241 TemplateTemplateParmDecl *D1,
1242 TemplateTemplateParmDecl *D2) {
Douglas Gregora082a492010-11-30 19:14:50 +00001243 if (D1->isParameterPack() != D2->isParameterPack()) {
Douglas Gregor069bbaf2012-10-26 15:34:11 +00001244 if (Context.Complain) {
1245 Context.Diag2(D2->getLocation(), diag::err_odr_parameter_pack_non_pack)
1246 << D2->isParameterPack();
1247 Context.Diag1(D1->getLocation(), diag::note_odr_parameter_pack_non_pack)
1248 << D1->isParameterPack();
1249 }
Douglas Gregora082a492010-11-30 19:14:50 +00001250 return false;
1251 }
Douglas Gregor3c7380b2012-10-26 15:36:15 +00001252
Douglas Gregora082a492010-11-30 19:14:50 +00001253 // Check template parameter lists.
1254 return IsStructurallyEquivalent(Context, D1->getTemplateParameters(),
1255 D2->getTemplateParameters());
1256}
1257
1258static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1259 ClassTemplateDecl *D1,
1260 ClassTemplateDecl *D2) {
1261 // Check template parameters.
1262 if (!IsStructurallyEquivalent(Context,
1263 D1->getTemplateParameters(),
1264 D2->getTemplateParameters()))
1265 return false;
1266
1267 // Check the templated declaration.
1268 return Context.IsStructurallyEquivalent(D1->getTemplatedDecl(),
1269 D2->getTemplatedDecl());
1270}
1271
Douglas Gregor3996e242010-02-15 22:01:00 +00001272/// \brief Determine structural equivalence of two declarations.
1273static bool IsStructurallyEquivalent(StructuralEquivalenceContext &Context,
1274 Decl *D1, Decl *D2) {
1275 // FIXME: Check for known structural equivalences via a callback of some sort.
1276
Douglas Gregorb4964f72010-02-15 23:54:17 +00001277 // Check whether we already know that these two declarations are not
1278 // structurally equivalent.
1279 if (Context.NonEquivalentDecls.count(std::make_pair(D1->getCanonicalDecl(),
1280 D2->getCanonicalDecl())))
1281 return false;
1282
Douglas Gregor3996e242010-02-15 22:01:00 +00001283 // Determine whether we've already produced a tentative equivalence for D1.
1284 Decl *&EquivToD1 = Context.TentativeEquivalences[D1->getCanonicalDecl()];
1285 if (EquivToD1)
1286 return EquivToD1 == D2->getCanonicalDecl();
1287
1288 // Produce a tentative equivalence D1 <-> D2, which will be checked later.
1289 EquivToD1 = D2->getCanonicalDecl();
1290 Context.DeclsToCheck.push_back(D1->getCanonicalDecl());
1291 return true;
1292}
1293
1294bool StructuralEquivalenceContext::IsStructurallyEquivalent(Decl *D1,
1295 Decl *D2) {
1296 if (!::IsStructurallyEquivalent(*this, D1, D2))
1297 return false;
1298
1299 return !Finish();
1300}
1301
1302bool StructuralEquivalenceContext::IsStructurallyEquivalent(QualType T1,
1303 QualType T2) {
1304 if (!::IsStructurallyEquivalent(*this, T1, T2))
1305 return false;
1306
1307 return !Finish();
1308}
1309
1310bool StructuralEquivalenceContext::Finish() {
1311 while (!DeclsToCheck.empty()) {
1312 // Check the next declaration.
1313 Decl *D1 = DeclsToCheck.front();
1314 DeclsToCheck.pop_front();
1315
1316 Decl *D2 = TentativeEquivalences[D1];
1317 assert(D2 && "Unrecorded tentative equivalence?");
1318
Douglas Gregorb4964f72010-02-15 23:54:17 +00001319 bool Equivalent = true;
1320
Douglas Gregor3996e242010-02-15 22:01:00 +00001321 // FIXME: Switch on all declaration kinds. For now, we're just going to
1322 // check the obvious ones.
1323 if (RecordDecl *Record1 = dyn_cast<RecordDecl>(D1)) {
1324 if (RecordDecl *Record2 = dyn_cast<RecordDecl>(D2)) {
1325 // Check for equivalent structure names.
1326 IdentifierInfo *Name1 = Record1->getIdentifier();
Richard Smithdda56e42011-04-15 14:24:37 +00001327 if (!Name1 && Record1->getTypedefNameForAnonDecl())
1328 Name1 = Record1->getTypedefNameForAnonDecl()->getIdentifier();
Douglas Gregor3996e242010-02-15 22:01:00 +00001329 IdentifierInfo *Name2 = Record2->getIdentifier();
Richard Smithdda56e42011-04-15 14:24:37 +00001330 if (!Name2 && Record2->getTypedefNameForAnonDecl())
1331 Name2 = Record2->getTypedefNameForAnonDecl()->getIdentifier();
Douglas Gregorb4964f72010-02-15 23:54:17 +00001332 if (!::IsStructurallyEquivalent(Name1, Name2) ||
1333 !::IsStructurallyEquivalent(*this, Record1, Record2))
1334 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001335 } else {
1336 // Record/non-record mismatch.
Douglas Gregorb4964f72010-02-15 23:54:17 +00001337 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001338 }
Douglas Gregorb4964f72010-02-15 23:54:17 +00001339 } else if (EnumDecl *Enum1 = dyn_cast<EnumDecl>(D1)) {
Douglas Gregor3996e242010-02-15 22:01:00 +00001340 if (EnumDecl *Enum2 = dyn_cast<EnumDecl>(D2)) {
1341 // Check for equivalent enum names.
1342 IdentifierInfo *Name1 = Enum1->getIdentifier();
Richard Smithdda56e42011-04-15 14:24:37 +00001343 if (!Name1 && Enum1->getTypedefNameForAnonDecl())
1344 Name1 = Enum1->getTypedefNameForAnonDecl()->getIdentifier();
Douglas Gregor3996e242010-02-15 22:01:00 +00001345 IdentifierInfo *Name2 = Enum2->getIdentifier();
Richard Smithdda56e42011-04-15 14:24:37 +00001346 if (!Name2 && Enum2->getTypedefNameForAnonDecl())
1347 Name2 = Enum2->getTypedefNameForAnonDecl()->getIdentifier();
Douglas Gregorb4964f72010-02-15 23:54:17 +00001348 if (!::IsStructurallyEquivalent(Name1, Name2) ||
1349 !::IsStructurallyEquivalent(*this, Enum1, Enum2))
1350 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001351 } else {
1352 // Enum/non-enum mismatch
Douglas Gregorb4964f72010-02-15 23:54:17 +00001353 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001354 }
Richard Smithdda56e42011-04-15 14:24:37 +00001355 } else if (TypedefNameDecl *Typedef1 = dyn_cast<TypedefNameDecl>(D1)) {
1356 if (TypedefNameDecl *Typedef2 = dyn_cast<TypedefNameDecl>(D2)) {
Douglas Gregor3996e242010-02-15 22:01:00 +00001357 if (!::IsStructurallyEquivalent(Typedef1->getIdentifier(),
Douglas Gregorb4964f72010-02-15 23:54:17 +00001358 Typedef2->getIdentifier()) ||
1359 !::IsStructurallyEquivalent(*this,
Douglas Gregor3996e242010-02-15 22:01:00 +00001360 Typedef1->getUnderlyingType(),
1361 Typedef2->getUnderlyingType()))
Douglas Gregorb4964f72010-02-15 23:54:17 +00001362 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001363 } else {
1364 // Typedef/non-typedef mismatch.
Douglas Gregorb4964f72010-02-15 23:54:17 +00001365 Equivalent = false;
Douglas Gregor3996e242010-02-15 22:01:00 +00001366 }
Douglas Gregora082a492010-11-30 19:14:50 +00001367 } else if (ClassTemplateDecl *ClassTemplate1
1368 = dyn_cast<ClassTemplateDecl>(D1)) {
1369 if (ClassTemplateDecl *ClassTemplate2 = dyn_cast<ClassTemplateDecl>(D2)) {
1370 if (!::IsStructurallyEquivalent(ClassTemplate1->getIdentifier(),
1371 ClassTemplate2->getIdentifier()) ||
1372 !::IsStructurallyEquivalent(*this, ClassTemplate1, ClassTemplate2))
1373 Equivalent = false;
1374 } else {
1375 // Class template/non-class-template mismatch.
1376 Equivalent = false;
1377 }
1378 } else if (TemplateTypeParmDecl *TTP1= dyn_cast<TemplateTypeParmDecl>(D1)) {
1379 if (TemplateTypeParmDecl *TTP2 = dyn_cast<TemplateTypeParmDecl>(D2)) {
1380 if (!::IsStructurallyEquivalent(*this, TTP1, TTP2))
1381 Equivalent = false;
1382 } else {
1383 // Kind mismatch.
1384 Equivalent = false;
1385 }
1386 } else if (NonTypeTemplateParmDecl *NTTP1
1387 = dyn_cast<NonTypeTemplateParmDecl>(D1)) {
1388 if (NonTypeTemplateParmDecl *NTTP2
1389 = dyn_cast<NonTypeTemplateParmDecl>(D2)) {
1390 if (!::IsStructurallyEquivalent(*this, NTTP1, NTTP2))
1391 Equivalent = false;
1392 } else {
1393 // Kind mismatch.
1394 Equivalent = false;
1395 }
1396 } else if (TemplateTemplateParmDecl *TTP1
1397 = dyn_cast<TemplateTemplateParmDecl>(D1)) {
1398 if (TemplateTemplateParmDecl *TTP2
1399 = dyn_cast<TemplateTemplateParmDecl>(D2)) {
1400 if (!::IsStructurallyEquivalent(*this, TTP1, TTP2))
1401 Equivalent = false;
1402 } else {
1403 // Kind mismatch.
1404 Equivalent = false;
1405 }
1406 }
1407
Douglas Gregorb4964f72010-02-15 23:54:17 +00001408 if (!Equivalent) {
1409 // Note that these two declarations are not equivalent (and we already
1410 // know about it).
1411 NonEquivalentDecls.insert(std::make_pair(D1->getCanonicalDecl(),
1412 D2->getCanonicalDecl()));
1413 return true;
1414 }
Douglas Gregor3996e242010-02-15 22:01:00 +00001415 // FIXME: Check other declaration kinds!
1416 }
1417
1418 return false;
1419}
1420
1421//----------------------------------------------------------------------------
Douglas Gregor96e578d2010-02-05 17:54:41 +00001422// Import Types
1423//----------------------------------------------------------------------------
1424
John McCall424cec92011-01-19 06:33:43 +00001425QualType ASTNodeImporter::VisitType(const Type *T) {
Douglas Gregore4c83e42010-02-09 22:48:33 +00001426 Importer.FromDiag(SourceLocation(), diag::err_unsupported_ast_node)
1427 << T->getTypeClassName();
1428 return QualType();
1429}
1430
John McCall424cec92011-01-19 06:33:43 +00001431QualType ASTNodeImporter::VisitBuiltinType(const BuiltinType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001432 switch (T->getKind()) {
John McCalle314e272011-10-18 21:02:43 +00001433#define SHARED_SINGLETON_TYPE(Expansion)
1434#define BUILTIN_TYPE(Id, SingletonId) \
1435 case BuiltinType::Id: return Importer.getToContext().SingletonId;
1436#include "clang/AST/BuiltinTypes.def"
1437
1438 // FIXME: for Char16, Char32, and NullPtr, make sure that the "to"
1439 // context supports C++.
1440
1441 // FIXME: for ObjCId, ObjCClass, and ObjCSel, make sure that the "to"
1442 // context supports ObjC.
1443
Douglas Gregor96e578d2010-02-05 17:54:41 +00001444 case BuiltinType::Char_U:
1445 // The context we're importing from has an unsigned 'char'. If we're
1446 // importing into a context with a signed 'char', translate to
1447 // 'unsigned char' instead.
David Blaikiebbafb8a2012-03-11 07:00:24 +00001448 if (Importer.getToContext().getLangOpts().CharIsSigned)
Douglas Gregor96e578d2010-02-05 17:54:41 +00001449 return Importer.getToContext().UnsignedCharTy;
1450
1451 return Importer.getToContext().CharTy;
1452
Douglas Gregor96e578d2010-02-05 17:54:41 +00001453 case BuiltinType::Char_S:
1454 // The context we're importing from has an unsigned 'char'. If we're
1455 // importing into a context with a signed 'char', translate to
1456 // 'unsigned char' instead.
David Blaikiebbafb8a2012-03-11 07:00:24 +00001457 if (!Importer.getToContext().getLangOpts().CharIsSigned)
Douglas Gregor96e578d2010-02-05 17:54:41 +00001458 return Importer.getToContext().SignedCharTy;
1459
1460 return Importer.getToContext().CharTy;
1461
Chris Lattnerad3467e2010-12-25 23:25:43 +00001462 case BuiltinType::WChar_S:
1463 case BuiltinType::WChar_U:
Douglas Gregor96e578d2010-02-05 17:54:41 +00001464 // FIXME: If not in C++, shall we translate to the C equivalent of
1465 // wchar_t?
1466 return Importer.getToContext().WCharTy;
Douglas Gregor96e578d2010-02-05 17:54:41 +00001467 }
David Blaikiee4d798f2012-01-20 21:50:17 +00001468
1469 llvm_unreachable("Invalid BuiltinType Kind!");
Douglas Gregor96e578d2010-02-05 17:54:41 +00001470}
1471
John McCall424cec92011-01-19 06:33:43 +00001472QualType ASTNodeImporter::VisitComplexType(const ComplexType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001473 QualType ToElementType = Importer.Import(T->getElementType());
1474 if (ToElementType.isNull())
1475 return QualType();
1476
1477 return Importer.getToContext().getComplexType(ToElementType);
1478}
1479
John McCall424cec92011-01-19 06:33:43 +00001480QualType ASTNodeImporter::VisitPointerType(const PointerType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001481 QualType ToPointeeType = Importer.Import(T->getPointeeType());
1482 if (ToPointeeType.isNull())
1483 return QualType();
1484
1485 return Importer.getToContext().getPointerType(ToPointeeType);
1486}
1487
John McCall424cec92011-01-19 06:33:43 +00001488QualType ASTNodeImporter::VisitBlockPointerType(const BlockPointerType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001489 // FIXME: Check for blocks support in "to" context.
1490 QualType ToPointeeType = Importer.Import(T->getPointeeType());
1491 if (ToPointeeType.isNull())
1492 return QualType();
1493
1494 return Importer.getToContext().getBlockPointerType(ToPointeeType);
1495}
1496
John McCall424cec92011-01-19 06:33:43 +00001497QualType
1498ASTNodeImporter::VisitLValueReferenceType(const LValueReferenceType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001499 // FIXME: Check for C++ support in "to" context.
1500 QualType ToPointeeType = Importer.Import(T->getPointeeTypeAsWritten());
1501 if (ToPointeeType.isNull())
1502 return QualType();
1503
1504 return Importer.getToContext().getLValueReferenceType(ToPointeeType);
1505}
1506
John McCall424cec92011-01-19 06:33:43 +00001507QualType
1508ASTNodeImporter::VisitRValueReferenceType(const RValueReferenceType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001509 // FIXME: Check for C++0x support in "to" context.
1510 QualType ToPointeeType = Importer.Import(T->getPointeeTypeAsWritten());
1511 if (ToPointeeType.isNull())
1512 return QualType();
1513
1514 return Importer.getToContext().getRValueReferenceType(ToPointeeType);
1515}
1516
John McCall424cec92011-01-19 06:33:43 +00001517QualType ASTNodeImporter::VisitMemberPointerType(const MemberPointerType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001518 // FIXME: Check for C++ support in "to" context.
1519 QualType ToPointeeType = Importer.Import(T->getPointeeType());
1520 if (ToPointeeType.isNull())
1521 return QualType();
1522
1523 QualType ClassType = Importer.Import(QualType(T->getClass(), 0));
1524 return Importer.getToContext().getMemberPointerType(ToPointeeType,
1525 ClassType.getTypePtr());
1526}
1527
John McCall424cec92011-01-19 06:33:43 +00001528QualType ASTNodeImporter::VisitConstantArrayType(const ConstantArrayType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001529 QualType ToElementType = Importer.Import(T->getElementType());
1530 if (ToElementType.isNull())
1531 return QualType();
1532
1533 return Importer.getToContext().getConstantArrayType(ToElementType,
1534 T->getSize(),
1535 T->getSizeModifier(),
1536 T->getIndexTypeCVRQualifiers());
1537}
1538
John McCall424cec92011-01-19 06:33:43 +00001539QualType
1540ASTNodeImporter::VisitIncompleteArrayType(const IncompleteArrayType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001541 QualType ToElementType = Importer.Import(T->getElementType());
1542 if (ToElementType.isNull())
1543 return QualType();
1544
1545 return Importer.getToContext().getIncompleteArrayType(ToElementType,
1546 T->getSizeModifier(),
1547 T->getIndexTypeCVRQualifiers());
1548}
1549
John McCall424cec92011-01-19 06:33:43 +00001550QualType ASTNodeImporter::VisitVariableArrayType(const VariableArrayType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001551 QualType ToElementType = Importer.Import(T->getElementType());
1552 if (ToElementType.isNull())
1553 return QualType();
1554
1555 Expr *Size = Importer.Import(T->getSizeExpr());
1556 if (!Size)
1557 return QualType();
1558
1559 SourceRange Brackets = Importer.Import(T->getBracketsRange());
1560 return Importer.getToContext().getVariableArrayType(ToElementType, Size,
1561 T->getSizeModifier(),
1562 T->getIndexTypeCVRQualifiers(),
1563 Brackets);
1564}
1565
John McCall424cec92011-01-19 06:33:43 +00001566QualType ASTNodeImporter::VisitVectorType(const VectorType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001567 QualType ToElementType = Importer.Import(T->getElementType());
1568 if (ToElementType.isNull())
1569 return QualType();
1570
1571 return Importer.getToContext().getVectorType(ToElementType,
1572 T->getNumElements(),
Bob Wilsonaeb56442010-11-10 21:56:12 +00001573 T->getVectorKind());
Douglas Gregor96e578d2010-02-05 17:54:41 +00001574}
1575
John McCall424cec92011-01-19 06:33:43 +00001576QualType ASTNodeImporter::VisitExtVectorType(const ExtVectorType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001577 QualType ToElementType = Importer.Import(T->getElementType());
1578 if (ToElementType.isNull())
1579 return QualType();
1580
1581 return Importer.getToContext().getExtVectorType(ToElementType,
1582 T->getNumElements());
1583}
1584
John McCall424cec92011-01-19 06:33:43 +00001585QualType
1586ASTNodeImporter::VisitFunctionNoProtoType(const FunctionNoProtoType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001587 // FIXME: What happens if we're importing a function without a prototype
1588 // into C++? Should we make it variadic?
1589 QualType ToResultType = Importer.Import(T->getResultType());
1590 if (ToResultType.isNull())
1591 return QualType();
Rafael Espindolac50c27c2010-03-30 20:24:48 +00001592
Douglas Gregor96e578d2010-02-05 17:54:41 +00001593 return Importer.getToContext().getFunctionNoProtoType(ToResultType,
Rafael Espindolac50c27c2010-03-30 20:24:48 +00001594 T->getExtInfo());
Douglas Gregor96e578d2010-02-05 17:54:41 +00001595}
1596
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00001597QualType ASTNodeImporter::VisitFunctionProtoType(const FunctionProtoType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001598 QualType ToResultType = Importer.Import(T->getResultType());
1599 if (ToResultType.isNull())
1600 return QualType();
1601
1602 // Import argument types
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001603 SmallVector<QualType, 4> ArgTypes;
Alp Toker9cacbab2014-01-20 20:26:09 +00001604 for (FunctionProtoType::param_type_iterator A = T->param_type_begin(),
1605 AEnd = T->param_type_end();
Douglas Gregor96e578d2010-02-05 17:54:41 +00001606 A != AEnd; ++A) {
1607 QualType ArgType = Importer.Import(*A);
1608 if (ArgType.isNull())
1609 return QualType();
1610 ArgTypes.push_back(ArgType);
1611 }
1612
1613 // Import exception types
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001614 SmallVector<QualType, 4> ExceptionTypes;
Douglas Gregor96e578d2010-02-05 17:54:41 +00001615 for (FunctionProtoType::exception_iterator E = T->exception_begin(),
1616 EEnd = T->exception_end();
1617 E != EEnd; ++E) {
1618 QualType ExceptionType = Importer.Import(*E);
1619 if (ExceptionType.isNull())
1620 return QualType();
1621 ExceptionTypes.push_back(ExceptionType);
1622 }
John McCalldb40c7f2010-12-14 08:05:40 +00001623
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00001624 FunctionProtoType::ExtProtoInfo FromEPI = T->getExtProtoInfo();
1625 FunctionProtoType::ExtProtoInfo ToEPI;
1626
1627 ToEPI.ExtInfo = FromEPI.ExtInfo;
1628 ToEPI.Variadic = FromEPI.Variadic;
1629 ToEPI.HasTrailingReturn = FromEPI.HasTrailingReturn;
1630 ToEPI.TypeQuals = FromEPI.TypeQuals;
1631 ToEPI.RefQualifier = FromEPI.RefQualifier;
1632 ToEPI.NumExceptions = ExceptionTypes.size();
1633 ToEPI.Exceptions = ExceptionTypes.data();
Alp Tokerb3fd5cf2014-01-21 00:32:38 +00001634 ToEPI.ConsumedParameters = FromEPI.ConsumedParameters;
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00001635 ToEPI.ExceptionSpecType = FromEPI.ExceptionSpecType;
1636 ToEPI.NoexceptExpr = Importer.Import(FromEPI.NoexceptExpr);
1637 ToEPI.ExceptionSpecDecl = cast_or_null<FunctionDecl>(
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00001638 Importer.Import(FromEPI.ExceptionSpecDecl));
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00001639 ToEPI.ExceptionSpecTemplate = cast_or_null<FunctionDecl>(
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00001640 Importer.Import(FromEPI.ExceptionSpecTemplate));
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00001641
Jordan Rose5c382722013-03-08 21:51:21 +00001642 return Importer.getToContext().getFunctionType(ToResultType, ArgTypes, ToEPI);
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00001643}
1644
Sean Callananda6df8a2011-08-11 16:56:07 +00001645QualType ASTNodeImporter::VisitParenType(const ParenType *T) {
1646 QualType ToInnerType = Importer.Import(T->getInnerType());
1647 if (ToInnerType.isNull())
1648 return QualType();
1649
1650 return Importer.getToContext().getParenType(ToInnerType);
1651}
1652
John McCall424cec92011-01-19 06:33:43 +00001653QualType ASTNodeImporter::VisitTypedefType(const TypedefType *T) {
Richard Smithdda56e42011-04-15 14:24:37 +00001654 TypedefNameDecl *ToDecl
1655 = dyn_cast_or_null<TypedefNameDecl>(Importer.Import(T->getDecl()));
Douglas Gregor96e578d2010-02-05 17:54:41 +00001656 if (!ToDecl)
1657 return QualType();
1658
1659 return Importer.getToContext().getTypeDeclType(ToDecl);
1660}
1661
John McCall424cec92011-01-19 06:33:43 +00001662QualType ASTNodeImporter::VisitTypeOfExprType(const TypeOfExprType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001663 Expr *ToExpr = Importer.Import(T->getUnderlyingExpr());
1664 if (!ToExpr)
1665 return QualType();
1666
1667 return Importer.getToContext().getTypeOfExprType(ToExpr);
1668}
1669
John McCall424cec92011-01-19 06:33:43 +00001670QualType ASTNodeImporter::VisitTypeOfType(const TypeOfType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001671 QualType ToUnderlyingType = Importer.Import(T->getUnderlyingType());
1672 if (ToUnderlyingType.isNull())
1673 return QualType();
1674
1675 return Importer.getToContext().getTypeOfType(ToUnderlyingType);
1676}
1677
John McCall424cec92011-01-19 06:33:43 +00001678QualType ASTNodeImporter::VisitDecltypeType(const DecltypeType *T) {
Richard Smith30482bc2011-02-20 03:19:35 +00001679 // FIXME: Make sure that the "to" context supports C++0x!
Douglas Gregor96e578d2010-02-05 17:54:41 +00001680 Expr *ToExpr = Importer.Import(T->getUnderlyingExpr());
1681 if (!ToExpr)
1682 return QualType();
1683
Douglas Gregor81495f32012-02-12 18:42:33 +00001684 QualType UnderlyingType = Importer.Import(T->getUnderlyingType());
1685 if (UnderlyingType.isNull())
1686 return QualType();
1687
1688 return Importer.getToContext().getDecltypeType(ToExpr, UnderlyingType);
Douglas Gregor96e578d2010-02-05 17:54:41 +00001689}
1690
Alexis Hunte852b102011-05-24 22:41:36 +00001691QualType ASTNodeImporter::VisitUnaryTransformType(const UnaryTransformType *T) {
1692 QualType ToBaseType = Importer.Import(T->getBaseType());
1693 QualType ToUnderlyingType = Importer.Import(T->getUnderlyingType());
1694 if (ToBaseType.isNull() || ToUnderlyingType.isNull())
1695 return QualType();
1696
1697 return Importer.getToContext().getUnaryTransformType(ToBaseType,
1698 ToUnderlyingType,
1699 T->getUTTKind());
1700}
1701
Richard Smith30482bc2011-02-20 03:19:35 +00001702QualType ASTNodeImporter::VisitAutoType(const AutoType *T) {
Richard Smith74aeef52013-04-26 16:15:35 +00001703 // FIXME: Make sure that the "to" context supports C++11!
Richard Smith30482bc2011-02-20 03:19:35 +00001704 QualType FromDeduced = T->getDeducedType();
1705 QualType ToDeduced;
1706 if (!FromDeduced.isNull()) {
1707 ToDeduced = Importer.Import(FromDeduced);
1708 if (ToDeduced.isNull())
1709 return QualType();
1710 }
1711
Faisal Vali2b391ab2013-09-26 19:54:12 +00001712 return Importer.getToContext().getAutoType(ToDeduced, T->isDecltypeAuto(),
1713 /*IsDependent*/false);
Richard Smith30482bc2011-02-20 03:19:35 +00001714}
1715
John McCall424cec92011-01-19 06:33:43 +00001716QualType ASTNodeImporter::VisitRecordType(const RecordType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001717 RecordDecl *ToDecl
1718 = dyn_cast_or_null<RecordDecl>(Importer.Import(T->getDecl()));
1719 if (!ToDecl)
1720 return QualType();
1721
1722 return Importer.getToContext().getTagDeclType(ToDecl);
1723}
1724
John McCall424cec92011-01-19 06:33:43 +00001725QualType ASTNodeImporter::VisitEnumType(const EnumType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001726 EnumDecl *ToDecl
1727 = dyn_cast_or_null<EnumDecl>(Importer.Import(T->getDecl()));
1728 if (!ToDecl)
1729 return QualType();
1730
1731 return Importer.getToContext().getTagDeclType(ToDecl);
1732}
1733
Douglas Gregore2e50d332010-12-01 01:36:18 +00001734QualType ASTNodeImporter::VisitTemplateSpecializationType(
John McCall424cec92011-01-19 06:33:43 +00001735 const TemplateSpecializationType *T) {
Douglas Gregore2e50d332010-12-01 01:36:18 +00001736 TemplateName ToTemplate = Importer.Import(T->getTemplateName());
1737 if (ToTemplate.isNull())
1738 return QualType();
1739
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001740 SmallVector<TemplateArgument, 2> ToTemplateArgs;
Douglas Gregore2e50d332010-12-01 01:36:18 +00001741 if (ImportTemplateArguments(T->getArgs(), T->getNumArgs(), ToTemplateArgs))
1742 return QualType();
1743
1744 QualType ToCanonType;
1745 if (!QualType(T, 0).isCanonical()) {
1746 QualType FromCanonType
1747 = Importer.getFromContext().getCanonicalType(QualType(T, 0));
1748 ToCanonType =Importer.Import(FromCanonType);
1749 if (ToCanonType.isNull())
1750 return QualType();
1751 }
1752 return Importer.getToContext().getTemplateSpecializationType(ToTemplate,
1753 ToTemplateArgs.data(),
1754 ToTemplateArgs.size(),
1755 ToCanonType);
1756}
1757
John McCall424cec92011-01-19 06:33:43 +00001758QualType ASTNodeImporter::VisitElaboratedType(const ElaboratedType *T) {
Abramo Bagnara6150c882010-05-11 21:36:43 +00001759 NestedNameSpecifier *ToQualifier = 0;
1760 // Note: the qualifier in an ElaboratedType is optional.
1761 if (T->getQualifier()) {
1762 ToQualifier = Importer.Import(T->getQualifier());
1763 if (!ToQualifier)
1764 return QualType();
1765 }
Douglas Gregor96e578d2010-02-05 17:54:41 +00001766
1767 QualType ToNamedType = Importer.Import(T->getNamedType());
1768 if (ToNamedType.isNull())
1769 return QualType();
1770
Abramo Bagnara6150c882010-05-11 21:36:43 +00001771 return Importer.getToContext().getElaboratedType(T->getKeyword(),
1772 ToQualifier, ToNamedType);
Douglas Gregor96e578d2010-02-05 17:54:41 +00001773}
1774
John McCall424cec92011-01-19 06:33:43 +00001775QualType ASTNodeImporter::VisitObjCInterfaceType(const ObjCInterfaceType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001776 ObjCInterfaceDecl *Class
1777 = dyn_cast_or_null<ObjCInterfaceDecl>(Importer.Import(T->getDecl()));
1778 if (!Class)
1779 return QualType();
1780
John McCall8b07ec22010-05-15 11:32:37 +00001781 return Importer.getToContext().getObjCInterfaceType(Class);
1782}
1783
John McCall424cec92011-01-19 06:33:43 +00001784QualType ASTNodeImporter::VisitObjCObjectType(const ObjCObjectType *T) {
John McCall8b07ec22010-05-15 11:32:37 +00001785 QualType ToBaseType = Importer.Import(T->getBaseType());
1786 if (ToBaseType.isNull())
1787 return QualType();
1788
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001789 SmallVector<ObjCProtocolDecl *, 4> Protocols;
John McCall8b07ec22010-05-15 11:32:37 +00001790 for (ObjCObjectType::qual_iterator P = T->qual_begin(),
Douglas Gregor96e578d2010-02-05 17:54:41 +00001791 PEnd = T->qual_end();
1792 P != PEnd; ++P) {
1793 ObjCProtocolDecl *Protocol
1794 = dyn_cast_or_null<ObjCProtocolDecl>(Importer.Import(*P));
1795 if (!Protocol)
1796 return QualType();
1797 Protocols.push_back(Protocol);
1798 }
1799
John McCall8b07ec22010-05-15 11:32:37 +00001800 return Importer.getToContext().getObjCObjectType(ToBaseType,
1801 Protocols.data(),
1802 Protocols.size());
Douglas Gregor96e578d2010-02-05 17:54:41 +00001803}
1804
John McCall424cec92011-01-19 06:33:43 +00001805QualType
1806ASTNodeImporter::VisitObjCObjectPointerType(const ObjCObjectPointerType *T) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00001807 QualType ToPointeeType = Importer.Import(T->getPointeeType());
1808 if (ToPointeeType.isNull())
1809 return QualType();
1810
John McCall8b07ec22010-05-15 11:32:37 +00001811 return Importer.getToContext().getObjCObjectPointerType(ToPointeeType);
Douglas Gregor96e578d2010-02-05 17:54:41 +00001812}
1813
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00001814//----------------------------------------------------------------------------
1815// Import Declarations
1816//----------------------------------------------------------------------------
Douglas Gregorbb7930c2010-02-10 19:54:31 +00001817bool ASTNodeImporter::ImportDeclParts(NamedDecl *D, DeclContext *&DC,
1818 DeclContext *&LexicalDC,
1819 DeclarationName &Name,
1820 SourceLocation &Loc) {
1821 // Import the context of this declaration.
1822 DC = Importer.ImportContext(D->getDeclContext());
1823 if (!DC)
1824 return true;
1825
1826 LexicalDC = DC;
1827 if (D->getDeclContext() != D->getLexicalDeclContext()) {
1828 LexicalDC = Importer.ImportContext(D->getLexicalDeclContext());
1829 if (!LexicalDC)
1830 return true;
1831 }
1832
1833 // Import the name of this declaration.
1834 Name = Importer.Import(D->getDeclName());
1835 if (D->getDeclName() && !Name)
1836 return true;
1837
1838 // Import the location of this declaration.
1839 Loc = Importer.Import(D->getLocation());
1840 return false;
1841}
1842
Douglas Gregord451ea92011-07-29 23:31:30 +00001843void ASTNodeImporter::ImportDefinitionIfNeeded(Decl *FromD, Decl *ToD) {
1844 if (!FromD)
1845 return;
1846
1847 if (!ToD) {
1848 ToD = Importer.Import(FromD);
1849 if (!ToD)
1850 return;
1851 }
1852
1853 if (RecordDecl *FromRecord = dyn_cast<RecordDecl>(FromD)) {
1854 if (RecordDecl *ToRecord = cast_or_null<RecordDecl>(ToD)) {
Sean Callanan19dfc932013-01-11 23:17:47 +00001855 if (FromRecord->getDefinition() && FromRecord->isCompleteDefinition() && !ToRecord->getDefinition()) {
Douglas Gregord451ea92011-07-29 23:31:30 +00001856 ImportDefinition(FromRecord, ToRecord);
1857 }
1858 }
1859 return;
1860 }
1861
1862 if (EnumDecl *FromEnum = dyn_cast<EnumDecl>(FromD)) {
1863 if (EnumDecl *ToEnum = cast_or_null<EnumDecl>(ToD)) {
1864 if (FromEnum->getDefinition() && !ToEnum->getDefinition()) {
1865 ImportDefinition(FromEnum, ToEnum);
1866 }
1867 }
1868 return;
1869 }
1870}
1871
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001872void
1873ASTNodeImporter::ImportDeclarationNameLoc(const DeclarationNameInfo &From,
1874 DeclarationNameInfo& To) {
1875 // NOTE: To.Name and To.Loc are already imported.
1876 // We only have to import To.LocInfo.
1877 switch (To.getName().getNameKind()) {
1878 case DeclarationName::Identifier:
1879 case DeclarationName::ObjCZeroArgSelector:
1880 case DeclarationName::ObjCOneArgSelector:
1881 case DeclarationName::ObjCMultiArgSelector:
1882 case DeclarationName::CXXUsingDirective:
1883 return;
1884
1885 case DeclarationName::CXXOperatorName: {
1886 SourceRange Range = From.getCXXOperatorNameRange();
1887 To.setCXXOperatorNameRange(Importer.Import(Range));
1888 return;
1889 }
1890 case DeclarationName::CXXLiteralOperatorName: {
1891 SourceLocation Loc = From.getCXXLiteralOperatorNameLoc();
1892 To.setCXXLiteralOperatorNameLoc(Importer.Import(Loc));
1893 return;
1894 }
1895 case DeclarationName::CXXConstructorName:
1896 case DeclarationName::CXXDestructorName:
1897 case DeclarationName::CXXConversionFunctionName: {
1898 TypeSourceInfo *FromTInfo = From.getNamedTypeInfo();
1899 To.setNamedTypeInfo(Importer.Import(FromTInfo));
1900 return;
1901 }
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001902 }
Douglas Gregor07216d12011-11-02 20:52:01 +00001903 llvm_unreachable("Unknown name kind.");
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00001904}
1905
Douglas Gregor2e15c842012-02-01 21:00:38 +00001906void ASTNodeImporter::ImportDeclContext(DeclContext *FromDC, bool ForceImport) {
Douglas Gregor0a791672011-01-18 03:11:38 +00001907 if (Importer.isMinimalImport() && !ForceImport) {
Sean Callanan81d577c2011-07-22 23:46:03 +00001908 Importer.ImportContext(FromDC);
Douglas Gregor0a791672011-01-18 03:11:38 +00001909 return;
1910 }
1911
Douglas Gregor968d6332010-02-21 18:24:45 +00001912 for (DeclContext::decl_iterator From = FromDC->decls_begin(),
1913 FromEnd = FromDC->decls_end();
1914 From != FromEnd;
1915 ++From)
1916 Importer.Import(*From);
1917}
1918
Douglas Gregord451ea92011-07-29 23:31:30 +00001919bool ASTNodeImporter::ImportDefinition(RecordDecl *From, RecordDecl *To,
Douglas Gregor95d82832012-01-24 18:36:04 +00001920 ImportDefinitionKind Kind) {
1921 if (To->getDefinition() || To->isBeingDefined()) {
1922 if (Kind == IDK_Everything)
1923 ImportDeclContext(From, /*ForceImport=*/true);
1924
Douglas Gregore2e50d332010-12-01 01:36:18 +00001925 return false;
Douglas Gregor95d82832012-01-24 18:36:04 +00001926 }
Douglas Gregore2e50d332010-12-01 01:36:18 +00001927
1928 To->startDefinition();
1929
1930 // Add base classes.
1931 if (CXXRecordDecl *ToCXX = dyn_cast<CXXRecordDecl>(To)) {
1932 CXXRecordDecl *FromCXX = cast<CXXRecordDecl>(From);
Douglas Gregor3c2404b2011-11-03 18:07:07 +00001933
1934 struct CXXRecordDecl::DefinitionData &ToData = ToCXX->data();
1935 struct CXXRecordDecl::DefinitionData &FromData = FromCXX->data();
1936 ToData.UserDeclaredConstructor = FromData.UserDeclaredConstructor;
Richard Smith328aae52012-11-30 05:11:39 +00001937 ToData.UserDeclaredSpecialMembers = FromData.UserDeclaredSpecialMembers;
Douglas Gregor3c2404b2011-11-03 18:07:07 +00001938 ToData.Aggregate = FromData.Aggregate;
1939 ToData.PlainOldData = FromData.PlainOldData;
1940 ToData.Empty = FromData.Empty;
1941 ToData.Polymorphic = FromData.Polymorphic;
1942 ToData.Abstract = FromData.Abstract;
1943 ToData.IsStandardLayout = FromData.IsStandardLayout;
1944 ToData.HasNoNonEmptyBases = FromData.HasNoNonEmptyBases;
1945 ToData.HasPrivateFields = FromData.HasPrivateFields;
1946 ToData.HasProtectedFields = FromData.HasProtectedFields;
1947 ToData.HasPublicFields = FromData.HasPublicFields;
1948 ToData.HasMutableFields = FromData.HasMutableFields;
Richard Smithab44d5b2013-12-10 08:25:00 +00001949 ToData.HasVariantMembers = FromData.HasVariantMembers;
Richard Smith561fb152012-02-25 07:33:38 +00001950 ToData.HasOnlyCMembers = FromData.HasOnlyCMembers;
Richard Smithe2648ba2012-05-07 01:07:30 +00001951 ToData.HasInClassInitializer = FromData.HasInClassInitializer;
Richard Smith593f9932012-12-08 02:01:17 +00001952 ToData.HasUninitializedReferenceMember
1953 = FromData.HasUninitializedReferenceMember;
Richard Smith6b02d462012-12-08 08:32:28 +00001954 ToData.NeedOverloadResolutionForMoveConstructor
1955 = FromData.NeedOverloadResolutionForMoveConstructor;
1956 ToData.NeedOverloadResolutionForMoveAssignment
1957 = FromData.NeedOverloadResolutionForMoveAssignment;
1958 ToData.NeedOverloadResolutionForDestructor
1959 = FromData.NeedOverloadResolutionForDestructor;
1960 ToData.DefaultedMoveConstructorIsDeleted
1961 = FromData.DefaultedMoveConstructorIsDeleted;
1962 ToData.DefaultedMoveAssignmentIsDeleted
1963 = FromData.DefaultedMoveAssignmentIsDeleted;
1964 ToData.DefaultedDestructorIsDeleted = FromData.DefaultedDestructorIsDeleted;
Richard Smith328aae52012-11-30 05:11:39 +00001965 ToData.HasTrivialSpecialMembers = FromData.HasTrivialSpecialMembers;
1966 ToData.HasIrrelevantDestructor = FromData.HasIrrelevantDestructor;
Douglas Gregor3c2404b2011-11-03 18:07:07 +00001967 ToData.HasConstexprNonCopyMoveConstructor
1968 = FromData.HasConstexprNonCopyMoveConstructor;
Richard Smith561fb152012-02-25 07:33:38 +00001969 ToData.DefaultedDefaultConstructorIsConstexpr
1970 = FromData.DefaultedDefaultConstructorIsConstexpr;
Richard Smith561fb152012-02-25 07:33:38 +00001971 ToData.HasConstexprDefaultConstructor
1972 = FromData.HasConstexprDefaultConstructor;
Douglas Gregor3c2404b2011-11-03 18:07:07 +00001973 ToData.HasNonLiteralTypeFieldsOrBases
1974 = FromData.HasNonLiteralTypeFieldsOrBases;
Richard Smith561fb152012-02-25 07:33:38 +00001975 // ComputedVisibleConversions not imported.
Douglas Gregor3c2404b2011-11-03 18:07:07 +00001976 ToData.UserProvidedDefaultConstructor
1977 = FromData.UserProvidedDefaultConstructor;
Richard Smith328aae52012-11-30 05:11:39 +00001978 ToData.DeclaredSpecialMembers = FromData.DeclaredSpecialMembers;
Richard Smith1c33fe82012-11-28 06:23:12 +00001979 ToData.ImplicitCopyConstructorHasConstParam
1980 = FromData.ImplicitCopyConstructorHasConstParam;
1981 ToData.ImplicitCopyAssignmentHasConstParam
1982 = FromData.ImplicitCopyAssignmentHasConstParam;
1983 ToData.HasDeclaredCopyConstructorWithConstParam
1984 = FromData.HasDeclaredCopyConstructorWithConstParam;
1985 ToData.HasDeclaredCopyAssignmentWithConstParam
1986 = FromData.HasDeclaredCopyAssignmentWithConstParam;
Richard Smith561fb152012-02-25 07:33:38 +00001987 ToData.IsLambda = FromData.IsLambda;
1988
Chris Lattner0e62c1c2011-07-23 10:55:15 +00001989 SmallVector<CXXBaseSpecifier *, 4> Bases;
Douglas Gregore2e50d332010-12-01 01:36:18 +00001990 for (CXXRecordDecl::base_class_iterator
1991 Base1 = FromCXX->bases_begin(),
1992 FromBaseEnd = FromCXX->bases_end();
1993 Base1 != FromBaseEnd;
1994 ++Base1) {
1995 QualType T = Importer.Import(Base1->getType());
1996 if (T.isNull())
Douglas Gregor96303ea2010-12-02 19:33:37 +00001997 return true;
Douglas Gregor752a5952011-01-03 22:36:02 +00001998
1999 SourceLocation EllipsisLoc;
2000 if (Base1->isPackExpansion())
2001 EllipsisLoc = Importer.Import(Base1->getEllipsisLoc());
Douglas Gregord451ea92011-07-29 23:31:30 +00002002
2003 // Ensure that we have a definition for the base.
2004 ImportDefinitionIfNeeded(Base1->getType()->getAsCXXRecordDecl());
2005
Douglas Gregore2e50d332010-12-01 01:36:18 +00002006 Bases.push_back(
2007 new (Importer.getToContext())
2008 CXXBaseSpecifier(Importer.Import(Base1->getSourceRange()),
2009 Base1->isVirtual(),
2010 Base1->isBaseOfClass(),
2011 Base1->getAccessSpecifierAsWritten(),
Douglas Gregor752a5952011-01-03 22:36:02 +00002012 Importer.Import(Base1->getTypeSourceInfo()),
2013 EllipsisLoc));
Douglas Gregore2e50d332010-12-01 01:36:18 +00002014 }
2015 if (!Bases.empty())
2016 ToCXX->setBases(Bases.data(), Bases.size());
2017 }
2018
Douglas Gregor2e15c842012-02-01 21:00:38 +00002019 if (shouldForceImportDeclContext(Kind))
Douglas Gregor95d82832012-01-24 18:36:04 +00002020 ImportDeclContext(From, /*ForceImport=*/true);
2021
Douglas Gregore2e50d332010-12-01 01:36:18 +00002022 To->completeDefinition();
Douglas Gregor96303ea2010-12-02 19:33:37 +00002023 return false;
Douglas Gregore2e50d332010-12-01 01:36:18 +00002024}
2025
Larisse Voufo39a1e502013-08-06 01:03:05 +00002026bool ASTNodeImporter::ImportDefinition(VarDecl *From, VarDecl *To,
2027 ImportDefinitionKind Kind) {
2028 if (To->getDefinition())
2029 return false;
2030
2031 // FIXME: Can we really import any initializer? Alternatively, we could force
2032 // ourselves to import every declaration of a variable and then only use
2033 // getInit() here.
2034 To->setInit(Importer.Import(const_cast<Expr *>(From->getAnyInitializer())));
2035
2036 // FIXME: Other bits to merge?
2037
2038 return false;
2039}
2040
Douglas Gregord451ea92011-07-29 23:31:30 +00002041bool ASTNodeImporter::ImportDefinition(EnumDecl *From, EnumDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +00002042 ImportDefinitionKind Kind) {
2043 if (To->getDefinition() || To->isBeingDefined()) {
2044 if (Kind == IDK_Everything)
2045 ImportDeclContext(From, /*ForceImport=*/true);
Douglas Gregord451ea92011-07-29 23:31:30 +00002046 return false;
Douglas Gregor2e15c842012-02-01 21:00:38 +00002047 }
Douglas Gregord451ea92011-07-29 23:31:30 +00002048
2049 To->startDefinition();
2050
2051 QualType T = Importer.Import(Importer.getFromContext().getTypeDeclType(From));
2052 if (T.isNull())
2053 return true;
2054
2055 QualType ToPromotionType = Importer.Import(From->getPromotionType());
2056 if (ToPromotionType.isNull())
2057 return true;
Douglas Gregor2e15c842012-02-01 21:00:38 +00002058
2059 if (shouldForceImportDeclContext(Kind))
2060 ImportDeclContext(From, /*ForceImport=*/true);
Douglas Gregord451ea92011-07-29 23:31:30 +00002061
2062 // FIXME: we might need to merge the number of positive or negative bits
2063 // if the enumerator lists don't match.
2064 To->completeDefinition(T, ToPromotionType,
2065 From->getNumPositiveBits(),
2066 From->getNumNegativeBits());
2067 return false;
2068}
2069
Douglas Gregora082a492010-11-30 19:14:50 +00002070TemplateParameterList *ASTNodeImporter::ImportTemplateParameterList(
2071 TemplateParameterList *Params) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002072 SmallVector<NamedDecl *, 4> ToParams;
Douglas Gregora082a492010-11-30 19:14:50 +00002073 ToParams.reserve(Params->size());
2074 for (TemplateParameterList::iterator P = Params->begin(),
2075 PEnd = Params->end();
2076 P != PEnd; ++P) {
2077 Decl *To = Importer.Import(*P);
2078 if (!To)
2079 return 0;
2080
2081 ToParams.push_back(cast<NamedDecl>(To));
2082 }
2083
2084 return TemplateParameterList::Create(Importer.getToContext(),
2085 Importer.Import(Params->getTemplateLoc()),
2086 Importer.Import(Params->getLAngleLoc()),
2087 ToParams.data(), ToParams.size(),
2088 Importer.Import(Params->getRAngleLoc()));
2089}
2090
Douglas Gregore2e50d332010-12-01 01:36:18 +00002091TemplateArgument
2092ASTNodeImporter::ImportTemplateArgument(const TemplateArgument &From) {
2093 switch (From.getKind()) {
2094 case TemplateArgument::Null:
2095 return TemplateArgument();
2096
2097 case TemplateArgument::Type: {
2098 QualType ToType = Importer.Import(From.getAsType());
2099 if (ToType.isNull())
2100 return TemplateArgument();
2101 return TemplateArgument(ToType);
2102 }
2103
2104 case TemplateArgument::Integral: {
2105 QualType ToType = Importer.Import(From.getIntegralType());
2106 if (ToType.isNull())
2107 return TemplateArgument();
Benjamin Kramer6003ad52012-06-07 15:09:51 +00002108 return TemplateArgument(From, ToType);
Douglas Gregore2e50d332010-12-01 01:36:18 +00002109 }
2110
Eli Friedmanb826a002012-09-26 02:36:12 +00002111 case TemplateArgument::Declaration: {
2112 ValueDecl *FromD = From.getAsDecl();
2113 if (ValueDecl *To = cast_or_null<ValueDecl>(Importer.Import(FromD)))
2114 return TemplateArgument(To, From.isDeclForReferenceParam());
Douglas Gregore2e50d332010-12-01 01:36:18 +00002115 return TemplateArgument();
Eli Friedmanb826a002012-09-26 02:36:12 +00002116 }
2117
2118 case TemplateArgument::NullPtr: {
2119 QualType ToType = Importer.Import(From.getNullPtrType());
2120 if (ToType.isNull())
2121 return TemplateArgument();
2122 return TemplateArgument(ToType, /*isNullPtr*/true);
2123 }
2124
Douglas Gregore2e50d332010-12-01 01:36:18 +00002125 case TemplateArgument::Template: {
2126 TemplateName ToTemplate = Importer.Import(From.getAsTemplate());
2127 if (ToTemplate.isNull())
2128 return TemplateArgument();
2129
2130 return TemplateArgument(ToTemplate);
2131 }
Douglas Gregore4ff4b52011-01-05 18:58:31 +00002132
2133 case TemplateArgument::TemplateExpansion: {
2134 TemplateName ToTemplate
2135 = Importer.Import(From.getAsTemplateOrTemplatePattern());
2136 if (ToTemplate.isNull())
2137 return TemplateArgument();
2138
Douglas Gregore1d60df2011-01-14 23:41:42 +00002139 return TemplateArgument(ToTemplate, From.getNumTemplateExpansions());
Douglas Gregore4ff4b52011-01-05 18:58:31 +00002140 }
2141
Douglas Gregore2e50d332010-12-01 01:36:18 +00002142 case TemplateArgument::Expression:
2143 if (Expr *ToExpr = Importer.Import(From.getAsExpr()))
2144 return TemplateArgument(ToExpr);
2145 return TemplateArgument();
2146
2147 case TemplateArgument::Pack: {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002148 SmallVector<TemplateArgument, 2> ToPack;
Douglas Gregore2e50d332010-12-01 01:36:18 +00002149 ToPack.reserve(From.pack_size());
2150 if (ImportTemplateArguments(From.pack_begin(), From.pack_size(), ToPack))
2151 return TemplateArgument();
2152
2153 TemplateArgument *ToArgs
2154 = new (Importer.getToContext()) TemplateArgument[ToPack.size()];
2155 std::copy(ToPack.begin(), ToPack.end(), ToArgs);
2156 return TemplateArgument(ToArgs, ToPack.size());
2157 }
2158 }
2159
2160 llvm_unreachable("Invalid template argument kind");
Douglas Gregore2e50d332010-12-01 01:36:18 +00002161}
2162
2163bool ASTNodeImporter::ImportTemplateArguments(const TemplateArgument *FromArgs,
2164 unsigned NumFromArgs,
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002165 SmallVectorImpl<TemplateArgument> &ToArgs) {
Douglas Gregore2e50d332010-12-01 01:36:18 +00002166 for (unsigned I = 0; I != NumFromArgs; ++I) {
2167 TemplateArgument To = ImportTemplateArgument(FromArgs[I]);
2168 if (To.isNull() && !FromArgs[I].isNull())
2169 return true;
2170
2171 ToArgs.push_back(To);
2172 }
2173
2174 return false;
2175}
2176
Douglas Gregor5c73e912010-02-11 00:48:18 +00002177bool ASTNodeImporter::IsStructuralMatch(RecordDecl *FromRecord,
Douglas Gregordd6006f2012-07-17 21:16:27 +00002178 RecordDecl *ToRecord, bool Complain) {
Sean Callananc665c9e2013-10-09 21:45:11 +00002179 // Eliminate a potential failure point where we attempt to re-import
2180 // something we're trying to import while completing ToRecord.
2181 Decl *ToOrigin = Importer.GetOriginalDecl(ToRecord);
2182 if (ToOrigin) {
2183 RecordDecl *ToOriginRecord = dyn_cast<RecordDecl>(ToOrigin);
2184 if (ToOriginRecord)
2185 ToRecord = ToOriginRecord;
2186 }
2187
Benjamin Kramer26d19c52010-02-18 13:02:13 +00002188 StructuralEquivalenceContext Ctx(Importer.getFromContext(),
Sean Callananc665c9e2013-10-09 21:45:11 +00002189 ToRecord->getASTContext(),
Douglas Gregordd6006f2012-07-17 21:16:27 +00002190 Importer.getNonEquivalentDecls(),
2191 false, Complain);
Benjamin Kramer26d19c52010-02-18 13:02:13 +00002192 return Ctx.IsStructurallyEquivalent(FromRecord, ToRecord);
Douglas Gregor5c73e912010-02-11 00:48:18 +00002193}
2194
Larisse Voufo39a1e502013-08-06 01:03:05 +00002195bool ASTNodeImporter::IsStructuralMatch(VarDecl *FromVar, VarDecl *ToVar,
2196 bool Complain) {
2197 StructuralEquivalenceContext Ctx(
2198 Importer.getFromContext(), Importer.getToContext(),
2199 Importer.getNonEquivalentDecls(), false, Complain);
2200 return Ctx.IsStructurallyEquivalent(FromVar, ToVar);
2201}
2202
Douglas Gregor98c10182010-02-12 22:17:39 +00002203bool ASTNodeImporter::IsStructuralMatch(EnumDecl *FromEnum, EnumDecl *ToEnum) {
Benjamin Kramer26d19c52010-02-18 13:02:13 +00002204 StructuralEquivalenceContext Ctx(Importer.getFromContext(),
Douglas Gregor3996e242010-02-15 22:01:00 +00002205 Importer.getToContext(),
Douglas Gregorb4964f72010-02-15 23:54:17 +00002206 Importer.getNonEquivalentDecls());
Benjamin Kramer26d19c52010-02-18 13:02:13 +00002207 return Ctx.IsStructurallyEquivalent(FromEnum, ToEnum);
Douglas Gregor98c10182010-02-12 22:17:39 +00002208}
2209
Douglas Gregor91155082012-11-14 22:29:20 +00002210bool ASTNodeImporter::IsStructuralMatch(EnumConstantDecl *FromEC,
2211 EnumConstantDecl *ToEC)
2212{
2213 const llvm::APSInt &FromVal = FromEC->getInitVal();
2214 const llvm::APSInt &ToVal = ToEC->getInitVal();
2215
2216 return FromVal.isSigned() == ToVal.isSigned() &&
2217 FromVal.getBitWidth() == ToVal.getBitWidth() &&
2218 FromVal == ToVal;
2219}
2220
2221bool ASTNodeImporter::IsStructuralMatch(ClassTemplateDecl *From,
Douglas Gregora082a492010-11-30 19:14:50 +00002222 ClassTemplateDecl *To) {
2223 StructuralEquivalenceContext Ctx(Importer.getFromContext(),
2224 Importer.getToContext(),
2225 Importer.getNonEquivalentDecls());
2226 return Ctx.IsStructurallyEquivalent(From, To);
2227}
2228
Larisse Voufo39a1e502013-08-06 01:03:05 +00002229bool ASTNodeImporter::IsStructuralMatch(VarTemplateDecl *From,
2230 VarTemplateDecl *To) {
2231 StructuralEquivalenceContext Ctx(Importer.getFromContext(),
2232 Importer.getToContext(),
2233 Importer.getNonEquivalentDecls());
2234 return Ctx.IsStructurallyEquivalent(From, To);
2235}
2236
Douglas Gregore4c83e42010-02-09 22:48:33 +00002237Decl *ASTNodeImporter::VisitDecl(Decl *D) {
Douglas Gregor811663e2010-02-10 00:15:17 +00002238 Importer.FromDiag(D->getLocation(), diag::err_unsupported_ast_node)
Douglas Gregore4c83e42010-02-09 22:48:33 +00002239 << D->getDeclKindName();
2240 return 0;
2241}
2242
Sean Callanan65198272011-11-17 23:20:56 +00002243Decl *ASTNodeImporter::VisitTranslationUnitDecl(TranslationUnitDecl *D) {
2244 TranslationUnitDecl *ToD =
2245 Importer.getToContext().getTranslationUnitDecl();
2246
2247 Importer.Imported(D, ToD);
2248
2249 return ToD;
2250}
2251
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002252Decl *ASTNodeImporter::VisitNamespaceDecl(NamespaceDecl *D) {
2253 // Import the major distinguishing characteristics of this namespace.
2254 DeclContext *DC, *LexicalDC;
2255 DeclarationName Name;
2256 SourceLocation Loc;
2257 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2258 return 0;
2259
2260 NamespaceDecl *MergeWithNamespace = 0;
2261 if (!Name) {
2262 // This is an anonymous namespace. Adopt an existing anonymous
2263 // namespace if we can.
2264 // FIXME: Not testable.
2265 if (TranslationUnitDecl *TU = dyn_cast<TranslationUnitDecl>(DC))
2266 MergeWithNamespace = TU->getAnonymousNamespace();
2267 else
2268 MergeWithNamespace = cast<NamespaceDecl>(DC)->getAnonymousNamespace();
2269 } else {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002270 SmallVector<NamedDecl *, 4> ConflictingDecls;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002271 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002272 DC->localUncachedLookup(Name, FoundDecls);
2273 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2274 if (!FoundDecls[I]->isInIdentifierNamespace(Decl::IDNS_Namespace))
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002275 continue;
2276
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002277 if (NamespaceDecl *FoundNS = dyn_cast<NamespaceDecl>(FoundDecls[I])) {
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002278 MergeWithNamespace = FoundNS;
2279 ConflictingDecls.clear();
2280 break;
2281 }
2282
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002283 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002284 }
2285
2286 if (!ConflictingDecls.empty()) {
John McCalle87beb22010-04-23 18:46:30 +00002287 Name = Importer.HandleNameConflict(Name, DC, Decl::IDNS_Namespace,
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002288 ConflictingDecls.data(),
2289 ConflictingDecls.size());
2290 }
2291 }
2292
2293 // Create the "to" namespace, if needed.
2294 NamespaceDecl *ToNamespace = MergeWithNamespace;
2295 if (!ToNamespace) {
Abramo Bagnarab5545be2011-03-08 12:38:20 +00002296 ToNamespace = NamespaceDecl::Create(Importer.getToContext(), DC,
Douglas Gregore57e7522012-01-07 09:11:48 +00002297 D->isInline(),
Abramo Bagnarab5545be2011-03-08 12:38:20 +00002298 Importer.Import(D->getLocStart()),
Douglas Gregore57e7522012-01-07 09:11:48 +00002299 Loc, Name.getAsIdentifierInfo(),
2300 /*PrevDecl=*/0);
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002301 ToNamespace->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00002302 LexicalDC->addDeclInternal(ToNamespace);
Douglas Gregorf18a2c72010-02-21 18:26:36 +00002303
2304 // If this is an anonymous namespace, register it as the anonymous
2305 // namespace within its context.
2306 if (!Name) {
2307 if (TranslationUnitDecl *TU = dyn_cast<TranslationUnitDecl>(DC))
2308 TU->setAnonymousNamespace(ToNamespace);
2309 else
2310 cast<NamespaceDecl>(DC)->setAnonymousNamespace(ToNamespace);
2311 }
2312 }
2313 Importer.Imported(D, ToNamespace);
2314
2315 ImportDeclContext(D);
2316
2317 return ToNamespace;
2318}
2319
Richard Smithdda56e42011-04-15 14:24:37 +00002320Decl *ASTNodeImporter::VisitTypedefNameDecl(TypedefNameDecl *D, bool IsAlias) {
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002321 // Import the major distinguishing characteristics of this typedef.
2322 DeclContext *DC, *LexicalDC;
2323 DeclarationName Name;
2324 SourceLocation Loc;
2325 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2326 return 0;
2327
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002328 // If this typedef is not in block scope, determine whether we've
2329 // seen a typedef with the same name (that we can merge with) or any
2330 // other entity by that name (which name lookup could conflict with).
2331 if (!DC->isFunctionOrMethod()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002332 SmallVector<NamedDecl *, 4> ConflictingDecls;
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002333 unsigned IDNS = Decl::IDNS_Ordinary;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002334 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002335 DC->localUncachedLookup(Name, FoundDecls);
2336 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2337 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002338 continue;
Richard Smithdda56e42011-04-15 14:24:37 +00002339 if (TypedefNameDecl *FoundTypedef =
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002340 dyn_cast<TypedefNameDecl>(FoundDecls[I])) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00002341 if (Importer.IsStructurallyEquivalent(D->getUnderlyingType(),
2342 FoundTypedef->getUnderlyingType()))
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002343 return Importer.Imported(D, FoundTypedef);
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002344 }
2345
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002346 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002347 }
2348
2349 if (!ConflictingDecls.empty()) {
2350 Name = Importer.HandleNameConflict(Name, DC, IDNS,
2351 ConflictingDecls.data(),
2352 ConflictingDecls.size());
2353 if (!Name)
2354 return 0;
2355 }
2356 }
2357
Douglas Gregorb4964f72010-02-15 23:54:17 +00002358 // Import the underlying type of this typedef;
2359 QualType T = Importer.Import(D->getUnderlyingType());
2360 if (T.isNull())
2361 return 0;
2362
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002363 // Create the new typedef node.
2364 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
Abramo Bagnarab3185b02011-03-06 15:48:19 +00002365 SourceLocation StartL = Importer.Import(D->getLocStart());
Richard Smithdda56e42011-04-15 14:24:37 +00002366 TypedefNameDecl *ToTypedef;
2367 if (IsAlias)
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002368 ToTypedef = TypeAliasDecl::Create(Importer.getToContext(), DC,
2369 StartL, Loc,
2370 Name.getAsIdentifierInfo(),
2371 TInfo);
2372 else
Richard Smithdda56e42011-04-15 14:24:37 +00002373 ToTypedef = TypedefDecl::Create(Importer.getToContext(), DC,
2374 StartL, Loc,
2375 Name.getAsIdentifierInfo(),
2376 TInfo);
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002377
Douglas Gregordd483172010-02-22 17:42:47 +00002378 ToTypedef->setAccess(D->getAccess());
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002379 ToTypedef->setLexicalDeclContext(LexicalDC);
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002380 Importer.Imported(D, ToTypedef);
Sean Callanan95e74be2011-10-21 02:57:43 +00002381 LexicalDC->addDeclInternal(ToTypedef);
Douglas Gregorb4964f72010-02-15 23:54:17 +00002382
Douglas Gregor5fa74c32010-02-10 21:10:29 +00002383 return ToTypedef;
2384}
2385
Richard Smithdda56e42011-04-15 14:24:37 +00002386Decl *ASTNodeImporter::VisitTypedefDecl(TypedefDecl *D) {
2387 return VisitTypedefNameDecl(D, /*IsAlias=*/false);
2388}
2389
2390Decl *ASTNodeImporter::VisitTypeAliasDecl(TypeAliasDecl *D) {
2391 return VisitTypedefNameDecl(D, /*IsAlias=*/true);
2392}
2393
Douglas Gregor98c10182010-02-12 22:17:39 +00002394Decl *ASTNodeImporter::VisitEnumDecl(EnumDecl *D) {
2395 // Import the major distinguishing characteristics of this enum.
2396 DeclContext *DC, *LexicalDC;
2397 DeclarationName Name;
2398 SourceLocation Loc;
2399 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2400 return 0;
2401
2402 // Figure out what enum name we're looking for.
2403 unsigned IDNS = Decl::IDNS_Tag;
2404 DeclarationName SearchName = Name;
Richard Smithdda56e42011-04-15 14:24:37 +00002405 if (!SearchName && D->getTypedefNameForAnonDecl()) {
2406 SearchName = Importer.Import(D->getTypedefNameForAnonDecl()->getDeclName());
Douglas Gregor98c10182010-02-12 22:17:39 +00002407 IDNS = Decl::IDNS_Ordinary;
David Blaikiebbafb8a2012-03-11 07:00:24 +00002408 } else if (Importer.getToContext().getLangOpts().CPlusPlus)
Douglas Gregor98c10182010-02-12 22:17:39 +00002409 IDNS |= Decl::IDNS_Ordinary;
2410
2411 // We may already have an enum of the same name; try to find and match it.
2412 if (!DC->isFunctionOrMethod() && SearchName) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002413 SmallVector<NamedDecl *, 4> ConflictingDecls;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002414 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002415 DC->localUncachedLookup(SearchName, FoundDecls);
2416 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2417 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregor98c10182010-02-12 22:17:39 +00002418 continue;
2419
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002420 Decl *Found = FoundDecls[I];
Richard Smithdda56e42011-04-15 14:24:37 +00002421 if (TypedefNameDecl *Typedef = dyn_cast<TypedefNameDecl>(Found)) {
Douglas Gregor98c10182010-02-12 22:17:39 +00002422 if (const TagType *Tag = Typedef->getUnderlyingType()->getAs<TagType>())
2423 Found = Tag->getDecl();
2424 }
2425
2426 if (EnumDecl *FoundEnum = dyn_cast<EnumDecl>(Found)) {
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002427 if (IsStructuralMatch(D, FoundEnum))
2428 return Importer.Imported(D, FoundEnum);
Douglas Gregor98c10182010-02-12 22:17:39 +00002429 }
2430
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002431 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregor98c10182010-02-12 22:17:39 +00002432 }
2433
2434 if (!ConflictingDecls.empty()) {
2435 Name = Importer.HandleNameConflict(Name, DC, IDNS,
2436 ConflictingDecls.data(),
2437 ConflictingDecls.size());
2438 }
2439 }
2440
2441 // Create the enum declaration.
Abramo Bagnara29c2d462011-03-09 14:09:51 +00002442 EnumDecl *D2 = EnumDecl::Create(Importer.getToContext(), DC,
2443 Importer.Import(D->getLocStart()),
2444 Loc, Name.getAsIdentifierInfo(), 0,
Abramo Bagnara0e05e242010-12-03 18:54:17 +00002445 D->isScoped(), D->isScopedUsingClassTag(),
2446 D->isFixed());
John McCall3e11ebe2010-03-15 10:12:16 +00002447 // Import the qualifier, if any.
Douglas Gregor14454802011-02-25 02:25:35 +00002448 D2->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
Douglas Gregordd483172010-02-22 17:42:47 +00002449 D2->setAccess(D->getAccess());
Douglas Gregor3996e242010-02-15 22:01:00 +00002450 D2->setLexicalDeclContext(LexicalDC);
2451 Importer.Imported(D, D2);
Sean Callanan95e74be2011-10-21 02:57:43 +00002452 LexicalDC->addDeclInternal(D2);
Douglas Gregor98c10182010-02-12 22:17:39 +00002453
2454 // Import the integer type.
2455 QualType ToIntegerType = Importer.Import(D->getIntegerType());
2456 if (ToIntegerType.isNull())
2457 return 0;
Douglas Gregor3996e242010-02-15 22:01:00 +00002458 D2->setIntegerType(ToIntegerType);
Douglas Gregor98c10182010-02-12 22:17:39 +00002459
2460 // Import the definition
John McCallf937c022011-10-07 06:10:15 +00002461 if (D->isCompleteDefinition() && ImportDefinition(D, D2))
Douglas Gregord451ea92011-07-29 23:31:30 +00002462 return 0;
Douglas Gregor98c10182010-02-12 22:17:39 +00002463
Douglas Gregor3996e242010-02-15 22:01:00 +00002464 return D2;
Douglas Gregor98c10182010-02-12 22:17:39 +00002465}
2466
Douglas Gregor5c73e912010-02-11 00:48:18 +00002467Decl *ASTNodeImporter::VisitRecordDecl(RecordDecl *D) {
2468 // If this record has a definition in the translation unit we're coming from,
2469 // but this particular declaration is not that definition, import the
2470 // definition and map to that.
Douglas Gregor0a5a2212010-02-11 01:04:33 +00002471 TagDecl *Definition = D->getDefinition();
Douglas Gregor5c73e912010-02-11 00:48:18 +00002472 if (Definition && Definition != D) {
2473 Decl *ImportedDef = Importer.Import(Definition);
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002474 if (!ImportedDef)
2475 return 0;
2476
2477 return Importer.Imported(D, ImportedDef);
Douglas Gregor5c73e912010-02-11 00:48:18 +00002478 }
2479
2480 // Import the major distinguishing characteristics of this record.
2481 DeclContext *DC, *LexicalDC;
2482 DeclarationName Name;
2483 SourceLocation Loc;
2484 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2485 return 0;
2486
2487 // Figure out what structure name we're looking for.
2488 unsigned IDNS = Decl::IDNS_Tag;
2489 DeclarationName SearchName = Name;
Richard Smithdda56e42011-04-15 14:24:37 +00002490 if (!SearchName && D->getTypedefNameForAnonDecl()) {
2491 SearchName = Importer.Import(D->getTypedefNameForAnonDecl()->getDeclName());
Douglas Gregor5c73e912010-02-11 00:48:18 +00002492 IDNS = Decl::IDNS_Ordinary;
David Blaikiebbafb8a2012-03-11 07:00:24 +00002493 } else if (Importer.getToContext().getLangOpts().CPlusPlus)
Douglas Gregor5c73e912010-02-11 00:48:18 +00002494 IDNS |= Decl::IDNS_Ordinary;
2495
2496 // We may already have a record of the same name; try to find and match it.
Douglas Gregor25791052010-02-12 00:09:27 +00002497 RecordDecl *AdoptDecl = 0;
Douglas Gregordd6006f2012-07-17 21:16:27 +00002498 if (!DC->isFunctionOrMethod()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002499 SmallVector<NamedDecl *, 4> ConflictingDecls;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002500 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002501 DC->localUncachedLookup(SearchName, FoundDecls);
2502 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2503 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregor5c73e912010-02-11 00:48:18 +00002504 continue;
2505
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002506 Decl *Found = FoundDecls[I];
Richard Smithdda56e42011-04-15 14:24:37 +00002507 if (TypedefNameDecl *Typedef = dyn_cast<TypedefNameDecl>(Found)) {
Douglas Gregor5c73e912010-02-11 00:48:18 +00002508 if (const TagType *Tag = Typedef->getUnderlyingType()->getAs<TagType>())
2509 Found = Tag->getDecl();
2510 }
2511
2512 if (RecordDecl *FoundRecord = dyn_cast<RecordDecl>(Found)) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002513 if (D->isAnonymousStructOrUnion() &&
2514 FoundRecord->isAnonymousStructOrUnion()) {
2515 // If both anonymous structs/unions are in a record context, make sure
2516 // they occur in the same location in the context records.
David Blaikie05785d12013-02-20 22:23:23 +00002517 if (Optional<unsigned> Index1
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002518 = findAnonymousStructOrUnionIndex(D)) {
David Blaikie05785d12013-02-20 22:23:23 +00002519 if (Optional<unsigned> Index2 =
2520 findAnonymousStructOrUnionIndex(FoundRecord)) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002521 if (*Index1 != *Index2)
2522 continue;
2523 }
2524 }
2525 }
2526
Douglas Gregor25791052010-02-12 00:09:27 +00002527 if (RecordDecl *FoundDef = FoundRecord->getDefinition()) {
Douglas Gregordd6006f2012-07-17 21:16:27 +00002528 if ((SearchName && !D->isCompleteDefinition())
2529 || (D->isCompleteDefinition() &&
2530 D->isAnonymousStructOrUnion()
2531 == FoundDef->isAnonymousStructOrUnion() &&
2532 IsStructuralMatch(D, FoundDef))) {
Douglas Gregor25791052010-02-12 00:09:27 +00002533 // The record types structurally match, or the "from" translation
2534 // unit only had a forward declaration anyway; call it the same
2535 // function.
2536 // FIXME: For C++, we should also merge methods here.
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002537 return Importer.Imported(D, FoundDef);
Douglas Gregor25791052010-02-12 00:09:27 +00002538 }
Douglas Gregordd6006f2012-07-17 21:16:27 +00002539 } else if (!D->isCompleteDefinition()) {
Douglas Gregor25791052010-02-12 00:09:27 +00002540 // We have a forward declaration of this type, so adopt that forward
2541 // declaration rather than building a new one.
2542 AdoptDecl = FoundRecord;
2543 continue;
Douglas Gregordd6006f2012-07-17 21:16:27 +00002544 } else if (!SearchName) {
2545 continue;
2546 }
Douglas Gregor5c73e912010-02-11 00:48:18 +00002547 }
2548
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002549 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregor5c73e912010-02-11 00:48:18 +00002550 }
2551
Douglas Gregordd6006f2012-07-17 21:16:27 +00002552 if (!ConflictingDecls.empty() && SearchName) {
Douglas Gregor5c73e912010-02-11 00:48:18 +00002553 Name = Importer.HandleNameConflict(Name, DC, IDNS,
2554 ConflictingDecls.data(),
2555 ConflictingDecls.size());
2556 }
2557 }
2558
2559 // Create the record declaration.
Douglas Gregor3996e242010-02-15 22:01:00 +00002560 RecordDecl *D2 = AdoptDecl;
Abramo Bagnara29c2d462011-03-09 14:09:51 +00002561 SourceLocation StartLoc = Importer.Import(D->getLocStart());
Douglas Gregor3996e242010-02-15 22:01:00 +00002562 if (!D2) {
John McCall1c70e992010-06-03 19:28:45 +00002563 if (isa<CXXRecordDecl>(D)) {
Douglas Gregor3996e242010-02-15 22:01:00 +00002564 CXXRecordDecl *D2CXX = CXXRecordDecl::Create(Importer.getToContext(),
Douglas Gregor25791052010-02-12 00:09:27 +00002565 D->getTagKind(),
Abramo Bagnara29c2d462011-03-09 14:09:51 +00002566 DC, StartLoc, Loc,
2567 Name.getAsIdentifierInfo());
Douglas Gregor3996e242010-02-15 22:01:00 +00002568 D2 = D2CXX;
Douglas Gregordd483172010-02-22 17:42:47 +00002569 D2->setAccess(D->getAccess());
Douglas Gregor25791052010-02-12 00:09:27 +00002570 } else {
Douglas Gregor3996e242010-02-15 22:01:00 +00002571 D2 = RecordDecl::Create(Importer.getToContext(), D->getTagKind(),
Abramo Bagnara29c2d462011-03-09 14:09:51 +00002572 DC, StartLoc, Loc, Name.getAsIdentifierInfo());
Douglas Gregor5c73e912010-02-11 00:48:18 +00002573 }
Douglas Gregor14454802011-02-25 02:25:35 +00002574
2575 D2->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
Douglas Gregor3996e242010-02-15 22:01:00 +00002576 D2->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00002577 LexicalDC->addDeclInternal(D2);
Douglas Gregordd6006f2012-07-17 21:16:27 +00002578 if (D->isAnonymousStructOrUnion())
2579 D2->setAnonymousStructOrUnion(true);
Douglas Gregor5c73e912010-02-11 00:48:18 +00002580 }
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002581
Douglas Gregor3996e242010-02-15 22:01:00 +00002582 Importer.Imported(D, D2);
Douglas Gregor25791052010-02-12 00:09:27 +00002583
Douglas Gregor95d82832012-01-24 18:36:04 +00002584 if (D->isCompleteDefinition() && ImportDefinition(D, D2, IDK_Default))
Douglas Gregore2e50d332010-12-01 01:36:18 +00002585 return 0;
Douglas Gregor5c73e912010-02-11 00:48:18 +00002586
Douglas Gregor3996e242010-02-15 22:01:00 +00002587 return D2;
Douglas Gregor5c73e912010-02-11 00:48:18 +00002588}
2589
Douglas Gregor98c10182010-02-12 22:17:39 +00002590Decl *ASTNodeImporter::VisitEnumConstantDecl(EnumConstantDecl *D) {
2591 // Import the major distinguishing characteristics of this enumerator.
2592 DeclContext *DC, *LexicalDC;
2593 DeclarationName Name;
2594 SourceLocation Loc;
Douglas Gregorb4964f72010-02-15 23:54:17 +00002595 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
Douglas Gregor98c10182010-02-12 22:17:39 +00002596 return 0;
Douglas Gregorb4964f72010-02-15 23:54:17 +00002597
2598 QualType T = Importer.Import(D->getType());
2599 if (T.isNull())
2600 return 0;
2601
Douglas Gregor98c10182010-02-12 22:17:39 +00002602 // Determine whether there are any other declarations with the same name and
2603 // in the same context.
2604 if (!LexicalDC->isFunctionOrMethod()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002605 SmallVector<NamedDecl *, 4> ConflictingDecls;
Douglas Gregor98c10182010-02-12 22:17:39 +00002606 unsigned IDNS = Decl::IDNS_Ordinary;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002607 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002608 DC->localUncachedLookup(Name, FoundDecls);
2609 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2610 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregor98c10182010-02-12 22:17:39 +00002611 continue;
Douglas Gregor91155082012-11-14 22:29:20 +00002612
2613 if (EnumConstantDecl *FoundEnumConstant
2614 = dyn_cast<EnumConstantDecl>(FoundDecls[I])) {
2615 if (IsStructuralMatch(D, FoundEnumConstant))
2616 return Importer.Imported(D, FoundEnumConstant);
2617 }
2618
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002619 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregor98c10182010-02-12 22:17:39 +00002620 }
2621
2622 if (!ConflictingDecls.empty()) {
2623 Name = Importer.HandleNameConflict(Name, DC, IDNS,
2624 ConflictingDecls.data(),
2625 ConflictingDecls.size());
2626 if (!Name)
2627 return 0;
2628 }
2629 }
2630
2631 Expr *Init = Importer.Import(D->getInitExpr());
2632 if (D->getInitExpr() && !Init)
2633 return 0;
2634
2635 EnumConstantDecl *ToEnumerator
2636 = EnumConstantDecl::Create(Importer.getToContext(), cast<EnumDecl>(DC), Loc,
2637 Name.getAsIdentifierInfo(), T,
2638 Init, D->getInitVal());
Douglas Gregordd483172010-02-22 17:42:47 +00002639 ToEnumerator->setAccess(D->getAccess());
Douglas Gregor98c10182010-02-12 22:17:39 +00002640 ToEnumerator->setLexicalDeclContext(LexicalDC);
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002641 Importer.Imported(D, ToEnumerator);
Sean Callanan95e74be2011-10-21 02:57:43 +00002642 LexicalDC->addDeclInternal(ToEnumerator);
Douglas Gregor98c10182010-02-12 22:17:39 +00002643 return ToEnumerator;
2644}
Douglas Gregor5c73e912010-02-11 00:48:18 +00002645
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002646Decl *ASTNodeImporter::VisitFunctionDecl(FunctionDecl *D) {
2647 // Import the major distinguishing characteristics of this function.
2648 DeclContext *DC, *LexicalDC;
2649 DeclarationName Name;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002650 SourceLocation Loc;
Douglas Gregorb4964f72010-02-15 23:54:17 +00002651 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00002652 return 0;
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002653
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002654 // Try to find a function in our own ("to") context with the same name, same
2655 // type, and in the same context as the function we're importing.
2656 if (!LexicalDC->isFunctionOrMethod()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002657 SmallVector<NamedDecl *, 4> ConflictingDecls;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002658 unsigned IDNS = Decl::IDNS_Ordinary;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002659 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002660 DC->localUncachedLookup(Name, FoundDecls);
2661 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2662 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002663 continue;
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00002664
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002665 if (FunctionDecl *FoundFunction = dyn_cast<FunctionDecl>(FoundDecls[I])) {
Rafael Espindola3ae00052013-05-13 00:12:11 +00002666 if (FoundFunction->hasExternalFormalLinkage() &&
2667 D->hasExternalFormalLinkage()) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00002668 if (Importer.IsStructurallyEquivalent(D->getType(),
2669 FoundFunction->getType())) {
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002670 // FIXME: Actually try to merge the body and other attributes.
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002671 return Importer.Imported(D, FoundFunction);
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002672 }
2673
2674 // FIXME: Check for overloading more carefully, e.g., by boosting
2675 // Sema::IsOverload out to the AST library.
2676
2677 // Function overloading is okay in C++.
David Blaikiebbafb8a2012-03-11 07:00:24 +00002678 if (Importer.getToContext().getLangOpts().CPlusPlus)
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002679 continue;
2680
2681 // Complain about inconsistent function types.
2682 Importer.ToDiag(Loc, diag::err_odr_function_type_inconsistent)
Douglas Gregorb4964f72010-02-15 23:54:17 +00002683 << Name << D->getType() << FoundFunction->getType();
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002684 Importer.ToDiag(FoundFunction->getLocation(),
2685 diag::note_odr_value_here)
2686 << FoundFunction->getType();
2687 }
2688 }
2689
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002690 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002691 }
2692
2693 if (!ConflictingDecls.empty()) {
2694 Name = Importer.HandleNameConflict(Name, DC, IDNS,
2695 ConflictingDecls.data(),
2696 ConflictingDecls.size());
2697 if (!Name)
2698 return 0;
2699 }
Douglas Gregor62d311f2010-02-09 19:21:46 +00002700 }
Douglas Gregorb4964f72010-02-15 23:54:17 +00002701
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002702 DeclarationNameInfo NameInfo(Name, Loc);
2703 // Import additional name location/type info.
2704 ImportDeclarationNameLoc(D->getNameInfo(), NameInfo);
2705
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00002706 QualType FromTy = D->getType();
2707 bool usedDifferentExceptionSpec = false;
2708
2709 if (const FunctionProtoType *
2710 FromFPT = D->getType()->getAs<FunctionProtoType>()) {
2711 FunctionProtoType::ExtProtoInfo FromEPI = FromFPT->getExtProtoInfo();
2712 // FunctionProtoType::ExtProtoInfo's ExceptionSpecDecl can point to the
2713 // FunctionDecl that we are importing the FunctionProtoType for.
2714 // To avoid an infinite recursion when importing, create the FunctionDecl
2715 // with a simplified function type and update it afterwards.
2716 if (FromEPI.ExceptionSpecDecl || FromEPI.ExceptionSpecTemplate ||
2717 FromEPI.NoexceptExpr) {
2718 FunctionProtoType::ExtProtoInfo DefaultEPI;
2719 FromTy = Importer.getFromContext().getFunctionType(
Alp Toker9cacbab2014-01-20 20:26:09 +00002720 FromFPT->getResultType(), FromFPT->getParamTypes(), DefaultEPI);
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00002721 usedDifferentExceptionSpec = true;
2722 }
2723 }
2724
Douglas Gregorb4964f72010-02-15 23:54:17 +00002725 // Import the type.
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00002726 QualType T = Importer.Import(FromTy);
Douglas Gregorb4964f72010-02-15 23:54:17 +00002727 if (T.isNull())
2728 return 0;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002729
2730 // Import the function parameters.
Chris Lattner0e62c1c2011-07-23 10:55:15 +00002731 SmallVector<ParmVarDecl *, 8> Parameters;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002732 for (FunctionDecl::param_iterator P = D->param_begin(), PEnd = D->param_end();
2733 P != PEnd; ++P) {
2734 ParmVarDecl *ToP = cast_or_null<ParmVarDecl>(Importer.Import(*P));
2735 if (!ToP)
2736 return 0;
2737
2738 Parameters.push_back(ToP);
2739 }
2740
2741 // Create the imported function.
2742 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
Douglas Gregor00eace12010-02-21 18:29:16 +00002743 FunctionDecl *ToFunction = 0;
2744 if (CXXConstructorDecl *FromConstructor = dyn_cast<CXXConstructorDecl>(D)) {
2745 ToFunction = CXXConstructorDecl::Create(Importer.getToContext(),
2746 cast<CXXRecordDecl>(DC),
Abramo Bagnaradff19302011-03-08 08:55:46 +00002747 D->getInnerLocStart(),
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002748 NameInfo, T, TInfo,
Douglas Gregor00eace12010-02-21 18:29:16 +00002749 FromConstructor->isExplicit(),
2750 D->isInlineSpecified(),
Richard Smitha77a0a62011-08-15 21:04:07 +00002751 D->isImplicit(),
2752 D->isConstexpr());
Douglas Gregor00eace12010-02-21 18:29:16 +00002753 } else if (isa<CXXDestructorDecl>(D)) {
2754 ToFunction = CXXDestructorDecl::Create(Importer.getToContext(),
2755 cast<CXXRecordDecl>(DC),
Abramo Bagnaradff19302011-03-08 08:55:46 +00002756 D->getInnerLocStart(),
Craig Silversteinaf8808d2010-10-21 00:44:50 +00002757 NameInfo, T, TInfo,
Douglas Gregor00eace12010-02-21 18:29:16 +00002758 D->isInlineSpecified(),
2759 D->isImplicit());
2760 } else if (CXXConversionDecl *FromConversion
2761 = dyn_cast<CXXConversionDecl>(D)) {
2762 ToFunction = CXXConversionDecl::Create(Importer.getToContext(),
2763 cast<CXXRecordDecl>(DC),
Abramo Bagnaradff19302011-03-08 08:55:46 +00002764 D->getInnerLocStart(),
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002765 NameInfo, T, TInfo,
Douglas Gregor00eace12010-02-21 18:29:16 +00002766 D->isInlineSpecified(),
Douglas Gregorf2f08062011-03-08 17:10:18 +00002767 FromConversion->isExplicit(),
Richard Smitha77a0a62011-08-15 21:04:07 +00002768 D->isConstexpr(),
Douglas Gregorf2f08062011-03-08 17:10:18 +00002769 Importer.Import(D->getLocEnd()));
Douglas Gregora50ad132010-11-29 16:04:58 +00002770 } else if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D)) {
2771 ToFunction = CXXMethodDecl::Create(Importer.getToContext(),
2772 cast<CXXRecordDecl>(DC),
Abramo Bagnaradff19302011-03-08 08:55:46 +00002773 D->getInnerLocStart(),
Douglas Gregora50ad132010-11-29 16:04:58 +00002774 NameInfo, T, TInfo,
Rafael Espindola6ae7e502013-04-03 19:27:57 +00002775 Method->getStorageClass(),
Douglas Gregorf2f08062011-03-08 17:10:18 +00002776 Method->isInlineSpecified(),
Richard Smitha77a0a62011-08-15 21:04:07 +00002777 D->isConstexpr(),
Douglas Gregorf2f08062011-03-08 17:10:18 +00002778 Importer.Import(D->getLocEnd()));
Douglas Gregor00eace12010-02-21 18:29:16 +00002779 } else {
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002780 ToFunction = FunctionDecl::Create(Importer.getToContext(), DC,
Abramo Bagnaradff19302011-03-08 08:55:46 +00002781 D->getInnerLocStart(),
Abramo Bagnarad6d2f182010-08-11 22:01:17 +00002782 NameInfo, T, TInfo, D->getStorageClass(),
Douglas Gregor00eace12010-02-21 18:29:16 +00002783 D->isInlineSpecified(),
Richard Smitha77a0a62011-08-15 21:04:07 +00002784 D->hasWrittenPrototype(),
2785 D->isConstexpr());
Douglas Gregor00eace12010-02-21 18:29:16 +00002786 }
John McCall3e11ebe2010-03-15 10:12:16 +00002787
2788 // Import the qualifier, if any.
Douglas Gregor14454802011-02-25 02:25:35 +00002789 ToFunction->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
Douglas Gregordd483172010-02-22 17:42:47 +00002790 ToFunction->setAccess(D->getAccess());
Douglas Gregor43f54792010-02-17 02:12:47 +00002791 ToFunction->setLexicalDeclContext(LexicalDC);
John McCall08432c82011-01-27 02:37:01 +00002792 ToFunction->setVirtualAsWritten(D->isVirtualAsWritten());
2793 ToFunction->setTrivial(D->isTrivial());
2794 ToFunction->setPure(D->isPure());
Douglas Gregor43f54792010-02-17 02:12:47 +00002795 Importer.Imported(D, ToFunction);
Douglas Gregor62d311f2010-02-09 19:21:46 +00002796
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002797 // Set the parameters.
2798 for (unsigned I = 0, N = Parameters.size(); I != N; ++I) {
Douglas Gregor43f54792010-02-17 02:12:47 +00002799 Parameters[I]->setOwningFunction(ToFunction);
Sean Callanan95e74be2011-10-21 02:57:43 +00002800 ToFunction->addDeclInternal(Parameters[I]);
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002801 }
David Blaikie9c70e042011-09-21 18:16:56 +00002802 ToFunction->setParams(Parameters);
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002803
Argyrios Kyrtzidis2f458532012-09-25 19:26:39 +00002804 if (usedDifferentExceptionSpec) {
2805 // Update FunctionProtoType::ExtProtoInfo.
2806 QualType T = Importer.Import(D->getType());
2807 if (T.isNull())
2808 return 0;
2809 ToFunction->setType(T);
Argyrios Kyrtzidisb41791d2012-09-22 01:58:06 +00002810 }
2811
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002812 // FIXME: Other bits to merge?
Douglas Gregor0eaa2bf2010-10-01 23:55:07 +00002813
2814 // Add this function to the lexical context.
Sean Callanan95e74be2011-10-21 02:57:43 +00002815 LexicalDC->addDeclInternal(ToFunction);
Douglas Gregor0eaa2bf2010-10-01 23:55:07 +00002816
Douglas Gregor43f54792010-02-17 02:12:47 +00002817 return ToFunction;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00002818}
2819
Douglas Gregor00eace12010-02-21 18:29:16 +00002820Decl *ASTNodeImporter::VisitCXXMethodDecl(CXXMethodDecl *D) {
2821 return VisitFunctionDecl(D);
2822}
2823
2824Decl *ASTNodeImporter::VisitCXXConstructorDecl(CXXConstructorDecl *D) {
2825 return VisitCXXMethodDecl(D);
2826}
2827
2828Decl *ASTNodeImporter::VisitCXXDestructorDecl(CXXDestructorDecl *D) {
2829 return VisitCXXMethodDecl(D);
2830}
2831
2832Decl *ASTNodeImporter::VisitCXXConversionDecl(CXXConversionDecl *D) {
2833 return VisitCXXMethodDecl(D);
2834}
2835
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002836static unsigned getFieldIndex(Decl *F) {
2837 RecordDecl *Owner = dyn_cast<RecordDecl>(F->getDeclContext());
2838 if (!Owner)
2839 return 0;
2840
2841 unsigned Index = 1;
2842 for (DeclContext::decl_iterator D = Owner->noload_decls_begin(),
2843 DEnd = Owner->noload_decls_end();
2844 D != DEnd; ++D) {
2845 if (*D == F)
2846 return Index;
2847
2848 if (isa<FieldDecl>(*D) || isa<IndirectFieldDecl>(*D))
2849 ++Index;
2850 }
2851
2852 return Index;
2853}
2854
Douglas Gregor5c73e912010-02-11 00:48:18 +00002855Decl *ASTNodeImporter::VisitFieldDecl(FieldDecl *D) {
2856 // Import the major distinguishing characteristics of a variable.
2857 DeclContext *DC, *LexicalDC;
2858 DeclarationName Name;
Douglas Gregor5c73e912010-02-11 00:48:18 +00002859 SourceLocation Loc;
Douglas Gregorb4964f72010-02-15 23:54:17 +00002860 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2861 return 0;
2862
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002863 // Determine whether we've already imported this field.
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002864 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002865 DC->localUncachedLookup(Name, FoundDecls);
2866 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2867 if (FieldDecl *FoundField = dyn_cast<FieldDecl>(FoundDecls[I])) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002868 // For anonymous fields, match up by index.
2869 if (!Name && getFieldIndex(D) != getFieldIndex(FoundField))
2870 continue;
2871
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002872 if (Importer.IsStructurallyEquivalent(D->getType(),
2873 FoundField->getType())) {
2874 Importer.Imported(D, FoundField);
2875 return FoundField;
2876 }
2877
2878 Importer.ToDiag(Loc, diag::err_odr_field_type_inconsistent)
2879 << Name << D->getType() << FoundField->getType();
2880 Importer.ToDiag(FoundField->getLocation(), diag::note_odr_value_here)
2881 << FoundField->getType();
2882 return 0;
2883 }
2884 }
2885
Douglas Gregorb4964f72010-02-15 23:54:17 +00002886 // Import the type.
2887 QualType T = Importer.Import(D->getType());
2888 if (T.isNull())
Douglas Gregor5c73e912010-02-11 00:48:18 +00002889 return 0;
2890
2891 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
2892 Expr *BitWidth = Importer.Import(D->getBitWidth());
2893 if (!BitWidth && D->getBitWidth())
2894 return 0;
2895
Abramo Bagnaradff19302011-03-08 08:55:46 +00002896 FieldDecl *ToField = FieldDecl::Create(Importer.getToContext(), DC,
2897 Importer.Import(D->getInnerLocStart()),
Douglas Gregor5c73e912010-02-11 00:48:18 +00002898 Loc, Name.getAsIdentifierInfo(),
Richard Smith938f40b2011-06-11 17:19:42 +00002899 T, TInfo, BitWidth, D->isMutable(),
Richard Smith2b013182012-06-10 03:12:00 +00002900 D->getInClassInitStyle());
Douglas Gregordd483172010-02-22 17:42:47 +00002901 ToField->setAccess(D->getAccess());
Douglas Gregor5c73e912010-02-11 00:48:18 +00002902 ToField->setLexicalDeclContext(LexicalDC);
Richard Smith938f40b2011-06-11 17:19:42 +00002903 if (ToField->hasInClassInitializer())
2904 ToField->setInClassInitializer(D->getInClassInitializer());
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002905 ToField->setImplicit(D->isImplicit());
Douglas Gregor8cdbe642010-02-12 23:44:20 +00002906 Importer.Imported(D, ToField);
Sean Callanan95e74be2011-10-21 02:57:43 +00002907 LexicalDC->addDeclInternal(ToField);
Douglas Gregor5c73e912010-02-11 00:48:18 +00002908 return ToField;
2909}
2910
Francois Pichet783dd6e2010-11-21 06:08:52 +00002911Decl *ASTNodeImporter::VisitIndirectFieldDecl(IndirectFieldDecl *D) {
2912 // Import the major distinguishing characteristics of a variable.
2913 DeclContext *DC, *LexicalDC;
2914 DeclarationName Name;
2915 SourceLocation Loc;
2916 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2917 return 0;
2918
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002919 // Determine whether we've already imported this field.
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002920 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002921 DC->localUncachedLookup(Name, FoundDecls);
2922 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002923 if (IndirectFieldDecl *FoundField
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002924 = dyn_cast<IndirectFieldDecl>(FoundDecls[I])) {
Douglas Gregorceb32bf2012-10-26 16:45:11 +00002925 // For anonymous indirect fields, match up by index.
2926 if (!Name && getFieldIndex(D) != getFieldIndex(FoundField))
2927 continue;
2928
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002929 if (Importer.IsStructurallyEquivalent(D->getType(),
Douglas Gregordd6006f2012-07-17 21:16:27 +00002930 FoundField->getType(),
David Blaikie7d170102013-05-15 07:37:26 +00002931 !Name.isEmpty())) {
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002932 Importer.Imported(D, FoundField);
2933 return FoundField;
2934 }
Douglas Gregordd6006f2012-07-17 21:16:27 +00002935
2936 // If there are more anonymous fields to check, continue.
2937 if (!Name && I < N-1)
2938 continue;
2939
Douglas Gregor03d1ed32011-10-14 21:54:42 +00002940 Importer.ToDiag(Loc, diag::err_odr_field_type_inconsistent)
2941 << Name << D->getType() << FoundField->getType();
2942 Importer.ToDiag(FoundField->getLocation(), diag::note_odr_value_here)
2943 << FoundField->getType();
2944 return 0;
2945 }
2946 }
2947
Francois Pichet783dd6e2010-11-21 06:08:52 +00002948 // Import the type.
2949 QualType T = Importer.Import(D->getType());
2950 if (T.isNull())
2951 return 0;
2952
2953 NamedDecl **NamedChain =
2954 new (Importer.getToContext())NamedDecl*[D->getChainingSize()];
2955
2956 unsigned i = 0;
2957 for (IndirectFieldDecl::chain_iterator PI = D->chain_begin(),
2958 PE = D->chain_end(); PI != PE; ++PI) {
2959 Decl* D = Importer.Import(*PI);
2960 if (!D)
2961 return 0;
2962 NamedChain[i++] = cast<NamedDecl>(D);
2963 }
2964
2965 IndirectFieldDecl *ToIndirectField = IndirectFieldDecl::Create(
2966 Importer.getToContext(), DC,
2967 Loc, Name.getAsIdentifierInfo(), T,
2968 NamedChain, D->getChainingSize());
2969 ToIndirectField->setAccess(D->getAccess());
2970 ToIndirectField->setLexicalDeclContext(LexicalDC);
2971 Importer.Imported(D, ToIndirectField);
Sean Callanan95e74be2011-10-21 02:57:43 +00002972 LexicalDC->addDeclInternal(ToIndirectField);
Francois Pichet783dd6e2010-11-21 06:08:52 +00002973 return ToIndirectField;
2974}
2975
Douglas Gregor7244b0b2010-02-17 00:34:30 +00002976Decl *ASTNodeImporter::VisitObjCIvarDecl(ObjCIvarDecl *D) {
2977 // Import the major distinguishing characteristics of an ivar.
2978 DeclContext *DC, *LexicalDC;
2979 DeclarationName Name;
2980 SourceLocation Loc;
2981 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
2982 return 0;
2983
2984 // Determine whether we've already imported this ivar
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002985 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00002986 DC->localUncachedLookup(Name, FoundDecls);
2987 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
2988 if (ObjCIvarDecl *FoundIvar = dyn_cast<ObjCIvarDecl>(FoundDecls[I])) {
Douglas Gregor7244b0b2010-02-17 00:34:30 +00002989 if (Importer.IsStructurallyEquivalent(D->getType(),
2990 FoundIvar->getType())) {
2991 Importer.Imported(D, FoundIvar);
2992 return FoundIvar;
2993 }
2994
2995 Importer.ToDiag(Loc, diag::err_odr_ivar_type_inconsistent)
2996 << Name << D->getType() << FoundIvar->getType();
2997 Importer.ToDiag(FoundIvar->getLocation(), diag::note_odr_value_here)
2998 << FoundIvar->getType();
2999 return 0;
3000 }
3001 }
3002
3003 // Import the type.
3004 QualType T = Importer.Import(D->getType());
3005 if (T.isNull())
3006 return 0;
3007
3008 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
3009 Expr *BitWidth = Importer.Import(D->getBitWidth());
3010 if (!BitWidth && D->getBitWidth())
3011 return 0;
3012
Daniel Dunbarfe3ead72010-04-02 20:10:03 +00003013 ObjCIvarDecl *ToIvar = ObjCIvarDecl::Create(Importer.getToContext(),
3014 cast<ObjCContainerDecl>(DC),
Abramo Bagnaradff19302011-03-08 08:55:46 +00003015 Importer.Import(D->getInnerLocStart()),
Douglas Gregor7244b0b2010-02-17 00:34:30 +00003016 Loc, Name.getAsIdentifierInfo(),
3017 T, TInfo, D->getAccessControl(),
Argyrios Kyrtzidis2080d902014-01-03 18:32:18 +00003018 BitWidth, D->getSynthesize());
Douglas Gregor7244b0b2010-02-17 00:34:30 +00003019 ToIvar->setLexicalDeclContext(LexicalDC);
3020 Importer.Imported(D, ToIvar);
Sean Callanan95e74be2011-10-21 02:57:43 +00003021 LexicalDC->addDeclInternal(ToIvar);
Douglas Gregor7244b0b2010-02-17 00:34:30 +00003022 return ToIvar;
3023
3024}
3025
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003026Decl *ASTNodeImporter::VisitVarDecl(VarDecl *D) {
3027 // Import the major distinguishing characteristics of a variable.
3028 DeclContext *DC, *LexicalDC;
3029 DeclarationName Name;
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003030 SourceLocation Loc;
Douglas Gregorb4964f72010-02-15 23:54:17 +00003031 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003032 return 0;
3033
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003034 // Try to find a variable in our own ("to") context with the same name and
3035 // in the same context as the variable we're importing.
Douglas Gregor62d311f2010-02-09 19:21:46 +00003036 if (D->isFileVarDecl()) {
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003037 VarDecl *MergeWithVar = 0;
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003038 SmallVector<NamedDecl *, 4> ConflictingDecls;
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003039 unsigned IDNS = Decl::IDNS_Ordinary;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003040 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003041 DC->localUncachedLookup(Name, FoundDecls);
3042 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
3043 if (!FoundDecls[I]->isInIdentifierNamespace(IDNS))
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003044 continue;
3045
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003046 if (VarDecl *FoundVar = dyn_cast<VarDecl>(FoundDecls[I])) {
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003047 // We have found a variable that we may need to merge with. Check it.
Rafael Espindola3ae00052013-05-13 00:12:11 +00003048 if (FoundVar->hasExternalFormalLinkage() &&
3049 D->hasExternalFormalLinkage()) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00003050 if (Importer.IsStructurallyEquivalent(D->getType(),
3051 FoundVar->getType())) {
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003052 MergeWithVar = FoundVar;
3053 break;
3054 }
3055
Douglas Gregor56521c52010-02-12 17:23:39 +00003056 const ArrayType *FoundArray
3057 = Importer.getToContext().getAsArrayType(FoundVar->getType());
3058 const ArrayType *TArray
Douglas Gregorb4964f72010-02-15 23:54:17 +00003059 = Importer.getToContext().getAsArrayType(D->getType());
Douglas Gregor56521c52010-02-12 17:23:39 +00003060 if (FoundArray && TArray) {
3061 if (isa<IncompleteArrayType>(FoundArray) &&
3062 isa<ConstantArrayType>(TArray)) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00003063 // Import the type.
3064 QualType T = Importer.Import(D->getType());
3065 if (T.isNull())
3066 return 0;
3067
Douglas Gregor56521c52010-02-12 17:23:39 +00003068 FoundVar->setType(T);
3069 MergeWithVar = FoundVar;
3070 break;
3071 } else if (isa<IncompleteArrayType>(TArray) &&
3072 isa<ConstantArrayType>(FoundArray)) {
3073 MergeWithVar = FoundVar;
3074 break;
Douglas Gregor2fbe5582010-02-10 17:16:49 +00003075 }
3076 }
3077
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003078 Importer.ToDiag(Loc, diag::err_odr_variable_type_inconsistent)
Douglas Gregorb4964f72010-02-15 23:54:17 +00003079 << Name << D->getType() << FoundVar->getType();
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003080 Importer.ToDiag(FoundVar->getLocation(), diag::note_odr_value_here)
3081 << FoundVar->getType();
3082 }
3083 }
3084
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003085 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003086 }
3087
3088 if (MergeWithVar) {
3089 // An equivalent variable with external linkage has been found. Link
3090 // the two declarations, then merge them.
Douglas Gregor8cdbe642010-02-12 23:44:20 +00003091 Importer.Imported(D, MergeWithVar);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003092
3093 if (VarDecl *DDef = D->getDefinition()) {
3094 if (VarDecl *ExistingDef = MergeWithVar->getDefinition()) {
3095 Importer.ToDiag(ExistingDef->getLocation(),
3096 diag::err_odr_variable_multiple_def)
3097 << Name;
3098 Importer.FromDiag(DDef->getLocation(), diag::note_odr_defined_here);
3099 } else {
3100 Expr *Init = Importer.Import(DDef->getInit());
Douglas Gregord5058122010-02-11 01:19:42 +00003101 MergeWithVar->setInit(Init);
Richard Smithd0b4dd62011-12-19 06:19:21 +00003102 if (DDef->isInitKnownICE()) {
3103 EvaluatedStmt *Eval = MergeWithVar->ensureEvaluatedStmt();
3104 Eval->CheckedICE = true;
3105 Eval->IsICE = DDef->isInitICE();
3106 }
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003107 }
3108 }
3109
3110 return MergeWithVar;
3111 }
3112
3113 if (!ConflictingDecls.empty()) {
3114 Name = Importer.HandleNameConflict(Name, DC, IDNS,
3115 ConflictingDecls.data(),
3116 ConflictingDecls.size());
3117 if (!Name)
3118 return 0;
3119 }
3120 }
Douglas Gregorfa7a0e52010-02-10 17:47:19 +00003121
Douglas Gregorb4964f72010-02-15 23:54:17 +00003122 // Import the type.
3123 QualType T = Importer.Import(D->getType());
3124 if (T.isNull())
3125 return 0;
3126
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003127 // Create the imported variable.
Douglas Gregorfa7a0e52010-02-10 17:47:19 +00003128 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
Abramo Bagnaradff19302011-03-08 08:55:46 +00003129 VarDecl *ToVar = VarDecl::Create(Importer.getToContext(), DC,
3130 Importer.Import(D->getInnerLocStart()),
3131 Loc, Name.getAsIdentifierInfo(),
3132 T, TInfo,
Rafael Espindola6ae7e502013-04-03 19:27:57 +00003133 D->getStorageClass());
Douglas Gregor14454802011-02-25 02:25:35 +00003134 ToVar->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
Douglas Gregordd483172010-02-22 17:42:47 +00003135 ToVar->setAccess(D->getAccess());
Douglas Gregor62d311f2010-02-09 19:21:46 +00003136 ToVar->setLexicalDeclContext(LexicalDC);
Douglas Gregor8cdbe642010-02-12 23:44:20 +00003137 Importer.Imported(D, ToVar);
Sean Callanan95e74be2011-10-21 02:57:43 +00003138 LexicalDC->addDeclInternal(ToVar);
Douglas Gregor62d311f2010-02-09 19:21:46 +00003139
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003140 // Merge the initializer.
Larisse Voufo39a1e502013-08-06 01:03:05 +00003141 if (ImportDefinition(D, ToVar))
3142 return 0;
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003143
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00003144 return ToVar;
3145}
3146
Douglas Gregor8b228d72010-02-17 21:22:52 +00003147Decl *ASTNodeImporter::VisitImplicitParamDecl(ImplicitParamDecl *D) {
3148 // Parameters are created in the translation unit's context, then moved
3149 // into the function declaration's context afterward.
3150 DeclContext *DC = Importer.getToContext().getTranslationUnitDecl();
3151
3152 // Import the name of this declaration.
3153 DeclarationName Name = Importer.Import(D->getDeclName());
3154 if (D->getDeclName() && !Name)
3155 return 0;
3156
3157 // Import the location of this declaration.
3158 SourceLocation Loc = Importer.Import(D->getLocation());
3159
3160 // Import the parameter's type.
3161 QualType T = Importer.Import(D->getType());
3162 if (T.isNull())
3163 return 0;
3164
3165 // Create the imported parameter.
3166 ImplicitParamDecl *ToParm
3167 = ImplicitParamDecl::Create(Importer.getToContext(), DC,
3168 Loc, Name.getAsIdentifierInfo(),
3169 T);
3170 return Importer.Imported(D, ToParm);
3171}
3172
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003173Decl *ASTNodeImporter::VisitParmVarDecl(ParmVarDecl *D) {
3174 // Parameters are created in the translation unit's context, then moved
3175 // into the function declaration's context afterward.
3176 DeclContext *DC = Importer.getToContext().getTranslationUnitDecl();
3177
Douglas Gregorfa7a0e52010-02-10 17:47:19 +00003178 // Import the name of this declaration.
3179 DeclarationName Name = Importer.Import(D->getDeclName());
3180 if (D->getDeclName() && !Name)
3181 return 0;
3182
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003183 // Import the location of this declaration.
3184 SourceLocation Loc = Importer.Import(D->getLocation());
3185
3186 // Import the parameter's type.
3187 QualType T = Importer.Import(D->getType());
3188 if (T.isNull())
3189 return 0;
3190
3191 // Create the imported parameter.
3192 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
3193 ParmVarDecl *ToParm = ParmVarDecl::Create(Importer.getToContext(), DC,
Abramo Bagnaradff19302011-03-08 08:55:46 +00003194 Importer.Import(D->getInnerLocStart()),
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003195 Loc, Name.getAsIdentifierInfo(),
3196 T, TInfo, D->getStorageClass(),
3197 /*FIXME: Default argument*/ 0);
John McCallf3cd6652010-03-12 18:31:32 +00003198 ToParm->setHasInheritedDefaultArg(D->hasInheritedDefaultArg());
Douglas Gregor8cdbe642010-02-12 23:44:20 +00003199 return Importer.Imported(D, ToParm);
Douglas Gregorbb7930c2010-02-10 19:54:31 +00003200}
3201
Douglas Gregor43f54792010-02-17 02:12:47 +00003202Decl *ASTNodeImporter::VisitObjCMethodDecl(ObjCMethodDecl *D) {
3203 // Import the major distinguishing characteristics of a method.
3204 DeclContext *DC, *LexicalDC;
3205 DeclarationName Name;
3206 SourceLocation Loc;
3207 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3208 return 0;
3209
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003210 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003211 DC->localUncachedLookup(Name, FoundDecls);
3212 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
3213 if (ObjCMethodDecl *FoundMethod = dyn_cast<ObjCMethodDecl>(FoundDecls[I])) {
Douglas Gregor43f54792010-02-17 02:12:47 +00003214 if (FoundMethod->isInstanceMethod() != D->isInstanceMethod())
3215 continue;
3216
3217 // Check return types.
3218 if (!Importer.IsStructurallyEquivalent(D->getResultType(),
3219 FoundMethod->getResultType())) {
3220 Importer.ToDiag(Loc, diag::err_odr_objc_method_result_type_inconsistent)
3221 << D->isInstanceMethod() << Name
3222 << D->getResultType() << FoundMethod->getResultType();
3223 Importer.ToDiag(FoundMethod->getLocation(),
3224 diag::note_odr_objc_method_here)
3225 << D->isInstanceMethod() << Name;
3226 return 0;
3227 }
3228
3229 // Check the number of parameters.
3230 if (D->param_size() != FoundMethod->param_size()) {
3231 Importer.ToDiag(Loc, diag::err_odr_objc_method_num_params_inconsistent)
3232 << D->isInstanceMethod() << Name
3233 << D->param_size() << FoundMethod->param_size();
3234 Importer.ToDiag(FoundMethod->getLocation(),
3235 diag::note_odr_objc_method_here)
3236 << D->isInstanceMethod() << Name;
3237 return 0;
3238 }
3239
3240 // Check parameter types.
3241 for (ObjCMethodDecl::param_iterator P = D->param_begin(),
3242 PEnd = D->param_end(), FoundP = FoundMethod->param_begin();
3243 P != PEnd; ++P, ++FoundP) {
3244 if (!Importer.IsStructurallyEquivalent((*P)->getType(),
3245 (*FoundP)->getType())) {
3246 Importer.FromDiag((*P)->getLocation(),
3247 diag::err_odr_objc_method_param_type_inconsistent)
3248 << D->isInstanceMethod() << Name
3249 << (*P)->getType() << (*FoundP)->getType();
3250 Importer.ToDiag((*FoundP)->getLocation(), diag::note_odr_value_here)
3251 << (*FoundP)->getType();
3252 return 0;
3253 }
3254 }
3255
3256 // Check variadic/non-variadic.
3257 // Check the number of parameters.
3258 if (D->isVariadic() != FoundMethod->isVariadic()) {
3259 Importer.ToDiag(Loc, diag::err_odr_objc_method_variadic_inconsistent)
3260 << D->isInstanceMethod() << Name;
3261 Importer.ToDiag(FoundMethod->getLocation(),
3262 diag::note_odr_objc_method_here)
3263 << D->isInstanceMethod() << Name;
3264 return 0;
3265 }
3266
3267 // FIXME: Any other bits we need to merge?
3268 return Importer.Imported(D, FoundMethod);
3269 }
3270 }
3271
3272 // Import the result type.
3273 QualType ResultTy = Importer.Import(D->getResultType());
3274 if (ResultTy.isNull())
3275 return 0;
3276
Douglas Gregor12852d92010-03-08 14:59:44 +00003277 TypeSourceInfo *ResultTInfo = Importer.Import(D->getResultTypeSourceInfo());
3278
Douglas Gregor43f54792010-02-17 02:12:47 +00003279 ObjCMethodDecl *ToMethod
3280 = ObjCMethodDecl::Create(Importer.getToContext(),
3281 Loc,
3282 Importer.Import(D->getLocEnd()),
3283 Name.getObjCSelector(),
Douglas Gregor12852d92010-03-08 14:59:44 +00003284 ResultTy, ResultTInfo, DC,
Douglas Gregor43f54792010-02-17 02:12:47 +00003285 D->isInstanceMethod(),
3286 D->isVariadic(),
Jordan Rosed01e83a2012-10-10 16:42:25 +00003287 D->isPropertyAccessor(),
Argyrios Kyrtzidis004df6e2011-08-17 19:25:08 +00003288 D->isImplicit(),
Fariborz Jahanian6e7e8cc2010-07-22 18:24:20 +00003289 D->isDefined(),
Douglas Gregor33823722011-06-11 01:09:30 +00003290 D->getImplementationControl(),
3291 D->hasRelatedResultType());
Douglas Gregor43f54792010-02-17 02:12:47 +00003292
3293 // FIXME: When we decide to merge method definitions, we'll need to
3294 // deal with implicit parameters.
3295
3296 // Import the parameters
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003297 SmallVector<ParmVarDecl *, 5> ToParams;
Douglas Gregor43f54792010-02-17 02:12:47 +00003298 for (ObjCMethodDecl::param_iterator FromP = D->param_begin(),
3299 FromPEnd = D->param_end();
3300 FromP != FromPEnd;
3301 ++FromP) {
3302 ParmVarDecl *ToP = cast_or_null<ParmVarDecl>(Importer.Import(*FromP));
3303 if (!ToP)
3304 return 0;
3305
3306 ToParams.push_back(ToP);
3307 }
3308
3309 // Set the parameters.
3310 for (unsigned I = 0, N = ToParams.size(); I != N; ++I) {
3311 ToParams[I]->setOwningFunction(ToMethod);
Sean Callanan95e74be2011-10-21 02:57:43 +00003312 ToMethod->addDeclInternal(ToParams[I]);
Douglas Gregor43f54792010-02-17 02:12:47 +00003313 }
Argyrios Kyrtzidisb8c3aaf2011-10-03 06:37:04 +00003314 SmallVector<SourceLocation, 12> SelLocs;
3315 D->getSelectorLocs(SelLocs);
3316 ToMethod->setMethodParams(Importer.getToContext(), ToParams, SelLocs);
Douglas Gregor43f54792010-02-17 02:12:47 +00003317
3318 ToMethod->setLexicalDeclContext(LexicalDC);
3319 Importer.Imported(D, ToMethod);
Sean Callanan95e74be2011-10-21 02:57:43 +00003320 LexicalDC->addDeclInternal(ToMethod);
Douglas Gregor43f54792010-02-17 02:12:47 +00003321 return ToMethod;
3322}
3323
Douglas Gregor84c51c32010-02-18 01:47:50 +00003324Decl *ASTNodeImporter::VisitObjCCategoryDecl(ObjCCategoryDecl *D) {
3325 // Import the major distinguishing characteristics of a category.
3326 DeclContext *DC, *LexicalDC;
3327 DeclarationName Name;
3328 SourceLocation Loc;
3329 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3330 return 0;
3331
3332 ObjCInterfaceDecl *ToInterface
3333 = cast_or_null<ObjCInterfaceDecl>(Importer.Import(D->getClassInterface()));
3334 if (!ToInterface)
3335 return 0;
3336
3337 // Determine if we've already encountered this category.
3338 ObjCCategoryDecl *MergeWithCategory
3339 = ToInterface->FindCategoryDeclaration(Name.getAsIdentifierInfo());
3340 ObjCCategoryDecl *ToCategory = MergeWithCategory;
3341 if (!ToCategory) {
3342 ToCategory = ObjCCategoryDecl::Create(Importer.getToContext(), DC,
Argyrios Kyrtzidis52f53fb2011-10-04 04:48:02 +00003343 Importer.Import(D->getAtStartLoc()),
Douglas Gregor84c51c32010-02-18 01:47:50 +00003344 Loc,
3345 Importer.Import(D->getCategoryNameLoc()),
Argyrios Kyrtzidis3a5094b2011-08-30 19:43:26 +00003346 Name.getAsIdentifierInfo(),
Fariborz Jahaniana7765fe2012-02-20 20:09:20 +00003347 ToInterface,
3348 Importer.Import(D->getIvarLBraceLoc()),
3349 Importer.Import(D->getIvarRBraceLoc()));
Douglas Gregor84c51c32010-02-18 01:47:50 +00003350 ToCategory->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00003351 LexicalDC->addDeclInternal(ToCategory);
Douglas Gregor84c51c32010-02-18 01:47:50 +00003352 Importer.Imported(D, ToCategory);
3353
Douglas Gregor84c51c32010-02-18 01:47:50 +00003354 // Import protocols
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003355 SmallVector<ObjCProtocolDecl *, 4> Protocols;
3356 SmallVector<SourceLocation, 4> ProtocolLocs;
Douglas Gregor84c51c32010-02-18 01:47:50 +00003357 ObjCCategoryDecl::protocol_loc_iterator FromProtoLoc
3358 = D->protocol_loc_begin();
3359 for (ObjCCategoryDecl::protocol_iterator FromProto = D->protocol_begin(),
3360 FromProtoEnd = D->protocol_end();
3361 FromProto != FromProtoEnd;
3362 ++FromProto, ++FromProtoLoc) {
3363 ObjCProtocolDecl *ToProto
3364 = cast_or_null<ObjCProtocolDecl>(Importer.Import(*FromProto));
3365 if (!ToProto)
3366 return 0;
3367 Protocols.push_back(ToProto);
3368 ProtocolLocs.push_back(Importer.Import(*FromProtoLoc));
3369 }
3370
3371 // FIXME: If we're merging, make sure that the protocol list is the same.
3372 ToCategory->setProtocolList(Protocols.data(), Protocols.size(),
3373 ProtocolLocs.data(), Importer.getToContext());
3374
3375 } else {
3376 Importer.Imported(D, ToCategory);
3377 }
3378
3379 // Import all of the members of this category.
Douglas Gregor968d6332010-02-21 18:24:45 +00003380 ImportDeclContext(D);
Douglas Gregor84c51c32010-02-18 01:47:50 +00003381
3382 // If we have an implementation, import it as well.
3383 if (D->getImplementation()) {
3384 ObjCCategoryImplDecl *Impl
Douglas Gregor35fd7bc2010-12-08 16:41:55 +00003385 = cast_or_null<ObjCCategoryImplDecl>(
3386 Importer.Import(D->getImplementation()));
Douglas Gregor84c51c32010-02-18 01:47:50 +00003387 if (!Impl)
3388 return 0;
3389
3390 ToCategory->setImplementation(Impl);
3391 }
3392
3393 return ToCategory;
3394}
3395
Douglas Gregor2aa53772012-01-24 17:42:07 +00003396bool ASTNodeImporter::ImportDefinition(ObjCProtocolDecl *From,
3397 ObjCProtocolDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +00003398 ImportDefinitionKind Kind) {
Douglas Gregor2aa53772012-01-24 17:42:07 +00003399 if (To->getDefinition()) {
Douglas Gregor2e15c842012-02-01 21:00:38 +00003400 if (shouldForceImportDeclContext(Kind))
3401 ImportDeclContext(From);
Douglas Gregor2aa53772012-01-24 17:42:07 +00003402 return false;
3403 }
3404
3405 // Start the protocol definition
3406 To->startDefinition();
3407
3408 // Import protocols
3409 SmallVector<ObjCProtocolDecl *, 4> Protocols;
3410 SmallVector<SourceLocation, 4> ProtocolLocs;
3411 ObjCProtocolDecl::protocol_loc_iterator
3412 FromProtoLoc = From->protocol_loc_begin();
3413 for (ObjCProtocolDecl::protocol_iterator FromProto = From->protocol_begin(),
3414 FromProtoEnd = From->protocol_end();
3415 FromProto != FromProtoEnd;
3416 ++FromProto, ++FromProtoLoc) {
3417 ObjCProtocolDecl *ToProto
3418 = cast_or_null<ObjCProtocolDecl>(Importer.Import(*FromProto));
3419 if (!ToProto)
3420 return true;
3421 Protocols.push_back(ToProto);
3422 ProtocolLocs.push_back(Importer.Import(*FromProtoLoc));
3423 }
3424
3425 // FIXME: If we're merging, make sure that the protocol list is the same.
3426 To->setProtocolList(Protocols.data(), Protocols.size(),
3427 ProtocolLocs.data(), Importer.getToContext());
3428
Douglas Gregor2e15c842012-02-01 21:00:38 +00003429 if (shouldForceImportDeclContext(Kind)) {
3430 // Import all of the members of this protocol.
3431 ImportDeclContext(From, /*ForceImport=*/true);
3432 }
Douglas Gregor2aa53772012-01-24 17:42:07 +00003433 return false;
3434}
3435
Douglas Gregor98d156a2010-02-17 16:12:00 +00003436Decl *ASTNodeImporter::VisitObjCProtocolDecl(ObjCProtocolDecl *D) {
Douglas Gregor2aa53772012-01-24 17:42:07 +00003437 // If this protocol has a definition in the translation unit we're coming
3438 // from, but this particular declaration is not that definition, import the
3439 // definition and map to that.
3440 ObjCProtocolDecl *Definition = D->getDefinition();
3441 if (Definition && Definition != D) {
3442 Decl *ImportedDef = Importer.Import(Definition);
3443 if (!ImportedDef)
3444 return 0;
3445
3446 return Importer.Imported(D, ImportedDef);
3447 }
3448
Douglas Gregor84c51c32010-02-18 01:47:50 +00003449 // Import the major distinguishing characteristics of a protocol.
Douglas Gregor98d156a2010-02-17 16:12:00 +00003450 DeclContext *DC, *LexicalDC;
3451 DeclarationName Name;
3452 SourceLocation Loc;
3453 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3454 return 0;
3455
3456 ObjCProtocolDecl *MergeWithProtocol = 0;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003457 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003458 DC->localUncachedLookup(Name, FoundDecls);
3459 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
3460 if (!FoundDecls[I]->isInIdentifierNamespace(Decl::IDNS_ObjCProtocol))
Douglas Gregor98d156a2010-02-17 16:12:00 +00003461 continue;
3462
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003463 if ((MergeWithProtocol = dyn_cast<ObjCProtocolDecl>(FoundDecls[I])))
Douglas Gregor98d156a2010-02-17 16:12:00 +00003464 break;
3465 }
3466
3467 ObjCProtocolDecl *ToProto = MergeWithProtocol;
Douglas Gregor2aa53772012-01-24 17:42:07 +00003468 if (!ToProto) {
3469 ToProto = ObjCProtocolDecl::Create(Importer.getToContext(), DC,
3470 Name.getAsIdentifierInfo(), Loc,
3471 Importer.Import(D->getAtStartLoc()),
3472 /*PrevDecl=*/0);
3473 ToProto->setLexicalDeclContext(LexicalDC);
3474 LexicalDC->addDeclInternal(ToProto);
Douglas Gregor98d156a2010-02-17 16:12:00 +00003475 }
Douglas Gregor2aa53772012-01-24 17:42:07 +00003476
3477 Importer.Imported(D, ToProto);
Douglas Gregor98d156a2010-02-17 16:12:00 +00003478
Douglas Gregor2aa53772012-01-24 17:42:07 +00003479 if (D->isThisDeclarationADefinition() && ImportDefinition(D, ToProto))
3480 return 0;
3481
Douglas Gregor98d156a2010-02-17 16:12:00 +00003482 return ToProto;
3483}
3484
Douglas Gregor2aa53772012-01-24 17:42:07 +00003485bool ASTNodeImporter::ImportDefinition(ObjCInterfaceDecl *From,
3486 ObjCInterfaceDecl *To,
Douglas Gregor2e15c842012-02-01 21:00:38 +00003487 ImportDefinitionKind Kind) {
Douglas Gregor2aa53772012-01-24 17:42:07 +00003488 if (To->getDefinition()) {
3489 // Check consistency of superclass.
3490 ObjCInterfaceDecl *FromSuper = From->getSuperClass();
3491 if (FromSuper) {
3492 FromSuper = cast_or_null<ObjCInterfaceDecl>(Importer.Import(FromSuper));
3493 if (!FromSuper)
3494 return true;
3495 }
3496
3497 ObjCInterfaceDecl *ToSuper = To->getSuperClass();
3498 if ((bool)FromSuper != (bool)ToSuper ||
3499 (FromSuper && !declaresSameEntity(FromSuper, ToSuper))) {
3500 Importer.ToDiag(To->getLocation(),
3501 diag::err_odr_objc_superclass_inconsistent)
3502 << To->getDeclName();
3503 if (ToSuper)
3504 Importer.ToDiag(To->getSuperClassLoc(), diag::note_odr_objc_superclass)
3505 << To->getSuperClass()->getDeclName();
3506 else
3507 Importer.ToDiag(To->getLocation(),
3508 diag::note_odr_objc_missing_superclass);
3509 if (From->getSuperClass())
3510 Importer.FromDiag(From->getSuperClassLoc(),
3511 diag::note_odr_objc_superclass)
3512 << From->getSuperClass()->getDeclName();
3513 else
3514 Importer.FromDiag(From->getLocation(),
3515 diag::note_odr_objc_missing_superclass);
3516 }
3517
Douglas Gregor2e15c842012-02-01 21:00:38 +00003518 if (shouldForceImportDeclContext(Kind))
3519 ImportDeclContext(From);
Douglas Gregor2aa53772012-01-24 17:42:07 +00003520 return false;
3521 }
3522
3523 // Start the definition.
3524 To->startDefinition();
3525
3526 // If this class has a superclass, import it.
3527 if (From->getSuperClass()) {
3528 ObjCInterfaceDecl *Super = cast_or_null<ObjCInterfaceDecl>(
3529 Importer.Import(From->getSuperClass()));
3530 if (!Super)
3531 return true;
3532
3533 To->setSuperClass(Super);
3534 To->setSuperClassLoc(Importer.Import(From->getSuperClassLoc()));
3535 }
3536
3537 // Import protocols
3538 SmallVector<ObjCProtocolDecl *, 4> Protocols;
3539 SmallVector<SourceLocation, 4> ProtocolLocs;
3540 ObjCInterfaceDecl::protocol_loc_iterator
3541 FromProtoLoc = From->protocol_loc_begin();
3542
3543 for (ObjCInterfaceDecl::protocol_iterator FromProto = From->protocol_begin(),
3544 FromProtoEnd = From->protocol_end();
3545 FromProto != FromProtoEnd;
3546 ++FromProto, ++FromProtoLoc) {
3547 ObjCProtocolDecl *ToProto
3548 = cast_or_null<ObjCProtocolDecl>(Importer.Import(*FromProto));
3549 if (!ToProto)
3550 return true;
3551 Protocols.push_back(ToProto);
3552 ProtocolLocs.push_back(Importer.Import(*FromProtoLoc));
3553 }
3554
3555 // FIXME: If we're merging, make sure that the protocol list is the same.
3556 To->setProtocolList(Protocols.data(), Protocols.size(),
3557 ProtocolLocs.data(), Importer.getToContext());
3558
3559 // Import categories. When the categories themselves are imported, they'll
3560 // hook themselves into this interface.
Douglas Gregor048fbfa2013-01-16 23:00:23 +00003561 for (ObjCInterfaceDecl::known_categories_iterator
3562 Cat = From->known_categories_begin(),
3563 CatEnd = From->known_categories_end();
3564 Cat != CatEnd; ++Cat) {
3565 Importer.Import(*Cat);
3566 }
3567
Douglas Gregor2aa53772012-01-24 17:42:07 +00003568 // If we have an @implementation, import it as well.
3569 if (From->getImplementation()) {
3570 ObjCImplementationDecl *Impl = cast_or_null<ObjCImplementationDecl>(
3571 Importer.Import(From->getImplementation()));
3572 if (!Impl)
3573 return true;
3574
3575 To->setImplementation(Impl);
3576 }
3577
Douglas Gregor2e15c842012-02-01 21:00:38 +00003578 if (shouldForceImportDeclContext(Kind)) {
3579 // Import all of the members of this class.
3580 ImportDeclContext(From, /*ForceImport=*/true);
3581 }
Douglas Gregor2aa53772012-01-24 17:42:07 +00003582 return false;
3583}
3584
Douglas Gregor45635322010-02-16 01:20:57 +00003585Decl *ASTNodeImporter::VisitObjCInterfaceDecl(ObjCInterfaceDecl *D) {
Douglas Gregor2aa53772012-01-24 17:42:07 +00003586 // If this class has a definition in the translation unit we're coming from,
3587 // but this particular declaration is not that definition, import the
3588 // definition and map to that.
3589 ObjCInterfaceDecl *Definition = D->getDefinition();
3590 if (Definition && Definition != D) {
3591 Decl *ImportedDef = Importer.Import(Definition);
3592 if (!ImportedDef)
3593 return 0;
3594
3595 return Importer.Imported(D, ImportedDef);
3596 }
3597
Douglas Gregor45635322010-02-16 01:20:57 +00003598 // Import the major distinguishing characteristics of an @interface.
3599 DeclContext *DC, *LexicalDC;
3600 DeclarationName Name;
3601 SourceLocation Loc;
3602 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3603 return 0;
3604
Douglas Gregor2aa53772012-01-24 17:42:07 +00003605 // Look for an existing interface with the same name.
Douglas Gregor45635322010-02-16 01:20:57 +00003606 ObjCInterfaceDecl *MergeWithIface = 0;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003607 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003608 DC->localUncachedLookup(Name, FoundDecls);
3609 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
3610 if (!FoundDecls[I]->isInIdentifierNamespace(Decl::IDNS_Ordinary))
Douglas Gregor45635322010-02-16 01:20:57 +00003611 continue;
3612
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003613 if ((MergeWithIface = dyn_cast<ObjCInterfaceDecl>(FoundDecls[I])))
Douglas Gregor45635322010-02-16 01:20:57 +00003614 break;
3615 }
3616
Douglas Gregor2aa53772012-01-24 17:42:07 +00003617 // Create an interface declaration, if one does not already exist.
Douglas Gregor45635322010-02-16 01:20:57 +00003618 ObjCInterfaceDecl *ToIface = MergeWithIface;
Douglas Gregor2aa53772012-01-24 17:42:07 +00003619 if (!ToIface) {
3620 ToIface = ObjCInterfaceDecl::Create(Importer.getToContext(), DC,
3621 Importer.Import(D->getAtStartLoc()),
3622 Name.getAsIdentifierInfo(),
3623 /*PrevDecl=*/0,Loc,
3624 D->isImplicitInterfaceDecl());
3625 ToIface->setLexicalDeclContext(LexicalDC);
3626 LexicalDC->addDeclInternal(ToIface);
Douglas Gregor45635322010-02-16 01:20:57 +00003627 }
Douglas Gregor2aa53772012-01-24 17:42:07 +00003628 Importer.Imported(D, ToIface);
Douglas Gregor45635322010-02-16 01:20:57 +00003629
Douglas Gregor2aa53772012-01-24 17:42:07 +00003630 if (D->isThisDeclarationADefinition() && ImportDefinition(D, ToIface))
3631 return 0;
Douglas Gregor45635322010-02-16 01:20:57 +00003632
Douglas Gregor98d156a2010-02-17 16:12:00 +00003633 return ToIface;
Douglas Gregor45635322010-02-16 01:20:57 +00003634}
3635
Douglas Gregor4da9d682010-12-07 15:32:12 +00003636Decl *ASTNodeImporter::VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D) {
3637 ObjCCategoryDecl *Category = cast_or_null<ObjCCategoryDecl>(
3638 Importer.Import(D->getCategoryDecl()));
3639 if (!Category)
3640 return 0;
3641
3642 ObjCCategoryImplDecl *ToImpl = Category->getImplementation();
3643 if (!ToImpl) {
3644 DeclContext *DC = Importer.ImportContext(D->getDeclContext());
3645 if (!DC)
3646 return 0;
3647
Argyrios Kyrtzidis4996f5f2011-12-09 00:31:40 +00003648 SourceLocation CategoryNameLoc = Importer.Import(D->getCategoryNameLoc());
Douglas Gregor4da9d682010-12-07 15:32:12 +00003649 ToImpl = ObjCCategoryImplDecl::Create(Importer.getToContext(), DC,
Douglas Gregor4da9d682010-12-07 15:32:12 +00003650 Importer.Import(D->getIdentifier()),
Argyrios Kyrtzidis52f53fb2011-10-04 04:48:02 +00003651 Category->getClassInterface(),
3652 Importer.Import(D->getLocation()),
Argyrios Kyrtzidis4996f5f2011-12-09 00:31:40 +00003653 Importer.Import(D->getAtStartLoc()),
3654 CategoryNameLoc);
Douglas Gregor4da9d682010-12-07 15:32:12 +00003655
3656 DeclContext *LexicalDC = DC;
3657 if (D->getDeclContext() != D->getLexicalDeclContext()) {
3658 LexicalDC = Importer.ImportContext(D->getLexicalDeclContext());
3659 if (!LexicalDC)
3660 return 0;
3661
3662 ToImpl->setLexicalDeclContext(LexicalDC);
3663 }
3664
Sean Callanan95e74be2011-10-21 02:57:43 +00003665 LexicalDC->addDeclInternal(ToImpl);
Douglas Gregor4da9d682010-12-07 15:32:12 +00003666 Category->setImplementation(ToImpl);
3667 }
3668
3669 Importer.Imported(D, ToImpl);
Douglas Gregor35fd7bc2010-12-08 16:41:55 +00003670 ImportDeclContext(D);
Douglas Gregor4da9d682010-12-07 15:32:12 +00003671 return ToImpl;
3672}
3673
Douglas Gregorda8025c2010-12-07 01:26:03 +00003674Decl *ASTNodeImporter::VisitObjCImplementationDecl(ObjCImplementationDecl *D) {
3675 // Find the corresponding interface.
3676 ObjCInterfaceDecl *Iface = cast_or_null<ObjCInterfaceDecl>(
3677 Importer.Import(D->getClassInterface()));
3678 if (!Iface)
3679 return 0;
3680
3681 // Import the superclass, if any.
3682 ObjCInterfaceDecl *Super = 0;
3683 if (D->getSuperClass()) {
3684 Super = cast_or_null<ObjCInterfaceDecl>(
3685 Importer.Import(D->getSuperClass()));
3686 if (!Super)
3687 return 0;
3688 }
3689
3690 ObjCImplementationDecl *Impl = Iface->getImplementation();
3691 if (!Impl) {
3692 // We haven't imported an implementation yet. Create a new @implementation
3693 // now.
3694 Impl = ObjCImplementationDecl::Create(Importer.getToContext(),
3695 Importer.ImportContext(D->getDeclContext()),
Argyrios Kyrtzidis52f53fb2011-10-04 04:48:02 +00003696 Iface, Super,
Douglas Gregorda8025c2010-12-07 01:26:03 +00003697 Importer.Import(D->getLocation()),
Fariborz Jahaniana7765fe2012-02-20 20:09:20 +00003698 Importer.Import(D->getAtStartLoc()),
Argyrios Kyrtzidis5d2ce842013-05-03 22:31:26 +00003699 Importer.Import(D->getSuperClassLoc()),
Fariborz Jahaniana7765fe2012-02-20 20:09:20 +00003700 Importer.Import(D->getIvarLBraceLoc()),
3701 Importer.Import(D->getIvarRBraceLoc()));
Douglas Gregorda8025c2010-12-07 01:26:03 +00003702
3703 if (D->getDeclContext() != D->getLexicalDeclContext()) {
3704 DeclContext *LexicalDC
3705 = Importer.ImportContext(D->getLexicalDeclContext());
3706 if (!LexicalDC)
3707 return 0;
3708 Impl->setLexicalDeclContext(LexicalDC);
3709 }
3710
3711 // Associate the implementation with the class it implements.
3712 Iface->setImplementation(Impl);
3713 Importer.Imported(D, Iface->getImplementation());
3714 } else {
3715 Importer.Imported(D, Iface->getImplementation());
3716
3717 // Verify that the existing @implementation has the same superclass.
3718 if ((Super && !Impl->getSuperClass()) ||
3719 (!Super && Impl->getSuperClass()) ||
3720 (Super && Impl->getSuperClass() &&
Douglas Gregor0b144e12011-12-15 00:29:59 +00003721 !declaresSameEntity(Super->getCanonicalDecl(), Impl->getSuperClass()))) {
Douglas Gregorda8025c2010-12-07 01:26:03 +00003722 Importer.ToDiag(Impl->getLocation(),
3723 diag::err_odr_objc_superclass_inconsistent)
3724 << Iface->getDeclName();
3725 // FIXME: It would be nice to have the location of the superclass
3726 // below.
3727 if (Impl->getSuperClass())
3728 Importer.ToDiag(Impl->getLocation(),
3729 diag::note_odr_objc_superclass)
3730 << Impl->getSuperClass()->getDeclName();
3731 else
3732 Importer.ToDiag(Impl->getLocation(),
3733 diag::note_odr_objc_missing_superclass);
3734 if (D->getSuperClass())
3735 Importer.FromDiag(D->getLocation(),
3736 diag::note_odr_objc_superclass)
3737 << D->getSuperClass()->getDeclName();
3738 else
3739 Importer.FromDiag(D->getLocation(),
3740 diag::note_odr_objc_missing_superclass);
3741 return 0;
3742 }
3743 }
3744
3745 // Import all of the members of this @implementation.
3746 ImportDeclContext(D);
3747
3748 return Impl;
3749}
3750
Douglas Gregora11c4582010-02-17 18:02:10 +00003751Decl *ASTNodeImporter::VisitObjCPropertyDecl(ObjCPropertyDecl *D) {
3752 // Import the major distinguishing characteristics of an @property.
3753 DeclContext *DC, *LexicalDC;
3754 DeclarationName Name;
3755 SourceLocation Loc;
3756 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3757 return 0;
3758
3759 // Check whether we have already imported this property.
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003760 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003761 DC->localUncachedLookup(Name, FoundDecls);
3762 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
Douglas Gregora11c4582010-02-17 18:02:10 +00003763 if (ObjCPropertyDecl *FoundProp
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003764 = dyn_cast<ObjCPropertyDecl>(FoundDecls[I])) {
Douglas Gregora11c4582010-02-17 18:02:10 +00003765 // Check property types.
3766 if (!Importer.IsStructurallyEquivalent(D->getType(),
3767 FoundProp->getType())) {
3768 Importer.ToDiag(Loc, diag::err_odr_objc_property_type_inconsistent)
3769 << Name << D->getType() << FoundProp->getType();
3770 Importer.ToDiag(FoundProp->getLocation(), diag::note_odr_value_here)
3771 << FoundProp->getType();
3772 return 0;
3773 }
3774
3775 // FIXME: Check property attributes, getters, setters, etc.?
3776
3777 // Consider these properties to be equivalent.
3778 Importer.Imported(D, FoundProp);
3779 return FoundProp;
3780 }
3781 }
3782
3783 // Import the type.
John McCall339bb662010-06-04 20:50:08 +00003784 TypeSourceInfo *T = Importer.Import(D->getTypeSourceInfo());
3785 if (!T)
Douglas Gregora11c4582010-02-17 18:02:10 +00003786 return 0;
3787
3788 // Create the new property.
3789 ObjCPropertyDecl *ToProperty
3790 = ObjCPropertyDecl::Create(Importer.getToContext(), DC, Loc,
3791 Name.getAsIdentifierInfo(),
3792 Importer.Import(D->getAtLoc()),
Fariborz Jahanian86c2f5c2012-02-29 22:18:55 +00003793 Importer.Import(D->getLParenLoc()),
Douglas Gregora11c4582010-02-17 18:02:10 +00003794 T,
3795 D->getPropertyImplementation());
3796 Importer.Imported(D, ToProperty);
3797 ToProperty->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00003798 LexicalDC->addDeclInternal(ToProperty);
Douglas Gregora11c4582010-02-17 18:02:10 +00003799
3800 ToProperty->setPropertyAttributes(D->getPropertyAttributes());
Fariborz Jahanian3bf0ded2010-06-22 23:20:40 +00003801 ToProperty->setPropertyAttributesAsWritten(
3802 D->getPropertyAttributesAsWritten());
Douglas Gregora11c4582010-02-17 18:02:10 +00003803 ToProperty->setGetterName(Importer.Import(D->getGetterName()));
3804 ToProperty->setSetterName(Importer.Import(D->getSetterName()));
3805 ToProperty->setGetterMethodDecl(
3806 cast_or_null<ObjCMethodDecl>(Importer.Import(D->getGetterMethodDecl())));
3807 ToProperty->setSetterMethodDecl(
3808 cast_or_null<ObjCMethodDecl>(Importer.Import(D->getSetterMethodDecl())));
3809 ToProperty->setPropertyIvarDecl(
3810 cast_or_null<ObjCIvarDecl>(Importer.Import(D->getPropertyIvarDecl())));
3811 return ToProperty;
3812}
3813
Douglas Gregor14a49e22010-12-07 18:32:03 +00003814Decl *ASTNodeImporter::VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D) {
3815 ObjCPropertyDecl *Property = cast_or_null<ObjCPropertyDecl>(
3816 Importer.Import(D->getPropertyDecl()));
3817 if (!Property)
3818 return 0;
3819
3820 DeclContext *DC = Importer.ImportContext(D->getDeclContext());
3821 if (!DC)
3822 return 0;
3823
3824 // Import the lexical declaration context.
3825 DeclContext *LexicalDC = DC;
3826 if (D->getDeclContext() != D->getLexicalDeclContext()) {
3827 LexicalDC = Importer.ImportContext(D->getLexicalDeclContext());
3828 if (!LexicalDC)
3829 return 0;
3830 }
3831
3832 ObjCImplDecl *InImpl = dyn_cast<ObjCImplDecl>(LexicalDC);
3833 if (!InImpl)
3834 return 0;
3835
3836 // Import the ivar (for an @synthesize).
3837 ObjCIvarDecl *Ivar = 0;
3838 if (D->getPropertyIvarDecl()) {
3839 Ivar = cast_or_null<ObjCIvarDecl>(
3840 Importer.Import(D->getPropertyIvarDecl()));
3841 if (!Ivar)
3842 return 0;
3843 }
3844
3845 ObjCPropertyImplDecl *ToImpl
3846 = InImpl->FindPropertyImplDecl(Property->getIdentifier());
3847 if (!ToImpl) {
3848 ToImpl = ObjCPropertyImplDecl::Create(Importer.getToContext(), DC,
3849 Importer.Import(D->getLocStart()),
3850 Importer.Import(D->getLocation()),
3851 Property,
3852 D->getPropertyImplementation(),
3853 Ivar,
3854 Importer.Import(D->getPropertyIvarDeclLoc()));
3855 ToImpl->setLexicalDeclContext(LexicalDC);
3856 Importer.Imported(D, ToImpl);
Sean Callanan95e74be2011-10-21 02:57:43 +00003857 LexicalDC->addDeclInternal(ToImpl);
Douglas Gregor14a49e22010-12-07 18:32:03 +00003858 } else {
3859 // Check that we have the same kind of property implementation (@synthesize
3860 // vs. @dynamic).
3861 if (D->getPropertyImplementation() != ToImpl->getPropertyImplementation()) {
3862 Importer.ToDiag(ToImpl->getLocation(),
3863 diag::err_odr_objc_property_impl_kind_inconsistent)
3864 << Property->getDeclName()
3865 << (ToImpl->getPropertyImplementation()
3866 == ObjCPropertyImplDecl::Dynamic);
3867 Importer.FromDiag(D->getLocation(),
3868 diag::note_odr_objc_property_impl_kind)
3869 << D->getPropertyDecl()->getDeclName()
3870 << (D->getPropertyImplementation() == ObjCPropertyImplDecl::Dynamic);
3871 return 0;
3872 }
3873
3874 // For @synthesize, check that we have the same
3875 if (D->getPropertyImplementation() == ObjCPropertyImplDecl::Synthesize &&
3876 Ivar != ToImpl->getPropertyIvarDecl()) {
3877 Importer.ToDiag(ToImpl->getPropertyIvarDeclLoc(),
3878 diag::err_odr_objc_synthesize_ivar_inconsistent)
3879 << Property->getDeclName()
3880 << ToImpl->getPropertyIvarDecl()->getDeclName()
3881 << Ivar->getDeclName();
3882 Importer.FromDiag(D->getPropertyIvarDeclLoc(),
3883 diag::note_odr_objc_synthesize_ivar_here)
3884 << D->getPropertyIvarDecl()->getDeclName();
3885 return 0;
3886 }
3887
3888 // Merge the existing implementation with the new implementation.
3889 Importer.Imported(D, ToImpl);
3890 }
3891
3892 return ToImpl;
3893}
3894
Douglas Gregora082a492010-11-30 19:14:50 +00003895Decl *ASTNodeImporter::VisitTemplateTypeParmDecl(TemplateTypeParmDecl *D) {
3896 // For template arguments, we adopt the translation unit as our declaration
3897 // context. This context will be fixed when the actual template declaration
3898 // is created.
3899
3900 // FIXME: Import default argument.
3901 return TemplateTypeParmDecl::Create(Importer.getToContext(),
3902 Importer.getToContext().getTranslationUnitDecl(),
Abramo Bagnarab3185b02011-03-06 15:48:19 +00003903 Importer.Import(D->getLocStart()),
Douglas Gregora082a492010-11-30 19:14:50 +00003904 Importer.Import(D->getLocation()),
3905 D->getDepth(),
3906 D->getIndex(),
3907 Importer.Import(D->getIdentifier()),
3908 D->wasDeclaredWithTypename(),
3909 D->isParameterPack());
3910}
3911
3912Decl *
3913ASTNodeImporter::VisitNonTypeTemplateParmDecl(NonTypeTemplateParmDecl *D) {
3914 // Import the name of this declaration.
3915 DeclarationName Name = Importer.Import(D->getDeclName());
3916 if (D->getDeclName() && !Name)
3917 return 0;
3918
3919 // Import the location of this declaration.
3920 SourceLocation Loc = Importer.Import(D->getLocation());
3921
3922 // Import the type of this declaration.
3923 QualType T = Importer.Import(D->getType());
3924 if (T.isNull())
3925 return 0;
3926
3927 // Import type-source information.
3928 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
3929 if (D->getTypeSourceInfo() && !TInfo)
3930 return 0;
3931
3932 // FIXME: Import default argument.
3933
3934 return NonTypeTemplateParmDecl::Create(Importer.getToContext(),
3935 Importer.getToContext().getTranslationUnitDecl(),
Abramo Bagnaradff19302011-03-08 08:55:46 +00003936 Importer.Import(D->getInnerLocStart()),
Douglas Gregora082a492010-11-30 19:14:50 +00003937 Loc, D->getDepth(), D->getPosition(),
3938 Name.getAsIdentifierInfo(),
Douglas Gregorda3cc0d2010-12-23 23:51:58 +00003939 T, D->isParameterPack(), TInfo);
Douglas Gregora082a492010-11-30 19:14:50 +00003940}
3941
3942Decl *
3943ASTNodeImporter::VisitTemplateTemplateParmDecl(TemplateTemplateParmDecl *D) {
3944 // Import the name of this declaration.
3945 DeclarationName Name = Importer.Import(D->getDeclName());
3946 if (D->getDeclName() && !Name)
3947 return 0;
3948
3949 // Import the location of this declaration.
3950 SourceLocation Loc = Importer.Import(D->getLocation());
3951
3952 // Import template parameters.
3953 TemplateParameterList *TemplateParams
3954 = ImportTemplateParameterList(D->getTemplateParameters());
3955 if (!TemplateParams)
3956 return 0;
3957
3958 // FIXME: Import default argument.
3959
3960 return TemplateTemplateParmDecl::Create(Importer.getToContext(),
3961 Importer.getToContext().getTranslationUnitDecl(),
3962 Loc, D->getDepth(), D->getPosition(),
Douglas Gregorf5500772011-01-05 15:48:55 +00003963 D->isParameterPack(),
Douglas Gregora082a492010-11-30 19:14:50 +00003964 Name.getAsIdentifierInfo(),
3965 TemplateParams);
3966}
3967
3968Decl *ASTNodeImporter::VisitClassTemplateDecl(ClassTemplateDecl *D) {
3969 // If this record has a definition in the translation unit we're coming from,
3970 // but this particular declaration is not that definition, import the
3971 // definition and map to that.
3972 CXXRecordDecl *Definition
3973 = cast_or_null<CXXRecordDecl>(D->getTemplatedDecl()->getDefinition());
3974 if (Definition && Definition != D->getTemplatedDecl()) {
3975 Decl *ImportedDef
3976 = Importer.Import(Definition->getDescribedClassTemplate());
3977 if (!ImportedDef)
3978 return 0;
3979
3980 return Importer.Imported(D, ImportedDef);
3981 }
3982
3983 // Import the major distinguishing characteristics of this class template.
3984 DeclContext *DC, *LexicalDC;
3985 DeclarationName Name;
3986 SourceLocation Loc;
3987 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
3988 return 0;
3989
3990 // We may already have a template of the same name; try to find and match it.
3991 if (!DC->isFunctionOrMethod()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +00003992 SmallVector<NamedDecl *, 4> ConflictingDecls;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00003993 SmallVector<NamedDecl *, 2> FoundDecls;
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003994 DC->localUncachedLookup(Name, FoundDecls);
3995 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
3996 if (!FoundDecls[I]->isInIdentifierNamespace(Decl::IDNS_Ordinary))
Douglas Gregora082a492010-11-30 19:14:50 +00003997 continue;
3998
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00003999 Decl *Found = FoundDecls[I];
Douglas Gregora082a492010-11-30 19:14:50 +00004000 if (ClassTemplateDecl *FoundTemplate
4001 = dyn_cast<ClassTemplateDecl>(Found)) {
4002 if (IsStructuralMatch(D, FoundTemplate)) {
4003 // The class templates structurally match; call it the same template.
4004 // FIXME: We may be filling in a forward declaration here. Handle
4005 // this case!
4006 Importer.Imported(D->getTemplatedDecl(),
4007 FoundTemplate->getTemplatedDecl());
4008 return Importer.Imported(D, FoundTemplate);
4009 }
4010 }
4011
Douglas Gregor9e0a5b32011-10-15 00:10:27 +00004012 ConflictingDecls.push_back(FoundDecls[I]);
Douglas Gregora082a492010-11-30 19:14:50 +00004013 }
4014
4015 if (!ConflictingDecls.empty()) {
4016 Name = Importer.HandleNameConflict(Name, DC, Decl::IDNS_Ordinary,
4017 ConflictingDecls.data(),
4018 ConflictingDecls.size());
4019 }
4020
4021 if (!Name)
4022 return 0;
4023 }
4024
4025 CXXRecordDecl *DTemplated = D->getTemplatedDecl();
4026
4027 // Create the declaration that is being templated.
Abramo Bagnara29c2d462011-03-09 14:09:51 +00004028 SourceLocation StartLoc = Importer.Import(DTemplated->getLocStart());
4029 SourceLocation IdLoc = Importer.Import(DTemplated->getLocation());
Douglas Gregora082a492010-11-30 19:14:50 +00004030 CXXRecordDecl *D2Templated = CXXRecordDecl::Create(Importer.getToContext(),
4031 DTemplated->getTagKind(),
Abramo Bagnara29c2d462011-03-09 14:09:51 +00004032 DC, StartLoc, IdLoc,
4033 Name.getAsIdentifierInfo());
Douglas Gregora082a492010-11-30 19:14:50 +00004034 D2Templated->setAccess(DTemplated->getAccess());
Douglas Gregor14454802011-02-25 02:25:35 +00004035 D2Templated->setQualifierInfo(Importer.Import(DTemplated->getQualifierLoc()));
Douglas Gregora082a492010-11-30 19:14:50 +00004036 D2Templated->setLexicalDeclContext(LexicalDC);
4037
4038 // Create the class template declaration itself.
4039 TemplateParameterList *TemplateParams
4040 = ImportTemplateParameterList(D->getTemplateParameters());
4041 if (!TemplateParams)
4042 return 0;
4043
4044 ClassTemplateDecl *D2 = ClassTemplateDecl::Create(Importer.getToContext(), DC,
4045 Loc, Name, TemplateParams,
4046 D2Templated,
4047 /*PrevDecl=*/0);
4048 D2Templated->setDescribedClassTemplate(D2);
4049
4050 D2->setAccess(D->getAccess());
4051 D2->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00004052 LexicalDC->addDeclInternal(D2);
Douglas Gregora082a492010-11-30 19:14:50 +00004053
4054 // Note the relationship between the class templates.
4055 Importer.Imported(D, D2);
4056 Importer.Imported(DTemplated, D2Templated);
4057
John McCallf937c022011-10-07 06:10:15 +00004058 if (DTemplated->isCompleteDefinition() &&
4059 !D2Templated->isCompleteDefinition()) {
Douglas Gregora082a492010-11-30 19:14:50 +00004060 // FIXME: Import definition!
4061 }
4062
4063 return D2;
4064}
4065
Douglas Gregore2e50d332010-12-01 01:36:18 +00004066Decl *ASTNodeImporter::VisitClassTemplateSpecializationDecl(
4067 ClassTemplateSpecializationDecl *D) {
4068 // If this record has a definition in the translation unit we're coming from,
4069 // but this particular declaration is not that definition, import the
4070 // definition and map to that.
4071 TagDecl *Definition = D->getDefinition();
4072 if (Definition && Definition != D) {
4073 Decl *ImportedDef = Importer.Import(Definition);
4074 if (!ImportedDef)
4075 return 0;
4076
4077 return Importer.Imported(D, ImportedDef);
4078 }
4079
4080 ClassTemplateDecl *ClassTemplate
4081 = cast_or_null<ClassTemplateDecl>(Importer.Import(
4082 D->getSpecializedTemplate()));
4083 if (!ClassTemplate)
4084 return 0;
4085
4086 // Import the context of this declaration.
4087 DeclContext *DC = ClassTemplate->getDeclContext();
4088 if (!DC)
4089 return 0;
4090
4091 DeclContext *LexicalDC = DC;
4092 if (D->getDeclContext() != D->getLexicalDeclContext()) {
4093 LexicalDC = Importer.ImportContext(D->getLexicalDeclContext());
4094 if (!LexicalDC)
4095 return 0;
4096 }
4097
4098 // Import the location of this declaration.
Abramo Bagnara29c2d462011-03-09 14:09:51 +00004099 SourceLocation StartLoc = Importer.Import(D->getLocStart());
4100 SourceLocation IdLoc = Importer.Import(D->getLocation());
Douglas Gregore2e50d332010-12-01 01:36:18 +00004101
4102 // Import template arguments.
Chris Lattner0e62c1c2011-07-23 10:55:15 +00004103 SmallVector<TemplateArgument, 2> TemplateArgs;
Douglas Gregore2e50d332010-12-01 01:36:18 +00004104 if (ImportTemplateArguments(D->getTemplateArgs().data(),
4105 D->getTemplateArgs().size(),
4106 TemplateArgs))
4107 return 0;
4108
4109 // Try to find an existing specialization with these template arguments.
4110 void *InsertPos = 0;
4111 ClassTemplateSpecializationDecl *D2
4112 = ClassTemplate->findSpecialization(TemplateArgs.data(),
4113 TemplateArgs.size(), InsertPos);
4114 if (D2) {
4115 // We already have a class template specialization with these template
4116 // arguments.
4117
4118 // FIXME: Check for specialization vs. instantiation errors.
4119
4120 if (RecordDecl *FoundDef = D2->getDefinition()) {
John McCallf937c022011-10-07 06:10:15 +00004121 if (!D->isCompleteDefinition() || IsStructuralMatch(D, FoundDef)) {
Douglas Gregore2e50d332010-12-01 01:36:18 +00004122 // The record types structurally match, or the "from" translation
4123 // unit only had a forward declaration anyway; call it the same
4124 // function.
4125 return Importer.Imported(D, FoundDef);
4126 }
4127 }
4128 } else {
4129 // Create a new specialization.
4130 D2 = ClassTemplateSpecializationDecl::Create(Importer.getToContext(),
4131 D->getTagKind(), DC,
Abramo Bagnara29c2d462011-03-09 14:09:51 +00004132 StartLoc, IdLoc,
4133 ClassTemplate,
Douglas Gregore2e50d332010-12-01 01:36:18 +00004134 TemplateArgs.data(),
4135 TemplateArgs.size(),
4136 /*PrevDecl=*/0);
4137 D2->setSpecializationKind(D->getSpecializationKind());
4138
4139 // Add this specialization to the class template.
4140 ClassTemplate->AddSpecialization(D2, InsertPos);
4141
4142 // Import the qualifier, if any.
Douglas Gregor14454802011-02-25 02:25:35 +00004143 D2->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
Douglas Gregore2e50d332010-12-01 01:36:18 +00004144
4145 // Add the specialization to this context.
4146 D2->setLexicalDeclContext(LexicalDC);
Sean Callanan95e74be2011-10-21 02:57:43 +00004147 LexicalDC->addDeclInternal(D2);
Douglas Gregore2e50d332010-12-01 01:36:18 +00004148 }
4149 Importer.Imported(D, D2);
4150
John McCallf937c022011-10-07 06:10:15 +00004151 if (D->isCompleteDefinition() && ImportDefinition(D, D2))
Douglas Gregore2e50d332010-12-01 01:36:18 +00004152 return 0;
4153
4154 return D2;
4155}
4156
Larisse Voufo39a1e502013-08-06 01:03:05 +00004157Decl *ASTNodeImporter::VisitVarTemplateDecl(VarTemplateDecl *D) {
4158 // If this variable has a definition in the translation unit we're coming
4159 // from,
4160 // but this particular declaration is not that definition, import the
4161 // definition and map to that.
4162 VarDecl *Definition =
4163 cast_or_null<VarDecl>(D->getTemplatedDecl()->getDefinition());
4164 if (Definition && Definition != D->getTemplatedDecl()) {
4165 Decl *ImportedDef = Importer.Import(Definition->getDescribedVarTemplate());
4166 if (!ImportedDef)
4167 return 0;
4168
4169 return Importer.Imported(D, ImportedDef);
4170 }
4171
4172 // Import the major distinguishing characteristics of this variable template.
4173 DeclContext *DC, *LexicalDC;
4174 DeclarationName Name;
4175 SourceLocation Loc;
4176 if (ImportDeclParts(D, DC, LexicalDC, Name, Loc))
4177 return 0;
4178
4179 // We may already have a template of the same name; try to find and match it.
4180 assert(!DC->isFunctionOrMethod() &&
4181 "Variable templates cannot be declared at function scope");
4182 SmallVector<NamedDecl *, 4> ConflictingDecls;
4183 SmallVector<NamedDecl *, 2> FoundDecls;
4184 DC->localUncachedLookup(Name, FoundDecls);
4185 for (unsigned I = 0, N = FoundDecls.size(); I != N; ++I) {
4186 if (!FoundDecls[I]->isInIdentifierNamespace(Decl::IDNS_Ordinary))
4187 continue;
4188
4189 Decl *Found = FoundDecls[I];
4190 if (VarTemplateDecl *FoundTemplate = dyn_cast<VarTemplateDecl>(Found)) {
4191 if (IsStructuralMatch(D, FoundTemplate)) {
4192 // The variable templates structurally match; call it the same template.
4193 Importer.Imported(D->getTemplatedDecl(),
4194 FoundTemplate->getTemplatedDecl());
4195 return Importer.Imported(D, FoundTemplate);
4196 }
4197 }
4198
4199 ConflictingDecls.push_back(FoundDecls[I]);
4200 }
4201
4202 if (!ConflictingDecls.empty()) {
4203 Name = Importer.HandleNameConflict(Name, DC, Decl::IDNS_Ordinary,
4204 ConflictingDecls.data(),
4205 ConflictingDecls.size());
4206 }
4207
4208 if (!Name)
4209 return 0;
4210
4211 VarDecl *DTemplated = D->getTemplatedDecl();
4212
4213 // Import the type.
4214 QualType T = Importer.Import(DTemplated->getType());
4215 if (T.isNull())
4216 return 0;
4217
4218 // Create the declaration that is being templated.
4219 SourceLocation StartLoc = Importer.Import(DTemplated->getLocStart());
4220 SourceLocation IdLoc = Importer.Import(DTemplated->getLocation());
4221 TypeSourceInfo *TInfo = Importer.Import(DTemplated->getTypeSourceInfo());
4222 VarDecl *D2Templated = VarDecl::Create(Importer.getToContext(), DC, StartLoc,
4223 IdLoc, Name.getAsIdentifierInfo(), T,
4224 TInfo, DTemplated->getStorageClass());
4225 D2Templated->setAccess(DTemplated->getAccess());
4226 D2Templated->setQualifierInfo(Importer.Import(DTemplated->getQualifierLoc()));
4227 D2Templated->setLexicalDeclContext(LexicalDC);
4228
4229 // Importer.Imported(DTemplated, D2Templated);
4230 // LexicalDC->addDeclInternal(D2Templated);
4231
4232 // Merge the initializer.
4233 if (ImportDefinition(DTemplated, D2Templated))
4234 return 0;
4235
4236 // Create the variable template declaration itself.
4237 TemplateParameterList *TemplateParams =
4238 ImportTemplateParameterList(D->getTemplateParameters());
4239 if (!TemplateParams)
4240 return 0;
4241
4242 VarTemplateDecl *D2 = VarTemplateDecl::Create(
Richard Smithbeef3452014-01-16 23:39:20 +00004243 Importer.getToContext(), DC, Loc, Name, TemplateParams, D2Templated);
Larisse Voufo39a1e502013-08-06 01:03:05 +00004244 D2Templated->setDescribedVarTemplate(D2);
4245
4246 D2->setAccess(D->getAccess());
4247 D2->setLexicalDeclContext(LexicalDC);
4248 LexicalDC->addDeclInternal(D2);
4249
4250 // Note the relationship between the variable templates.
4251 Importer.Imported(D, D2);
4252 Importer.Imported(DTemplated, D2Templated);
4253
4254 if (DTemplated->isThisDeclarationADefinition() &&
4255 !D2Templated->isThisDeclarationADefinition()) {
4256 // FIXME: Import definition!
4257 }
4258
4259 return D2;
4260}
4261
4262Decl *ASTNodeImporter::VisitVarTemplateSpecializationDecl(
4263 VarTemplateSpecializationDecl *D) {
4264 // If this record has a definition in the translation unit we're coming from,
4265 // but this particular declaration is not that definition, import the
4266 // definition and map to that.
4267 VarDecl *Definition = D->getDefinition();
4268 if (Definition && Definition != D) {
4269 Decl *ImportedDef = Importer.Import(Definition);
4270 if (!ImportedDef)
4271 return 0;
4272
4273 return Importer.Imported(D, ImportedDef);
4274 }
4275
4276 VarTemplateDecl *VarTemplate = cast_or_null<VarTemplateDecl>(
4277 Importer.Import(D->getSpecializedTemplate()));
4278 if (!VarTemplate)
4279 return 0;
4280
4281 // Import the context of this declaration.
4282 DeclContext *DC = VarTemplate->getDeclContext();
4283 if (!DC)
4284 return 0;
4285
4286 DeclContext *LexicalDC = DC;
4287 if (D->getDeclContext() != D->getLexicalDeclContext()) {
4288 LexicalDC = Importer.ImportContext(D->getLexicalDeclContext());
4289 if (!LexicalDC)
4290 return 0;
4291 }
4292
4293 // Import the location of this declaration.
4294 SourceLocation StartLoc = Importer.Import(D->getLocStart());
4295 SourceLocation IdLoc = Importer.Import(D->getLocation());
4296
4297 // Import template arguments.
4298 SmallVector<TemplateArgument, 2> TemplateArgs;
4299 if (ImportTemplateArguments(D->getTemplateArgs().data(),
4300 D->getTemplateArgs().size(), TemplateArgs))
4301 return 0;
4302
4303 // Try to find an existing specialization with these template arguments.
4304 void *InsertPos = 0;
4305 VarTemplateSpecializationDecl *D2 = VarTemplate->findSpecialization(
4306 TemplateArgs.data(), TemplateArgs.size(), InsertPos);
4307 if (D2) {
4308 // We already have a variable template specialization with these template
4309 // arguments.
4310
4311 // FIXME: Check for specialization vs. instantiation errors.
4312
4313 if (VarDecl *FoundDef = D2->getDefinition()) {
4314 if (!D->isThisDeclarationADefinition() ||
4315 IsStructuralMatch(D, FoundDef)) {
4316 // The record types structurally match, or the "from" translation
4317 // unit only had a forward declaration anyway; call it the same
4318 // variable.
4319 return Importer.Imported(D, FoundDef);
4320 }
4321 }
4322 } else {
4323
4324 // Import the type.
4325 QualType T = Importer.Import(D->getType());
4326 if (T.isNull())
4327 return 0;
4328 TypeSourceInfo *TInfo = Importer.Import(D->getTypeSourceInfo());
4329
4330 // Create a new specialization.
4331 D2 = VarTemplateSpecializationDecl::Create(
4332 Importer.getToContext(), DC, StartLoc, IdLoc, VarTemplate, T, TInfo,
4333 D->getStorageClass(), TemplateArgs.data(), TemplateArgs.size());
4334 D2->setSpecializationKind(D->getSpecializationKind());
4335 D2->setTemplateArgsInfo(D->getTemplateArgsInfo());
4336
4337 // Add this specialization to the class template.
4338 VarTemplate->AddSpecialization(D2, InsertPos);
4339
4340 // Import the qualifier, if any.
4341 D2->setQualifierInfo(Importer.Import(D->getQualifierLoc()));
4342
4343 // Add the specialization to this context.
4344 D2->setLexicalDeclContext(LexicalDC);
4345 LexicalDC->addDeclInternal(D2);
4346 }
4347 Importer.Imported(D, D2);
4348
4349 if (D->isThisDeclarationADefinition() && ImportDefinition(D, D2))
4350 return 0;
4351
4352 return D2;
4353}
4354
Douglas Gregor7eeb5972010-02-11 19:21:55 +00004355//----------------------------------------------------------------------------
4356// Import Statements
4357//----------------------------------------------------------------------------
4358
4359Stmt *ASTNodeImporter::VisitStmt(Stmt *S) {
4360 Importer.FromDiag(S->getLocStart(), diag::err_unsupported_ast_node)
4361 << S->getStmtClassName();
4362 return 0;
4363}
4364
4365//----------------------------------------------------------------------------
4366// Import Expressions
4367//----------------------------------------------------------------------------
4368Expr *ASTNodeImporter::VisitExpr(Expr *E) {
4369 Importer.FromDiag(E->getLocStart(), diag::err_unsupported_ast_node)
4370 << E->getStmtClassName();
4371 return 0;
4372}
4373
Douglas Gregor52f820e2010-02-19 01:17:02 +00004374Expr *ASTNodeImporter::VisitDeclRefExpr(DeclRefExpr *E) {
Douglas Gregor52f820e2010-02-19 01:17:02 +00004375 ValueDecl *ToD = cast_or_null<ValueDecl>(Importer.Import(E->getDecl()));
4376 if (!ToD)
4377 return 0;
Chandler Carruth8d26bb02011-05-01 23:48:14 +00004378
4379 NamedDecl *FoundD = 0;
4380 if (E->getDecl() != E->getFoundDecl()) {
4381 FoundD = cast_or_null<NamedDecl>(Importer.Import(E->getFoundDecl()));
4382 if (!FoundD)
4383 return 0;
4384 }
Douglas Gregor52f820e2010-02-19 01:17:02 +00004385
4386 QualType T = Importer.Import(E->getType());
4387 if (T.isNull())
4388 return 0;
Abramo Bagnara635ed24e2011-10-05 07:56:41 +00004389
4390 DeclRefExpr *DRE = DeclRefExpr::Create(Importer.getToContext(),
4391 Importer.Import(E->getQualifierLoc()),
Abramo Bagnara7945c982012-01-27 09:46:47 +00004392 Importer.Import(E->getTemplateKeywordLoc()),
Abramo Bagnara635ed24e2011-10-05 07:56:41 +00004393 ToD,
John McCall113bee02012-03-10 09:33:50 +00004394 E->refersToEnclosingLocal(),
Abramo Bagnara635ed24e2011-10-05 07:56:41 +00004395 Importer.Import(E->getLocation()),
4396 T, E->getValueKind(),
4397 FoundD,
4398 /*FIXME:TemplateArgs=*/0);
4399 if (E->hadMultipleCandidates())
4400 DRE->setHadMultipleCandidates(true);
4401 return DRE;
Douglas Gregor52f820e2010-02-19 01:17:02 +00004402}
4403
Douglas Gregor7eeb5972010-02-11 19:21:55 +00004404Expr *ASTNodeImporter::VisitIntegerLiteral(IntegerLiteral *E) {
4405 QualType T = Importer.Import(E->getType());
4406 if (T.isNull())
4407 return 0;
4408
Argyrios Kyrtzidis43b20572010-08-28 09:06:06 +00004409 return IntegerLiteral::Create(Importer.getToContext(),
4410 E->getValue(), T,
4411 Importer.Import(E->getLocation()));
Douglas Gregor7eeb5972010-02-11 19:21:55 +00004412}
4413
Douglas Gregor623421d2010-02-18 02:21:22 +00004414Expr *ASTNodeImporter::VisitCharacterLiteral(CharacterLiteral *E) {
4415 QualType T = Importer.Import(E->getType());
4416 if (T.isNull())
4417 return 0;
4418
Douglas Gregorfb65e592011-07-27 05:40:30 +00004419 return new (Importer.getToContext()) CharacterLiteral(E->getValue(),
4420 E->getKind(), T,
Douglas Gregor623421d2010-02-18 02:21:22 +00004421 Importer.Import(E->getLocation()));
4422}
4423
Douglas Gregorc74247e2010-02-19 01:07:06 +00004424Expr *ASTNodeImporter::VisitParenExpr(ParenExpr *E) {
4425 Expr *SubExpr = Importer.Import(E->getSubExpr());
4426 if (!SubExpr)
4427 return 0;
4428
4429 return new (Importer.getToContext())
4430 ParenExpr(Importer.Import(E->getLParen()),
4431 Importer.Import(E->getRParen()),
4432 SubExpr);
4433}
4434
4435Expr *ASTNodeImporter::VisitUnaryOperator(UnaryOperator *E) {
4436 QualType T = Importer.Import(E->getType());
4437 if (T.isNull())
4438 return 0;
4439
4440 Expr *SubExpr = Importer.Import(E->getSubExpr());
4441 if (!SubExpr)
4442 return 0;
4443
4444 return new (Importer.getToContext()) UnaryOperator(SubExpr, E->getOpcode(),
John McCall7decc9e2010-11-18 06:31:45 +00004445 T, E->getValueKind(),
4446 E->getObjectKind(),
Douglas Gregorc74247e2010-02-19 01:07:06 +00004447 Importer.Import(E->getOperatorLoc()));
4448}
4449
Peter Collingbournee190dee2011-03-11 19:24:49 +00004450Expr *ASTNodeImporter::VisitUnaryExprOrTypeTraitExpr(
4451 UnaryExprOrTypeTraitExpr *E) {
Douglas Gregord8552cd2010-02-19 01:24:23 +00004452 QualType ResultType = Importer.Import(E->getType());
4453
4454 if (E->isArgumentType()) {
4455 TypeSourceInfo *TInfo = Importer.Import(E->getArgumentTypeInfo());
4456 if (!TInfo)
4457 return 0;
4458
Peter Collingbournee190dee2011-03-11 19:24:49 +00004459 return new (Importer.getToContext()) UnaryExprOrTypeTraitExpr(E->getKind(),
4460 TInfo, ResultType,
Douglas Gregord8552cd2010-02-19 01:24:23 +00004461 Importer.Import(E->getOperatorLoc()),
4462 Importer.Import(E->getRParenLoc()));
4463 }
4464
4465 Expr *SubExpr = Importer.Import(E->getArgumentExpr());
4466 if (!SubExpr)
4467 return 0;
4468
Peter Collingbournee190dee2011-03-11 19:24:49 +00004469 return new (Importer.getToContext()) UnaryExprOrTypeTraitExpr(E->getKind(),
4470 SubExpr, ResultType,
Douglas Gregord8552cd2010-02-19 01:24:23 +00004471 Importer.Import(E->getOperatorLoc()),
4472 Importer.Import(E->getRParenLoc()));
4473}
4474
Douglas Gregorc74247e2010-02-19 01:07:06 +00004475Expr *ASTNodeImporter::VisitBinaryOperator(BinaryOperator *E) {
4476 QualType T = Importer.Import(E->getType());
4477 if (T.isNull())
4478 return 0;
4479
4480 Expr *LHS = Importer.Import(E->getLHS());
4481 if (!LHS)
4482 return 0;
4483
4484 Expr *RHS = Importer.Import(E->getRHS());
4485 if (!RHS)
4486 return 0;
4487
4488 return new (Importer.getToContext()) BinaryOperator(LHS, RHS, E->getOpcode(),
John McCall7decc9e2010-11-18 06:31:45 +00004489 T, E->getValueKind(),
4490 E->getObjectKind(),
Lang Hames5de91cc2012-10-02 04:45:10 +00004491 Importer.Import(E->getOperatorLoc()),
4492 E->isFPContractable());
Douglas Gregorc74247e2010-02-19 01:07:06 +00004493}
4494
4495Expr *ASTNodeImporter::VisitCompoundAssignOperator(CompoundAssignOperator *E) {
4496 QualType T = Importer.Import(E->getType());
4497 if (T.isNull())
4498 return 0;
4499
4500 QualType CompLHSType = Importer.Import(E->getComputationLHSType());
4501 if (CompLHSType.isNull())
4502 return 0;
4503
4504 QualType CompResultType = Importer.Import(E->getComputationResultType());
4505 if (CompResultType.isNull())
4506 return 0;
4507
4508 Expr *LHS = Importer.Import(E->getLHS());
4509 if (!LHS)
4510 return 0;
4511
4512 Expr *RHS = Importer.Import(E->getRHS());
4513 if (!RHS)
4514 return 0;
4515
4516 return new (Importer.getToContext())
4517 CompoundAssignOperator(LHS, RHS, E->getOpcode(),
John McCall7decc9e2010-11-18 06:31:45 +00004518 T, E->getValueKind(),
4519 E->getObjectKind(),
4520 CompLHSType, CompResultType,
Lang Hames5de91cc2012-10-02 04:45:10 +00004521 Importer.Import(E->getOperatorLoc()),
4522 E->isFPContractable());
Douglas Gregorc74247e2010-02-19 01:07:06 +00004523}
4524
Benjamin Kramer8aef5962011-03-26 12:38:21 +00004525static bool ImportCastPath(CastExpr *E, CXXCastPath &Path) {
John McCallcf142162010-08-07 06:22:56 +00004526 if (E->path_empty()) return false;
4527
4528 // TODO: import cast paths
4529 return true;
4530}
4531
Douglas Gregor98c10182010-02-12 22:17:39 +00004532Expr *ASTNodeImporter::VisitImplicitCastExpr(ImplicitCastExpr *E) {
4533 QualType T = Importer.Import(E->getType());
4534 if (T.isNull())
4535 return 0;
4536
4537 Expr *SubExpr = Importer.Import(E->getSubExpr());
4538 if (!SubExpr)
4539 return 0;
John McCallcf142162010-08-07 06:22:56 +00004540
4541 CXXCastPath BasePath;
4542 if (ImportCastPath(E, BasePath))
4543 return 0;
4544
4545 return ImplicitCastExpr::Create(Importer.getToContext(), T, E->getCastKind(),
John McCall2536c6d2010-08-25 10:28:54 +00004546 SubExpr, &BasePath, E->getValueKind());
Douglas Gregor98c10182010-02-12 22:17:39 +00004547}
4548
Douglas Gregor5481d322010-02-19 01:32:14 +00004549Expr *ASTNodeImporter::VisitCStyleCastExpr(CStyleCastExpr *E) {
4550 QualType T = Importer.Import(E->getType());
4551 if (T.isNull())
4552 return 0;
4553
4554 Expr *SubExpr = Importer.Import(E->getSubExpr());
4555 if (!SubExpr)
4556 return 0;
4557
4558 TypeSourceInfo *TInfo = Importer.Import(E->getTypeInfoAsWritten());
4559 if (!TInfo && E->getTypeInfoAsWritten())
4560 return 0;
4561
John McCallcf142162010-08-07 06:22:56 +00004562 CXXCastPath BasePath;
4563 if (ImportCastPath(E, BasePath))
4564 return 0;
4565
John McCall7decc9e2010-11-18 06:31:45 +00004566 return CStyleCastExpr::Create(Importer.getToContext(), T,
4567 E->getValueKind(), E->getCastKind(),
John McCallcf142162010-08-07 06:22:56 +00004568 SubExpr, &BasePath, TInfo,
4569 Importer.Import(E->getLParenLoc()),
4570 Importer.Import(E->getRParenLoc()));
Douglas Gregor5481d322010-02-19 01:32:14 +00004571}
4572
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +00004573ASTImporter::ASTImporter(ASTContext &ToContext, FileManager &ToFileManager,
Douglas Gregor0a791672011-01-18 03:11:38 +00004574 ASTContext &FromContext, FileManager &FromFileManager,
4575 bool MinimalImport)
Douglas Gregor96e578d2010-02-05 17:54:41 +00004576 : ToContext(ToContext), FromContext(FromContext),
Douglas Gregor0a791672011-01-18 03:11:38 +00004577 ToFileManager(ToFileManager), FromFileManager(FromFileManager),
Richard Smith5bb4cdf2012-12-20 02:22:15 +00004578 Minimal(MinimalImport), LastDiagFromFrom(false)
Douglas Gregor0a791672011-01-18 03:11:38 +00004579{
Douglas Gregor62d311f2010-02-09 19:21:46 +00004580 ImportedDecls[FromContext.getTranslationUnitDecl()]
4581 = ToContext.getTranslationUnitDecl();
4582}
4583
4584ASTImporter::~ASTImporter() { }
Douglas Gregor96e578d2010-02-05 17:54:41 +00004585
4586QualType ASTImporter::Import(QualType FromT) {
4587 if (FromT.isNull())
4588 return QualType();
John McCall424cec92011-01-19 06:33:43 +00004589
4590 const Type *fromTy = FromT.getTypePtr();
Douglas Gregor96e578d2010-02-05 17:54:41 +00004591
Douglas Gregorf65bbb32010-02-08 15:18:58 +00004592 // Check whether we've already imported this type.
John McCall424cec92011-01-19 06:33:43 +00004593 llvm::DenseMap<const Type *, const Type *>::iterator Pos
4594 = ImportedTypes.find(fromTy);
Douglas Gregorf65bbb32010-02-08 15:18:58 +00004595 if (Pos != ImportedTypes.end())
John McCall424cec92011-01-19 06:33:43 +00004596 return ToContext.getQualifiedType(Pos->second, FromT.getLocalQualifiers());
Douglas Gregor96e578d2010-02-05 17:54:41 +00004597
Douglas Gregorf65bbb32010-02-08 15:18:58 +00004598 // Import the type
Douglas Gregor96e578d2010-02-05 17:54:41 +00004599 ASTNodeImporter Importer(*this);
John McCall424cec92011-01-19 06:33:43 +00004600 QualType ToT = Importer.Visit(fromTy);
Douglas Gregor96e578d2010-02-05 17:54:41 +00004601 if (ToT.isNull())
4602 return ToT;
4603
Douglas Gregorf65bbb32010-02-08 15:18:58 +00004604 // Record the imported type.
John McCall424cec92011-01-19 06:33:43 +00004605 ImportedTypes[fromTy] = ToT.getTypePtr();
Douglas Gregorf65bbb32010-02-08 15:18:58 +00004606
John McCall424cec92011-01-19 06:33:43 +00004607 return ToContext.getQualifiedType(ToT, FromT.getLocalQualifiers());
Douglas Gregor96e578d2010-02-05 17:54:41 +00004608}
4609
Douglas Gregor62d311f2010-02-09 19:21:46 +00004610TypeSourceInfo *ASTImporter::Import(TypeSourceInfo *FromTSI) {
Douglas Gregorfa7a0e52010-02-10 17:47:19 +00004611 if (!FromTSI)
4612 return FromTSI;
4613
4614 // FIXME: For now we just create a "trivial" type source info based
Nick Lewycky19b9f952010-07-26 16:56:01 +00004615 // on the type and a single location. Implement a real version of this.
Douglas Gregorfa7a0e52010-02-10 17:47:19 +00004616 QualType T = Import(FromTSI->getType());
4617 if (T.isNull())
4618 return 0;
4619
4620 return ToContext.getTrivialTypeSourceInfo(T,
Daniel Dunbar62ee6412012-03-09 18:35:03 +00004621 FromTSI->getTypeLoc().getLocStart());
Douglas Gregor62d311f2010-02-09 19:21:46 +00004622}
4623
4624Decl *ASTImporter::Import(Decl *FromD) {
4625 if (!FromD)
4626 return 0;
4627
Douglas Gregord451ea92011-07-29 23:31:30 +00004628 ASTNodeImporter Importer(*this);
4629
Douglas Gregor62d311f2010-02-09 19:21:46 +00004630 // Check whether we've already imported this declaration.
4631 llvm::DenseMap<Decl *, Decl *>::iterator Pos = ImportedDecls.find(FromD);
Douglas Gregord451ea92011-07-29 23:31:30 +00004632 if (Pos != ImportedDecls.end()) {
4633 Decl *ToD = Pos->second;
4634 Importer.ImportDefinitionIfNeeded(FromD, ToD);
4635 return ToD;
4636 }
Douglas Gregor62d311f2010-02-09 19:21:46 +00004637
4638 // Import the type
Douglas Gregor62d311f2010-02-09 19:21:46 +00004639 Decl *ToD = Importer.Visit(FromD);
4640 if (!ToD)
4641 return 0;
4642
4643 // Record the imported declaration.
4644 ImportedDecls[FromD] = ToD;
Douglas Gregorb4964f72010-02-15 23:54:17 +00004645
4646 if (TagDecl *FromTag = dyn_cast<TagDecl>(FromD)) {
4647 // Keep track of anonymous tags that have an associated typedef.
Richard Smithdda56e42011-04-15 14:24:37 +00004648 if (FromTag->getTypedefNameForAnonDecl())
Douglas Gregorb4964f72010-02-15 23:54:17 +00004649 AnonTagsWithPendingTypedefs.push_back(FromTag);
Richard Smithdda56e42011-04-15 14:24:37 +00004650 } else if (TypedefNameDecl *FromTypedef = dyn_cast<TypedefNameDecl>(FromD)) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00004651 // When we've finished transforming a typedef, see whether it was the
4652 // typedef for an anonymous tag.
Craig Topper2341c0d2013-07-04 03:08:24 +00004653 for (SmallVectorImpl<TagDecl *>::iterator
Douglas Gregorb4964f72010-02-15 23:54:17 +00004654 FromTag = AnonTagsWithPendingTypedefs.begin(),
4655 FromTagEnd = AnonTagsWithPendingTypedefs.end();
4656 FromTag != FromTagEnd; ++FromTag) {
Richard Smithdda56e42011-04-15 14:24:37 +00004657 if ((*FromTag)->getTypedefNameForAnonDecl() == FromTypedef) {
Douglas Gregorb4964f72010-02-15 23:54:17 +00004658 if (TagDecl *ToTag = cast_or_null<TagDecl>(Import(*FromTag))) {
4659 // We found the typedef for an anonymous tag; link them.
Richard Smithdda56e42011-04-15 14:24:37 +00004660 ToTag->setTypedefNameForAnonDecl(cast<TypedefNameDecl>(ToD));
Douglas Gregorb4964f72010-02-15 23:54:17 +00004661 AnonTagsWithPendingTypedefs.erase(FromTag);
4662 break;
4663 }
4664 }
4665 }
4666 }
4667
Douglas Gregor62d311f2010-02-09 19:21:46 +00004668 return ToD;
4669}
4670
4671DeclContext *ASTImporter::ImportContext(DeclContext *FromDC) {
4672 if (!FromDC)
4673 return FromDC;
4674
Douglas Gregor95d82832012-01-24 18:36:04 +00004675 DeclContext *ToDC = cast_or_null<DeclContext>(Import(cast<Decl>(FromDC)));
Douglas Gregor2e15c842012-02-01 21:00:38 +00004676 if (!ToDC)
4677 return 0;
4678
4679 // When we're using a record/enum/Objective-C class/protocol as a context, we
4680 // need it to have a definition.
4681 if (RecordDecl *ToRecord = dyn_cast<RecordDecl>(ToDC)) {
Douglas Gregor63db9712012-01-25 01:13:20 +00004682 RecordDecl *FromRecord = cast<RecordDecl>(FromDC);
Douglas Gregor2e15c842012-02-01 21:00:38 +00004683 if (ToRecord->isCompleteDefinition()) {
4684 // Do nothing.
4685 } else if (FromRecord->isCompleteDefinition()) {
4686 ASTNodeImporter(*this).ImportDefinition(FromRecord, ToRecord,
4687 ASTNodeImporter::IDK_Basic);
4688 } else {
4689 CompleteDecl(ToRecord);
4690 }
4691 } else if (EnumDecl *ToEnum = dyn_cast<EnumDecl>(ToDC)) {
4692 EnumDecl *FromEnum = cast<EnumDecl>(FromDC);
4693 if (ToEnum->isCompleteDefinition()) {
4694 // Do nothing.
4695 } else if (FromEnum->isCompleteDefinition()) {
4696 ASTNodeImporter(*this).ImportDefinition(FromEnum, ToEnum,
4697 ASTNodeImporter::IDK_Basic);
4698 } else {
4699 CompleteDecl(ToEnum);
4700 }
4701 } else if (ObjCInterfaceDecl *ToClass = dyn_cast<ObjCInterfaceDecl>(ToDC)) {
4702 ObjCInterfaceDecl *FromClass = cast<ObjCInterfaceDecl>(FromDC);
4703 if (ToClass->getDefinition()) {
4704 // Do nothing.
4705 } else if (ObjCInterfaceDecl *FromDef = FromClass->getDefinition()) {
4706 ASTNodeImporter(*this).ImportDefinition(FromDef, ToClass,
4707 ASTNodeImporter::IDK_Basic);
4708 } else {
4709 CompleteDecl(ToClass);
4710 }
4711 } else if (ObjCProtocolDecl *ToProto = dyn_cast<ObjCProtocolDecl>(ToDC)) {
4712 ObjCProtocolDecl *FromProto = cast<ObjCProtocolDecl>(FromDC);
4713 if (ToProto->getDefinition()) {
4714 // Do nothing.
4715 } else if (ObjCProtocolDecl *FromDef = FromProto->getDefinition()) {
4716 ASTNodeImporter(*this).ImportDefinition(FromDef, ToProto,
4717 ASTNodeImporter::IDK_Basic);
4718 } else {
4719 CompleteDecl(ToProto);
4720 }
Douglas Gregor95d82832012-01-24 18:36:04 +00004721 }
4722
4723 return ToDC;
Douglas Gregor62d311f2010-02-09 19:21:46 +00004724}
4725
4726Expr *ASTImporter::Import(Expr *FromE) {
4727 if (!FromE)
4728 return 0;
4729
4730 return cast_or_null<Expr>(Import(cast<Stmt>(FromE)));
4731}
4732
4733Stmt *ASTImporter::Import(Stmt *FromS) {
4734 if (!FromS)
4735 return 0;
4736
Douglas Gregor7eeb5972010-02-11 19:21:55 +00004737 // Check whether we've already imported this declaration.
4738 llvm::DenseMap<Stmt *, Stmt *>::iterator Pos = ImportedStmts.find(FromS);
4739 if (Pos != ImportedStmts.end())
4740 return Pos->second;
4741
4742 // Import the type
4743 ASTNodeImporter Importer(*this);
4744 Stmt *ToS = Importer.Visit(FromS);
4745 if (!ToS)
4746 return 0;
4747
4748 // Record the imported declaration.
4749 ImportedStmts[FromS] = ToS;
4750 return ToS;
Douglas Gregor62d311f2010-02-09 19:21:46 +00004751}
4752
4753NestedNameSpecifier *ASTImporter::Import(NestedNameSpecifier *FromNNS) {
4754 if (!FromNNS)
4755 return 0;
4756
Douglas Gregor90ebf252011-04-27 16:48:40 +00004757 NestedNameSpecifier *prefix = Import(FromNNS->getPrefix());
4758
4759 switch (FromNNS->getKind()) {
4760 case NestedNameSpecifier::Identifier:
4761 if (IdentifierInfo *II = Import(FromNNS->getAsIdentifier())) {
4762 return NestedNameSpecifier::Create(ToContext, prefix, II);
4763 }
4764 return 0;
4765
4766 case NestedNameSpecifier::Namespace:
4767 if (NamespaceDecl *NS =
4768 cast<NamespaceDecl>(Import(FromNNS->getAsNamespace()))) {
4769 return NestedNameSpecifier::Create(ToContext, prefix, NS);
4770 }
4771 return 0;
4772
4773 case NestedNameSpecifier::NamespaceAlias:
4774 if (NamespaceAliasDecl *NSAD =
4775 cast<NamespaceAliasDecl>(Import(FromNNS->getAsNamespaceAlias()))) {
4776 return NestedNameSpecifier::Create(ToContext, prefix, NSAD);
4777 }
4778 return 0;
4779
4780 case NestedNameSpecifier::Global:
4781 return NestedNameSpecifier::GlobalSpecifier(ToContext);
4782
4783 case NestedNameSpecifier::TypeSpec:
4784 case NestedNameSpecifier::TypeSpecWithTemplate: {
4785 QualType T = Import(QualType(FromNNS->getAsType(), 0u));
4786 if (!T.isNull()) {
4787 bool bTemplate = FromNNS->getKind() ==
4788 NestedNameSpecifier::TypeSpecWithTemplate;
4789 return NestedNameSpecifier::Create(ToContext, prefix,
4790 bTemplate, T.getTypePtr());
4791 }
4792 }
4793 return 0;
4794 }
4795
4796 llvm_unreachable("Invalid nested name specifier kind");
Douglas Gregor62d311f2010-02-09 19:21:46 +00004797}
4798
Douglas Gregor14454802011-02-25 02:25:35 +00004799NestedNameSpecifierLoc ASTImporter::Import(NestedNameSpecifierLoc FromNNS) {
4800 // FIXME: Implement!
4801 return NestedNameSpecifierLoc();
4802}
4803
Douglas Gregore2e50d332010-12-01 01:36:18 +00004804TemplateName ASTImporter::Import(TemplateName From) {
4805 switch (From.getKind()) {
4806 case TemplateName::Template:
4807 if (TemplateDecl *ToTemplate
4808 = cast_or_null<TemplateDecl>(Import(From.getAsTemplateDecl())))
4809 return TemplateName(ToTemplate);
4810
4811 return TemplateName();
4812
4813 case TemplateName::OverloadedTemplate: {
4814 OverloadedTemplateStorage *FromStorage = From.getAsOverloadedTemplate();
4815 UnresolvedSet<2> ToTemplates;
4816 for (OverloadedTemplateStorage::iterator I = FromStorage->begin(),
4817 E = FromStorage->end();
4818 I != E; ++I) {
4819 if (NamedDecl *To = cast_or_null<NamedDecl>(Import(*I)))
4820 ToTemplates.addDecl(To);
4821 else
4822 return TemplateName();
4823 }
4824 return ToContext.getOverloadedTemplateName(ToTemplates.begin(),
4825 ToTemplates.end());
4826 }
4827
4828 case TemplateName::QualifiedTemplate: {
4829 QualifiedTemplateName *QTN = From.getAsQualifiedTemplateName();
4830 NestedNameSpecifier *Qualifier = Import(QTN->getQualifier());
4831 if (!Qualifier)
4832 return TemplateName();
4833
4834 if (TemplateDecl *ToTemplate
4835 = cast_or_null<TemplateDecl>(Import(From.getAsTemplateDecl())))
4836 return ToContext.getQualifiedTemplateName(Qualifier,
4837 QTN->hasTemplateKeyword(),
4838 ToTemplate);
4839
4840 return TemplateName();
4841 }
4842
4843 case TemplateName::DependentTemplate: {
4844 DependentTemplateName *DTN = From.getAsDependentTemplateName();
4845 NestedNameSpecifier *Qualifier = Import(DTN->getQualifier());
4846 if (!Qualifier)
4847 return TemplateName();
4848
4849 if (DTN->isIdentifier()) {
4850 return ToContext.getDependentTemplateName(Qualifier,
4851 Import(DTN->getIdentifier()));
4852 }
4853
4854 return ToContext.getDependentTemplateName(Qualifier, DTN->getOperator());
4855 }
John McCalld9dfe3a2011-06-30 08:33:18 +00004856
4857 case TemplateName::SubstTemplateTemplateParm: {
4858 SubstTemplateTemplateParmStorage *subst
4859 = From.getAsSubstTemplateTemplateParm();
4860 TemplateTemplateParmDecl *param
4861 = cast_or_null<TemplateTemplateParmDecl>(Import(subst->getParameter()));
4862 if (!param)
4863 return TemplateName();
4864
4865 TemplateName replacement = Import(subst->getReplacement());
4866 if (replacement.isNull()) return TemplateName();
4867
4868 return ToContext.getSubstTemplateTemplateParm(param, replacement);
4869 }
Douglas Gregor5590be02011-01-15 06:45:20 +00004870
4871 case TemplateName::SubstTemplateTemplateParmPack: {
4872 SubstTemplateTemplateParmPackStorage *SubstPack
4873 = From.getAsSubstTemplateTemplateParmPack();
4874 TemplateTemplateParmDecl *Param
4875 = cast_or_null<TemplateTemplateParmDecl>(
4876 Import(SubstPack->getParameterPack()));
4877 if (!Param)
4878 return TemplateName();
4879
4880 ASTNodeImporter Importer(*this);
4881 TemplateArgument ArgPack
4882 = Importer.ImportTemplateArgument(SubstPack->getArgumentPack());
4883 if (ArgPack.isNull())
4884 return TemplateName();
4885
4886 return ToContext.getSubstTemplateTemplateParmPack(Param, ArgPack);
4887 }
Douglas Gregore2e50d332010-12-01 01:36:18 +00004888 }
4889
4890 llvm_unreachable("Invalid template name kind");
Douglas Gregore2e50d332010-12-01 01:36:18 +00004891}
4892
Douglas Gregor62d311f2010-02-09 19:21:46 +00004893SourceLocation ASTImporter::Import(SourceLocation FromLoc) {
4894 if (FromLoc.isInvalid())
4895 return SourceLocation();
4896
Douglas Gregor811663e2010-02-10 00:15:17 +00004897 SourceManager &FromSM = FromContext.getSourceManager();
4898
4899 // For now, map everything down to its spelling location, so that we
Chandler Carruth25366412011-07-15 00:04:35 +00004900 // don't have to import macro expansions.
4901 // FIXME: Import macro expansions!
Douglas Gregor811663e2010-02-10 00:15:17 +00004902 FromLoc = FromSM.getSpellingLoc(FromLoc);
4903 std::pair<FileID, unsigned> Decomposed = FromSM.getDecomposedLoc(FromLoc);
4904 SourceManager &ToSM = ToContext.getSourceManager();
4905 return ToSM.getLocForStartOfFile(Import(Decomposed.first))
Argyrios Kyrtzidise6e67de2011-09-19 20:40:19 +00004906 .getLocWithOffset(Decomposed.second);
Douglas Gregor62d311f2010-02-09 19:21:46 +00004907}
4908
4909SourceRange ASTImporter::Import(SourceRange FromRange) {
4910 return SourceRange(Import(FromRange.getBegin()), Import(FromRange.getEnd()));
4911}
4912
Douglas Gregor811663e2010-02-10 00:15:17 +00004913FileID ASTImporter::Import(FileID FromID) {
Sebastian Redl99219f12010-09-30 01:03:06 +00004914 llvm::DenseMap<FileID, FileID>::iterator Pos
4915 = ImportedFileIDs.find(FromID);
Douglas Gregor811663e2010-02-10 00:15:17 +00004916 if (Pos != ImportedFileIDs.end())
4917 return Pos->second;
4918
4919 SourceManager &FromSM = FromContext.getSourceManager();
4920 SourceManager &ToSM = ToContext.getSourceManager();
4921 const SrcMgr::SLocEntry &FromSLoc = FromSM.getSLocEntry(FromID);
Chandler Carruth25366412011-07-15 00:04:35 +00004922 assert(FromSLoc.isFile() && "Cannot handle macro expansions yet");
Douglas Gregor811663e2010-02-10 00:15:17 +00004923
4924 // Include location of this file.
4925 SourceLocation ToIncludeLoc = Import(FromSLoc.getFile().getIncludeLoc());
4926
4927 // Map the FileID for to the "to" source manager.
4928 FileID ToID;
4929 const SrcMgr::ContentCache *Cache = FromSLoc.getFile().getContentCache();
Argyrios Kyrtzidis11e6f0a2011-03-05 01:03:53 +00004930 if (Cache->OrigEntry) {
Douglas Gregor811663e2010-02-10 00:15:17 +00004931 // FIXME: We probably want to use getVirtualFile(), so we don't hit the
4932 // disk again
4933 // FIXME: We definitely want to re-use the existing MemoryBuffer, rather
4934 // than mmap the files several times.
Argyrios Kyrtzidis11e6f0a2011-03-05 01:03:53 +00004935 const FileEntry *Entry = ToFileManager.getFile(Cache->OrigEntry->getName());
Douglas Gregor811663e2010-02-10 00:15:17 +00004936 ToID = ToSM.createFileID(Entry, ToIncludeLoc,
4937 FromSLoc.getFile().getFileCharacteristic());
4938 } else {
4939 // FIXME: We want to re-use the existing MemoryBuffer!
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +00004940 const llvm::MemoryBuffer *
4941 FromBuf = Cache->getBuffer(FromContext.getDiagnostics(), FromSM);
Douglas Gregor811663e2010-02-10 00:15:17 +00004942 llvm::MemoryBuffer *ToBuf
Chris Lattner58c79342010-04-05 22:42:27 +00004943 = llvm::MemoryBuffer::getMemBufferCopy(FromBuf->getBuffer(),
Douglas Gregor811663e2010-02-10 00:15:17 +00004944 FromBuf->getBufferIdentifier());
Argyrios Kyrtzidis6566e232012-11-09 19:40:45 +00004945 ToID = ToSM.createFileIDForMemBuffer(ToBuf,
4946 FromSLoc.getFile().getFileCharacteristic());
Douglas Gregor811663e2010-02-10 00:15:17 +00004947 }
4948
4949
Sebastian Redl99219f12010-09-30 01:03:06 +00004950 ImportedFileIDs[FromID] = ToID;
Douglas Gregor811663e2010-02-10 00:15:17 +00004951 return ToID;
4952}
4953
Douglas Gregor0a791672011-01-18 03:11:38 +00004954void ASTImporter::ImportDefinition(Decl *From) {
4955 Decl *To = Import(From);
4956 if (!To)
4957 return;
4958
4959 if (DeclContext *FromDC = cast<DeclContext>(From)) {
4960 ASTNodeImporter Importer(*this);
Sean Callanan53a6bff2011-07-19 22:38:25 +00004961
4962 if (RecordDecl *ToRecord = dyn_cast<RecordDecl>(To)) {
4963 if (!ToRecord->getDefinition()) {
4964 Importer.ImportDefinition(cast<RecordDecl>(FromDC), ToRecord,
Douglas Gregor95d82832012-01-24 18:36:04 +00004965 ASTNodeImporter::IDK_Everything);
Sean Callanan53a6bff2011-07-19 22:38:25 +00004966 return;
4967 }
4968 }
Douglas Gregord451ea92011-07-29 23:31:30 +00004969
4970 if (EnumDecl *ToEnum = dyn_cast<EnumDecl>(To)) {
4971 if (!ToEnum->getDefinition()) {
4972 Importer.ImportDefinition(cast<EnumDecl>(FromDC), ToEnum,
Douglas Gregor2e15c842012-02-01 21:00:38 +00004973 ASTNodeImporter::IDK_Everything);
Douglas Gregord451ea92011-07-29 23:31:30 +00004974 return;
4975 }
4976 }
Douglas Gregor2aa53772012-01-24 17:42:07 +00004977
4978 if (ObjCInterfaceDecl *ToIFace = dyn_cast<ObjCInterfaceDecl>(To)) {
4979 if (!ToIFace->getDefinition()) {
4980 Importer.ImportDefinition(cast<ObjCInterfaceDecl>(FromDC), ToIFace,
Douglas Gregor2e15c842012-02-01 21:00:38 +00004981 ASTNodeImporter::IDK_Everything);
Douglas Gregor2aa53772012-01-24 17:42:07 +00004982 return;
4983 }
4984 }
Douglas Gregord451ea92011-07-29 23:31:30 +00004985
Douglas Gregor2aa53772012-01-24 17:42:07 +00004986 if (ObjCProtocolDecl *ToProto = dyn_cast<ObjCProtocolDecl>(To)) {
4987 if (!ToProto->getDefinition()) {
4988 Importer.ImportDefinition(cast<ObjCProtocolDecl>(FromDC), ToProto,
Douglas Gregor2e15c842012-02-01 21:00:38 +00004989 ASTNodeImporter::IDK_Everything);
Douglas Gregor2aa53772012-01-24 17:42:07 +00004990 return;
4991 }
4992 }
4993
Douglas Gregor0a791672011-01-18 03:11:38 +00004994 Importer.ImportDeclContext(FromDC, true);
4995 }
4996}
4997
Douglas Gregor96e578d2010-02-05 17:54:41 +00004998DeclarationName ASTImporter::Import(DeclarationName FromName) {
4999 if (!FromName)
5000 return DeclarationName();
5001
5002 switch (FromName.getNameKind()) {
5003 case DeclarationName::Identifier:
5004 return Import(FromName.getAsIdentifierInfo());
5005
5006 case DeclarationName::ObjCZeroArgSelector:
5007 case DeclarationName::ObjCOneArgSelector:
5008 case DeclarationName::ObjCMultiArgSelector:
5009 return Import(FromName.getObjCSelector());
5010
5011 case DeclarationName::CXXConstructorName: {
5012 QualType T = Import(FromName.getCXXNameType());
5013 if (T.isNull())
5014 return DeclarationName();
5015
5016 return ToContext.DeclarationNames.getCXXConstructorName(
5017 ToContext.getCanonicalType(T));
5018 }
5019
5020 case DeclarationName::CXXDestructorName: {
5021 QualType T = Import(FromName.getCXXNameType());
5022 if (T.isNull())
5023 return DeclarationName();
5024
5025 return ToContext.DeclarationNames.getCXXDestructorName(
5026 ToContext.getCanonicalType(T));
5027 }
5028
5029 case DeclarationName::CXXConversionFunctionName: {
5030 QualType T = Import(FromName.getCXXNameType());
5031 if (T.isNull())
5032 return DeclarationName();
5033
5034 return ToContext.DeclarationNames.getCXXConversionFunctionName(
5035 ToContext.getCanonicalType(T));
5036 }
5037
5038 case DeclarationName::CXXOperatorName:
5039 return ToContext.DeclarationNames.getCXXOperatorName(
5040 FromName.getCXXOverloadedOperator());
5041
5042 case DeclarationName::CXXLiteralOperatorName:
5043 return ToContext.DeclarationNames.getCXXLiteralOperatorName(
5044 Import(FromName.getCXXLiteralIdentifier()));
5045
5046 case DeclarationName::CXXUsingDirective:
5047 // FIXME: STATICS!
5048 return DeclarationName::getUsingDirectiveName();
5049 }
5050
David Blaikiee4d798f2012-01-20 21:50:17 +00005051 llvm_unreachable("Invalid DeclarationName Kind!");
Douglas Gregor96e578d2010-02-05 17:54:41 +00005052}
5053
Douglas Gregore2e50d332010-12-01 01:36:18 +00005054IdentifierInfo *ASTImporter::Import(const IdentifierInfo *FromId) {
Douglas Gregor96e578d2010-02-05 17:54:41 +00005055 if (!FromId)
5056 return 0;
5057
5058 return &ToContext.Idents.get(FromId->getName());
5059}
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00005060
Douglas Gregor43f54792010-02-17 02:12:47 +00005061Selector ASTImporter::Import(Selector FromSel) {
5062 if (FromSel.isNull())
5063 return Selector();
5064
Chris Lattner0e62c1c2011-07-23 10:55:15 +00005065 SmallVector<IdentifierInfo *, 4> Idents;
Douglas Gregor43f54792010-02-17 02:12:47 +00005066 Idents.push_back(Import(FromSel.getIdentifierInfoForSlot(0)));
5067 for (unsigned I = 1, N = FromSel.getNumArgs(); I < N; ++I)
5068 Idents.push_back(Import(FromSel.getIdentifierInfoForSlot(I)));
5069 return ToContext.Selectors.getSelector(FromSel.getNumArgs(), Idents.data());
5070}
5071
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00005072DeclarationName ASTImporter::HandleNameConflict(DeclarationName Name,
5073 DeclContext *DC,
5074 unsigned IDNS,
5075 NamedDecl **Decls,
5076 unsigned NumDecls) {
5077 return Name;
5078}
5079
5080DiagnosticBuilder ASTImporter::ToDiag(SourceLocation Loc, unsigned DiagID) {
Richard Smith5bb4cdf2012-12-20 02:22:15 +00005081 if (LastDiagFromFrom)
5082 ToContext.getDiagnostics().notePriorDiagnosticFrom(
5083 FromContext.getDiagnostics());
5084 LastDiagFromFrom = false;
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +00005085 return ToContext.getDiagnostics().Report(Loc, DiagID);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00005086}
5087
5088DiagnosticBuilder ASTImporter::FromDiag(SourceLocation Loc, unsigned DiagID) {
Richard Smith5bb4cdf2012-12-20 02:22:15 +00005089 if (!LastDiagFromFrom)
5090 FromContext.getDiagnostics().notePriorDiagnosticFrom(
5091 ToContext.getDiagnostics());
5092 LastDiagFromFrom = true;
Argyrios Kyrtzidisd0040642010-11-18 20:06:41 +00005093 return FromContext.getDiagnostics().Report(Loc, DiagID);
Douglas Gregor3aed6cd2010-02-08 21:09:39 +00005094}
Douglas Gregor8cdbe642010-02-12 23:44:20 +00005095
Douglas Gregor2e15c842012-02-01 21:00:38 +00005096void ASTImporter::CompleteDecl (Decl *D) {
5097 if (ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(D)) {
5098 if (!ID->getDefinition())
5099 ID->startDefinition();
5100 }
5101 else if (ObjCProtocolDecl *PD = dyn_cast<ObjCProtocolDecl>(D)) {
5102 if (!PD->getDefinition())
5103 PD->startDefinition();
5104 }
5105 else if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
5106 if (!TD->getDefinition() && !TD->isBeingDefined()) {
5107 TD->startDefinition();
5108 TD->setCompleteDefinition(true);
5109 }
5110 }
5111 else {
5112 assert (0 && "CompleteDecl called on a Decl that can't be completed");
5113 }
5114}
5115
Douglas Gregor8cdbe642010-02-12 23:44:20 +00005116Decl *ASTImporter::Imported(Decl *From, Decl *To) {
5117 ImportedDecls[From] = To;
5118 return To;
Daniel Dunbar9ced5422010-02-13 20:24:39 +00005119}
Douglas Gregorb4964f72010-02-15 23:54:17 +00005120
Douglas Gregordd6006f2012-07-17 21:16:27 +00005121bool ASTImporter::IsStructurallyEquivalent(QualType From, QualType To,
5122 bool Complain) {
John McCall424cec92011-01-19 06:33:43 +00005123 llvm::DenseMap<const Type *, const Type *>::iterator Pos
Douglas Gregorb4964f72010-02-15 23:54:17 +00005124 = ImportedTypes.find(From.getTypePtr());
5125 if (Pos != ImportedTypes.end() && ToContext.hasSameType(Import(From), To))
5126 return true;
5127
Douglas Gregordd6006f2012-07-17 21:16:27 +00005128 StructuralEquivalenceContext Ctx(FromContext, ToContext, NonEquivalentDecls,
5129 false, Complain);
Benjamin Kramer26d19c52010-02-18 13:02:13 +00005130 return Ctx.IsStructurallyEquivalent(From, To);
Douglas Gregorb4964f72010-02-15 23:54:17 +00005131}