blob: 64542d1f5e63cdac0adea15d72b068c841396876 [file] [log] [blame]
Greg Claytona2721472011-06-25 00:44:06 +00001//===-- ClangASTImporter.cpp ------------------------------------*- 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#include "clang/AST/Decl.h"
Sean Callanancbbe3ac2012-01-13 22:55:55 +000011#include "clang/AST/DeclCXX.h"
Sean Callanancc427fa2011-07-30 02:42:06 +000012#include "clang/AST/DeclObjC.h"
Greg Claytonf74c4032012-12-03 18:29:55 +000013#include "llvm/Support/raw_ostream.h"
Sean Callanancc427fa2011-07-30 02:42:06 +000014#include "lldb/Core/Log.h"
Greg Clayton7c6d7b82011-10-21 23:04:20 +000015#include "lldb/Core/Module.h"
Greg Claytona2721472011-06-25 00:44:06 +000016#include "lldb/Symbol/ClangASTContext.h"
17#include "lldb/Symbol/ClangASTImporter.h"
Sean Callanan60217122012-04-13 00:10:03 +000018#include "lldb/Symbol/ClangExternalASTSourceCommon.h"
Sean Callananb2269162011-10-21 22:18:07 +000019#include "lldb/Symbol/ClangNamespaceDecl.h"
Sean Callanan83b8ad02015-07-08 18:03:41 +000020#include "lldb/Utility/LLDBAssert.h"
Greg Claytona2721472011-06-25 00:44:06 +000021
22using namespace lldb_private;
23using namespace clang;
24
Sean Callanan8106d802013-03-08 20:04:57 +000025ClangASTMetrics::Counters ClangASTMetrics::global_counters = { 0, 0, 0, 0, 0, 0 };
26ClangASTMetrics::Counters ClangASTMetrics::local_counters = { 0, 0, 0, 0, 0, 0 };
27
Greg Clayton5160ce52013-03-27 23:08:40 +000028void ClangASTMetrics::DumpCounters (Log *log, ClangASTMetrics::Counters &counters)
Sean Callanan8106d802013-03-08 20:04:57 +000029{
Matt Kopec787d1622013-03-12 17:45:38 +000030 log->Printf(" Number of visible Decl queries by name : %" PRIu64, counters.m_visible_query_count);
31 log->Printf(" Number of lexical Decl queries : %" PRIu64, counters.m_lexical_query_count);
32 log->Printf(" Number of imports initiated by LLDB : %" PRIu64, counters.m_lldb_import_count);
33 log->Printf(" Number of imports conducted by Clang : %" PRIu64, counters.m_clang_import_count);
34 log->Printf(" Number of Decls completed : %" PRIu64, counters.m_decls_completed_count);
35 log->Printf(" Number of records laid out : %" PRIu64, counters.m_record_layout_count);
Sean Callanan8106d802013-03-08 20:04:57 +000036}
37
Greg Clayton5160ce52013-03-27 23:08:40 +000038void ClangASTMetrics::DumpCounters (Log *log)
Sean Callanan8106d802013-03-08 20:04:57 +000039{
40 if (!log)
41 return;
42
43 log->Printf("== ClangASTMetrics output ==");
44 log->Printf("-- Global metrics --");
45 DumpCounters (log, global_counters);
46 log->Printf("-- Local metrics --");
47 DumpCounters (log, local_counters);
48}
49
50clang::QualType
Sean Callanan686b2312011-11-16 18:20:47 +000051ClangASTImporter::CopyType (clang::ASTContext *dst_ast,
52 clang::ASTContext *src_ast,
Greg Claytona2721472011-06-25 00:44:06 +000053 clang::QualType type)
54{
Sean Callanan686b2312011-11-16 18:20:47 +000055 MinionSP minion_sp (GetMinion(dst_ast, src_ast));
Sean Callanancc427fa2011-07-30 02:42:06 +000056
Greg Claytondd0649b2011-07-06 18:55:08 +000057 if (minion_sp)
58 return minion_sp->Import(type);
Sean Callanancc427fa2011-07-30 02:42:06 +000059
Greg Claytondd0649b2011-07-06 18:55:08 +000060 return QualType();
Greg Claytona2721472011-06-25 00:44:06 +000061}
62
Sean Callanan80f78672011-11-16 19:07:39 +000063lldb::clang_type_t
64ClangASTImporter::CopyType (clang::ASTContext *dst_ast,
65 clang::ASTContext *src_ast,
66 lldb::clang_type_t type)
67{
68 return CopyType (dst_ast, src_ast, QualType::getFromOpaquePtr(type)).getAsOpaquePtr();
69}
70
Greg Claytona2721472011-06-25 00:44:06 +000071clang::Decl *
Sean Callanan686b2312011-11-16 18:20:47 +000072ClangASTImporter::CopyDecl (clang::ASTContext *dst_ast,
73 clang::ASTContext *src_ast,
Greg Claytona2721472011-06-25 00:44:06 +000074 clang::Decl *decl)
75{
Greg Claytondd0649b2011-07-06 18:55:08 +000076 MinionSP minion_sp;
Greg Claytona2721472011-06-25 00:44:06 +000077
Sean Callanan686b2312011-11-16 18:20:47 +000078 minion_sp = GetMinion(dst_ast, src_ast);
Greg Claytona2721472011-06-25 00:44:06 +000079
Greg Claytondd0649b2011-07-06 18:55:08 +000080 if (minion_sp)
Sean Callananbfb237bc2011-11-04 22:46:46 +000081 {
82 clang::Decl *result = minion_sp->Import(decl);
83
84 if (!result)
85 {
Greg Clayton5160ce52013-03-27 23:08:40 +000086 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callananbfb237bc2011-11-04 22:46:46 +000087
Sean Callanand5145b32011-11-05 00:08:12 +000088 if (log)
89 {
Jason Molenda900dbdc2014-10-15 23:27:12 +000090 lldb::user_id_t user_id = LLDB_INVALID_UID;
Jim Ingham379397632012-10-27 02:54:13 +000091 ClangASTMetadata *metadata = GetDeclMetadata(decl);
92 if (metadata)
93 user_id = metadata->GetUserID();
94
Sean Callanand5145b32011-11-05 00:08:12 +000095 if (NamedDecl *named_decl = dyn_cast<NamedDecl>(decl))
Daniel Malead01b2952012-11-29 21:49:15 +000096 log->Printf(" [ClangASTImporter] WARNING: Failed to import a %s '%s', metadata 0x%" PRIx64,
Sean Callanand9804fb2012-04-17 22:30:04 +000097 decl->getDeclKindName(),
98 named_decl->getNameAsString().c_str(),
Jim Ingham379397632012-10-27 02:54:13 +000099 user_id);
Sean Callanand5145b32011-11-05 00:08:12 +0000100 else
Daniel Malead01b2952012-11-29 21:49:15 +0000101 log->Printf(" [ClangASTImporter] WARNING: Failed to import a %s, metadata 0x%" PRIx64,
Sean Callanand9804fb2012-04-17 22:30:04 +0000102 decl->getDeclKindName(),
Jim Ingham379397632012-10-27 02:54:13 +0000103 user_id);
Sean Callanand5145b32011-11-05 00:08:12 +0000104 }
Sean Callananbfb237bc2011-11-04 22:46:46 +0000105 }
106
107 return result;
108 }
Sean Callanancc427fa2011-07-30 02:42:06 +0000109
Ed Masted4612ad2014-04-20 13:17:36 +0000110 return nullptr;
Greg Claytona2721472011-06-25 00:44:06 +0000111}
112
Sean Callanan83b8ad02015-07-08 18:03:41 +0000113class DeclContextOverride
114{
115private:
116 struct Backup
117 {
118 clang::DeclContext *decl_context;
119 clang::DeclContext *lexical_decl_context;
120 };
121
122 std::map<clang::Decl *, Backup> m_backups;
123
124 void OverrideOne(clang::Decl *decl)
125 {
126 if (m_backups.find(decl) != m_backups.end())
127 {
128 return;
129 }
130
131 m_backups[decl] = { decl->getDeclContext(), decl->getLexicalDeclContext() };
132
133 decl->setDeclContext(decl->getASTContext().getTranslationUnitDecl());
134 decl->setLexicalDeclContext(decl->getASTContext().getTranslationUnitDecl());
135 }
136
137 bool ChainPassesThrough(clang::Decl *decl,
138 clang::DeclContext *base,
139 clang::DeclContext *(clang::Decl::*contextFromDecl)(),
140 clang::DeclContext *(clang::DeclContext::*contextFromContext)())
141 {
142 for (DeclContext *decl_ctx = (decl->*contextFromDecl)();
143 decl_ctx;
144 decl_ctx = (decl_ctx->*contextFromContext)())
145 {
146 if (decl_ctx == base)
147 {
148 return true;
149 }
150 }
151
152 return false;
153 }
154
155 clang::Decl *GetEscapedChild(clang::Decl *decl, clang::DeclContext *base = nullptr)
156 {
157 if (base)
158 {
159 // decl's DeclContext chains must pass through base.
160
161 if (!ChainPassesThrough(decl, base, &clang::Decl::getDeclContext, &clang::DeclContext::getParent) ||
162 !ChainPassesThrough(decl, base, &clang::Decl::getLexicalDeclContext, &clang::DeclContext::getLexicalParent))
163 {
164 return decl;
165 }
166 }
167 else
168 {
169 base = clang::dyn_cast<clang::DeclContext>(decl);
170
171 if (!base)
172 {
173 return nullptr;
174 }
175 }
176
177 if (clang::DeclContext *context = clang::dyn_cast<clang::DeclContext>(decl))
178 {
179 for (clang::Decl *decl : context->decls())
180 {
181 if (clang::Decl *escaped_child = GetEscapedChild(decl))
182 {
183 return escaped_child;
184 }
185 }
186 }
187
188 return nullptr;
189 }
190
191 void Override(clang::Decl *decl)
192 {
193 if (clang::Decl *escaped_child = GetEscapedChild(decl))
194 {
195 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
196
197 if (log)
198 log->Printf(" [ClangASTImporter] DeclContextOverride couldn't override (%sDecl*)%p - its child (%sDecl*)%p escapes",
199 decl->getDeclKindName(), static_cast<void*>(decl),
200 escaped_child->getDeclKindName(), static_cast<void*>(escaped_child));
201 lldbassert(0 && "Couldn't override!");
202 }
203
204 OverrideOne(decl);
205 }
206
207public:
208 DeclContextOverride()
209 {
210 }
211
212 void OverrideAllDeclsFromContainingFunction(clang::Decl *decl)
213 {
214 for (DeclContext *decl_context = decl->getLexicalDeclContext();
215 decl_context;
216 decl_context = decl_context->getLexicalParent())
217 {
218 DeclContext *redecl_context = decl_context->getRedeclContext();
219
220 if (llvm::isa<FunctionDecl>(redecl_context) &&
221 llvm::isa<TranslationUnitDecl>(redecl_context->getLexicalParent()))
222 {
223 for (clang::Decl *child_decl : decl_context->decls())
224 {
225 Override(child_decl);
226 }
227 }
228 }
229 }
230
231 ~DeclContextOverride()
232 {
233 for (const std::pair<clang::Decl *, Backup> &backup : m_backups)
234 {
235 backup.first->setDeclContext(backup.second.decl_context);
236 backup.first->setLexicalDeclContext(backup.second.lexical_decl_context);
237 }
238 }
239};
240
Sean Callananbb120042011-12-16 21:06:35 +0000241lldb::clang_type_t
242ClangASTImporter::DeportType (clang::ASTContext *dst_ctx,
243 clang::ASTContext *src_ctx,
244 lldb::clang_type_t type)
Sean Callanane55bc8a2013-03-30 02:31:21 +0000245{
246 MinionSP minion_sp (GetMinion (dst_ctx, src_ctx));
247
248 if (!minion_sp)
Ed Masted4612ad2014-04-20 13:17:36 +0000249 return nullptr;
Sean Callanane55bc8a2013-03-30 02:31:21 +0000250
251 std::set<NamedDecl *> decls_to_deport;
252 std::set<NamedDecl *> decls_already_deported;
253
Sean Callanan83b8ad02015-07-08 18:03:41 +0000254 DeclContextOverride decl_context_override;
255
256 if (const clang::TagType *tag_type = clang::QualType::getFromOpaquePtr(type)->getAs<TagType>())
257 {
258 decl_context_override.OverrideAllDeclsFromContainingFunction(tag_type->getDecl());
259 }
260
Sean Callanane55bc8a2013-03-30 02:31:21 +0000261 minion_sp->InitDeportWorkQueues(&decls_to_deport,
262 &decls_already_deported);
263
Sean Callananbb120042011-12-16 21:06:35 +0000264 lldb::clang_type_t result = CopyType(dst_ctx, src_ctx, type);
265
Sean Callanane55bc8a2013-03-30 02:31:21 +0000266 minion_sp->ExecuteDeportWorkQueues();
267
Sean Callananbb120042011-12-16 21:06:35 +0000268 if (!result)
Ed Masted4612ad2014-04-20 13:17:36 +0000269 return nullptr;
Sean Callananbb120042011-12-16 21:06:35 +0000270
Sean Callananbb120042011-12-16 21:06:35 +0000271 return result;
Sean Callanane55bc8a2013-03-30 02:31:21 +0000272
Sean Callananbb120042011-12-16 21:06:35 +0000273}
274
Sean Callanan0eed0d42011-12-06 03:41:14 +0000275clang::Decl *
276ClangASTImporter::DeportDecl (clang::ASTContext *dst_ctx,
277 clang::ASTContext *src_ctx,
278 clang::Decl *decl)
279{
Greg Clayton5160ce52013-03-27 23:08:40 +0000280 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000281
Sean Callanan933ca2e2013-02-28 03:12:58 +0000282 if (log)
283 log->Printf(" [ClangASTImporter] DeportDecl called on (%sDecl*)%p from (ASTContext*)%p to (ASTContex*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000284 decl->getDeclKindName(), static_cast<void*>(decl),
285 static_cast<void*>(src_ctx),
286 static_cast<void*>(dst_ctx));
287
Sean Callanane55bc8a2013-03-30 02:31:21 +0000288 MinionSP minion_sp (GetMinion (dst_ctx, src_ctx));
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000289
Sean Callanane55bc8a2013-03-30 02:31:21 +0000290 if (!minion_sp)
Ed Masted4612ad2014-04-20 13:17:36 +0000291 return nullptr;
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000292
Sean Callanane55bc8a2013-03-30 02:31:21 +0000293 std::set<NamedDecl *> decls_to_deport;
294 std::set<NamedDecl *> decls_already_deported;
Sean Callanan83b8ad02015-07-08 18:03:41 +0000295
296 DeclContextOverride decl_context_override;
297
298 decl_context_override.OverrideAllDeclsFromContainingFunction(decl);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000299
Sean Callanane55bc8a2013-03-30 02:31:21 +0000300 minion_sp->InitDeportWorkQueues(&decls_to_deport,
301 &decls_already_deported);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000302
Sean Callanan0eed0d42011-12-06 03:41:14 +0000303 clang::Decl *result = CopyDecl(dst_ctx, src_ctx, decl);
Sean Callanane55bc8a2013-03-30 02:31:21 +0000304
305 minion_sp->ExecuteDeportWorkQueues();
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000306
Sean Callanan0eed0d42011-12-06 03:41:14 +0000307 if (!result)
Ed Masted4612ad2014-04-20 13:17:36 +0000308 return nullptr;
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000309
Sean Callanan933ca2e2013-02-28 03:12:58 +0000310 if (log)
311 log->Printf(" [ClangASTImporter] DeportDecl deported (%sDecl*)%p to (%sDecl*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000312 decl->getDeclKindName(), static_cast<void*>(decl),
313 result->getDeclKindName(), static_cast<void*>(result));
314
Sean Callanan0eed0d42011-12-06 03:41:14 +0000315 return result;
316}
317
Sean Callanan5b26f272012-02-04 08:49:35 +0000318void
319ClangASTImporter::CompleteDecl (clang::Decl *decl)
320{
Greg Clayton5160ce52013-03-27 23:08:40 +0000321 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan5b26f272012-02-04 08:49:35 +0000322
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000323 if (log)
Sean Callanan5b26f272012-02-04 08:49:35 +0000324 log->Printf(" [ClangASTImporter] CompleteDecl called on (%sDecl*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000325 decl->getDeclKindName(), static_cast<void*>(decl));
326
Sean Callanan5b26f272012-02-04 08:49:35 +0000327 if (ObjCInterfaceDecl *interface_decl = dyn_cast<ObjCInterfaceDecl>(decl))
328 {
329 if (!interface_decl->getDefinition())
330 {
331 interface_decl->startDefinition();
332 CompleteObjCInterfaceDecl(interface_decl);
333 }
334 }
Greg Clayton23f59502012-07-17 03:23:13 +0000335 else if (ObjCProtocolDecl *protocol_decl = dyn_cast<ObjCProtocolDecl>(decl))
Sean Callanan5b26f272012-02-04 08:49:35 +0000336 {
337 if (!protocol_decl->getDefinition())
338 protocol_decl->startDefinition();
339 }
340 else if (TagDecl *tag_decl = dyn_cast<TagDecl>(decl))
341 {
342 if (!tag_decl->getDefinition() && !tag_decl->isBeingDefined())
343 {
344 tag_decl->startDefinition();
345 CompleteTagDecl(tag_decl);
346 tag_decl->setCompleteDefinition(true);
347 }
348 }
Greg Clayton219cf312012-03-30 00:51:13 +0000349 else
350 {
Sean Callanan5b26f272012-02-04 08:49:35 +0000351 assert (0 && "CompleteDecl called on a Decl that can't be completed");
352 }
353}
354
Sean Callanan12014a02011-12-08 23:45:45 +0000355bool
Sean Callanancc427fa2011-07-30 02:42:06 +0000356ClangASTImporter::CompleteTagDecl (clang::TagDecl *decl)
Sean Callanan8106d802013-03-08 20:04:57 +0000357{
358 ClangASTMetrics::RegisterDeclCompletion();
359
Sean Callanancc427fa2011-07-30 02:42:06 +0000360 DeclOrigin decl_origin = GetDeclOrigin(decl);
Greg Claytona2721472011-06-25 00:44:06 +0000361
Sean Callanancc427fa2011-07-30 02:42:06 +0000362 if (!decl_origin.Valid())
Sean Callanan12014a02011-12-08 23:45:45 +0000363 return false;
Greg Claytona2721472011-06-25 00:44:06 +0000364
Sean Callanancc427fa2011-07-30 02:42:06 +0000365 if (!ClangASTContext::GetCompleteDecl(decl_origin.ctx, decl_origin.decl))
Sean Callanan12014a02011-12-08 23:45:45 +0000366 return false;
Greg Claytona2721472011-06-25 00:44:06 +0000367
Sean Callanan686b2312011-11-16 18:20:47 +0000368 MinionSP minion_sp (GetMinion(&decl->getASTContext(), decl_origin.ctx));
Greg Claytona2721472011-06-25 00:44:06 +0000369
Greg Claytondd0649b2011-07-06 18:55:08 +0000370 if (minion_sp)
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000371 minion_sp->ImportDefinitionTo(decl, decl_origin.decl);
372
Sean Callanan12014a02011-12-08 23:45:45 +0000373 return true;
Greg Claytona2721472011-06-25 00:44:06 +0000374}
Sean Callanancc427fa2011-07-30 02:42:06 +0000375
Sean Callanan12014a02011-12-08 23:45:45 +0000376bool
377ClangASTImporter::CompleteTagDeclWithOrigin(clang::TagDecl *decl, clang::TagDecl *origin_decl)
378{
Sean Callanan8106d802013-03-08 20:04:57 +0000379 ClangASTMetrics::RegisterDeclCompletion();
380
Sean Callanan12014a02011-12-08 23:45:45 +0000381 clang::ASTContext *origin_ast_ctx = &origin_decl->getASTContext();
382
383 if (!ClangASTContext::GetCompleteDecl(origin_ast_ctx, origin_decl))
384 return false;
385
386 MinionSP minion_sp (GetMinion(&decl->getASTContext(), origin_ast_ctx));
387
388 if (minion_sp)
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000389 minion_sp->ImportDefinitionTo(decl, origin_decl);
390
Sean Callanan12014a02011-12-08 23:45:45 +0000391 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
392
393 OriginMap &origins = context_md->m_origins;
394
395 origins[decl] = DeclOrigin(origin_ast_ctx, origin_decl);
396
397 return true;
398}
399
400bool
Sean Callanancc427fa2011-07-30 02:42:06 +0000401ClangASTImporter::CompleteObjCInterfaceDecl (clang::ObjCInterfaceDecl *interface_decl)
402{
Sean Callanan8106d802013-03-08 20:04:57 +0000403 ClangASTMetrics::RegisterDeclCompletion();
Sean Callanancc427fa2011-07-30 02:42:06 +0000404
Sean Callanancc427fa2011-07-30 02:42:06 +0000405 DeclOrigin decl_origin = GetDeclOrigin(interface_decl);
406
407 if (!decl_origin.Valid())
Sean Callanan12014a02011-12-08 23:45:45 +0000408 return false;
Sean Callanancc427fa2011-07-30 02:42:06 +0000409
410 if (!ClangASTContext::GetCompleteDecl(decl_origin.ctx, decl_origin.decl))
Sean Callanan12014a02011-12-08 23:45:45 +0000411 return false;
Sean Callanancc427fa2011-07-30 02:42:06 +0000412
Sean Callanan686b2312011-11-16 18:20:47 +0000413 MinionSP minion_sp (GetMinion(&interface_decl->getASTContext(), decl_origin.ctx));
Sean Callanancc427fa2011-07-30 02:42:06 +0000414
415 if (minion_sp)
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000416 minion_sp->ImportDefinitionTo(interface_decl, decl_origin.decl);
Greg Clayton6292b30b2015-04-13 18:32:54 +0000417
418 if (ObjCInterfaceDecl *super_class = interface_decl->getSuperClass())
419 RequireCompleteType(clang::QualType(super_class->getTypeForDecl(), 0));
420
Sean Callanan12014a02011-12-08 23:45:45 +0000421 return true;
Sean Callanancc427fa2011-07-30 02:42:06 +0000422}
423
Sean Callanan6b200d02013-03-21 22:15:41 +0000424bool
425ClangASTImporter::RequireCompleteType (clang::QualType type)
426{
427 if (type.isNull())
428 return false;
429
430 if (const TagType *tag_type = type->getAs<TagType>())
431 {
Stephane Sezer9901e9c2015-04-08 21:52:45 +0000432 TagDecl *tag_decl = tag_type->getDecl();
433
434 if (tag_decl->getDefinition() || tag_decl->isBeingDefined())
435 return true;
436
437 return CompleteTagDecl(tag_decl);
Sean Callanan6b200d02013-03-21 22:15:41 +0000438 }
439 if (const ObjCObjectType *objc_object_type = type->getAs<ObjCObjectType>())
440 {
441 if (ObjCInterfaceDecl *objc_interface_decl = objc_object_type->getInterface())
442 return CompleteObjCInterfaceDecl(objc_interface_decl);
443 else
444 return false;
445 }
446 if (const ArrayType *array_type = type->getAsArrayTypeUnsafe())
447 {
448 return RequireCompleteType(array_type->getElementType());
449 }
450 if (const AtomicType *atomic_type = type->getAs<AtomicType>())
451 {
452 return RequireCompleteType(atomic_type->getPointeeType());
453 }
454
455 return true;
456}
457
Jim Ingham379397632012-10-27 02:54:13 +0000458ClangASTMetadata *
Sean Callanan60217122012-04-13 00:10:03 +0000459ClangASTImporter::GetDeclMetadata (const clang::Decl *decl)
460{
461 DeclOrigin decl_origin = GetDeclOrigin(decl);
462
463 if (decl_origin.Valid())
Greg Claytond0029442013-03-27 01:48:02 +0000464 return ClangASTContext::GetMetadata(decl_origin.ctx, decl_origin.decl);
Sean Callanan60217122012-04-13 00:10:03 +0000465 else
Greg Claytond0029442013-03-27 01:48:02 +0000466 return ClangASTContext::GetMetadata(&decl->getASTContext(), decl);
Sean Callanan60217122012-04-13 00:10:03 +0000467}
468
Sean Callananf487bd82011-11-16 21:40:57 +0000469ClangASTImporter::DeclOrigin
470ClangASTImporter::GetDeclOrigin(const clang::Decl *decl)
471{
472 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
473
474 OriginMap &origins = context_md->m_origins;
475
476 OriginMap::iterator iter = origins.find(decl);
477
478 if (iter != origins.end())
479 return iter->second;
480 else
481 return DeclOrigin();
482}
483
Sean Callanan2cb5e522012-09-20 23:21:16 +0000484void
485ClangASTImporter::SetDeclOrigin (const clang::Decl *decl, clang::Decl *original_decl)
486{
487 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
488
489 OriginMap &origins = context_md->m_origins;
490
491 OriginMap::iterator iter = origins.find(decl);
492
493 if (iter != origins.end())
494 {
495 iter->second.decl = original_decl;
496 iter->second.ctx = &original_decl->getASTContext();
497 }
498 else
499 {
500 origins[decl] = DeclOrigin(&original_decl->getASTContext(), original_decl);
501 }
502}
503
504void
Sean Callanan503aa522011-10-12 00:12:34 +0000505ClangASTImporter::RegisterNamespaceMap(const clang::NamespaceDecl *decl,
506 NamespaceMapSP &namespace_map)
507{
Sean Callananf487bd82011-11-16 21:40:57 +0000508 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
509
510 context_md->m_namespace_maps[decl] = namespace_map;
Sean Callanan503aa522011-10-12 00:12:34 +0000511}
512
513ClangASTImporter::NamespaceMapSP
514ClangASTImporter::GetNamespaceMap(const clang::NamespaceDecl *decl)
515{
Sean Callananf487bd82011-11-16 21:40:57 +0000516 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
517
518 NamespaceMetaMap &namespace_maps = context_md->m_namespace_maps;
Sean Callanan503aa522011-10-12 00:12:34 +0000519
Sean Callananf487bd82011-11-16 21:40:57 +0000520 NamespaceMetaMap::iterator iter = namespace_maps.find(decl);
521
522 if (iter != namespace_maps.end())
Sean Callanan503aa522011-10-12 00:12:34 +0000523 return iter->second;
524 else
525 return NamespaceMapSP();
526}
527
Sean Callananb2269162011-10-21 22:18:07 +0000528void
529ClangASTImporter::BuildNamespaceMap(const clang::NamespaceDecl *decl)
530{
Jim Ingham28eb5712012-10-12 17:34:26 +0000531 assert (decl);
Sean Callananf487bd82011-11-16 21:40:57 +0000532 ASTContextMetadataSP context_md = GetContextMetadata(&decl->getASTContext());
533
Sean Callananb2269162011-10-21 22:18:07 +0000534 const DeclContext *parent_context = decl->getDeclContext();
535 const NamespaceDecl *parent_namespace = dyn_cast<NamespaceDecl>(parent_context);
536 NamespaceMapSP parent_map;
537
538 if (parent_namespace)
539 parent_map = GetNamespaceMap(parent_namespace);
540
541 NamespaceMapSP new_map;
542
543 new_map.reset(new NamespaceMap);
544
Sean Callananf487bd82011-11-16 21:40:57 +0000545 if (context_md->m_map_completer)
Sean Callananb2269162011-10-21 22:18:07 +0000546 {
547 std::string namespace_string = decl->getDeclName().getAsString();
548
Sean Callananf487bd82011-11-16 21:40:57 +0000549 context_md->m_map_completer->CompleteNamespaceMap (new_map, ConstString(namespace_string.c_str()), parent_map);
Sean Callananb2269162011-10-21 22:18:07 +0000550 }
551
Sean Callanan0eed0d42011-12-06 03:41:14 +0000552 context_md->m_namespace_maps[decl] = new_map;
Sean Callananb2269162011-10-21 22:18:07 +0000553}
554
Sean Callanan686b2312011-11-16 18:20:47 +0000555void
Sean Callanan99732312011-11-29 00:42:02 +0000556ClangASTImporter::ForgetDestination (clang::ASTContext *dst_ast)
Sean Callanan686b2312011-11-16 18:20:47 +0000557{
Greg Clayton5160ce52013-03-27 23:08:40 +0000558 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000559
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000560 if (log)
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000561 log->Printf(" [ClangASTImporter] Forgetting destination (ASTContext*)%p",
562 static_cast<void*>(dst_ast));
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000563
Sean Callananf487bd82011-11-16 21:40:57 +0000564 m_metadata_map.erase(dst_ast);
Sean Callanan686b2312011-11-16 18:20:47 +0000565}
566
Sean Callanan99732312011-11-29 00:42:02 +0000567void
568ClangASTImporter::ForgetSource (clang::ASTContext *dst_ast, clang::ASTContext *src_ast)
569{
570 ASTContextMetadataSP md = MaybeGetContextMetadata (dst_ast);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000571
Greg Clayton5160ce52013-03-27 23:08:40 +0000572 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000573
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000574 if (log)
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000575 log->Printf(" [ClangASTImporter] Forgetting source->dest (ASTContext*)%p->(ASTContext*)%p",
576 static_cast<void*>(src_ast), static_cast<void*>(dst_ast));
577
Sean Callanan99732312011-11-29 00:42:02 +0000578 if (!md)
579 return;
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000580
Sean Callanan99732312011-11-29 00:42:02 +0000581 md->m_minions.erase(src_ast);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000582
Sean Callanan99732312011-11-29 00:42:02 +0000583 for (OriginMap::iterator iter = md->m_origins.begin();
584 iter != md->m_origins.end();
585 )
586 {
587 if (iter->second.ctx == src_ast)
588 md->m_origins.erase(iter++);
589 else
590 ++iter;
591 }
592}
593
Sean Callanan0eed0d42011-12-06 03:41:14 +0000594ClangASTImporter::MapCompleter::~MapCompleter ()
Sean Callananb2269162011-10-21 22:18:07 +0000595{
596 return;
597}
598
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000599void
Sean Callanane55bc8a2013-03-30 02:31:21 +0000600ClangASTImporter::Minion::InitDeportWorkQueues (std::set<clang::NamedDecl *> *decls_to_deport,
601 std::set<clang::NamedDecl *> *decls_already_deported)
602{
603 assert(!m_decls_to_deport); // TODO make debug only
604 assert(!m_decls_already_deported);
605
606 m_decls_to_deport = decls_to_deport;
607 m_decls_already_deported = decls_already_deported;
608}
609
610void
611ClangASTImporter::Minion::ExecuteDeportWorkQueues ()
612{
613 assert(m_decls_to_deport); // TODO make debug only
614 assert(m_decls_already_deported);
615
616 ASTContextMetadataSP to_context_md = m_master.GetContextMetadata(&getToContext());
617
618 while (!m_decls_to_deport->empty())
619 {
620 NamedDecl *decl = *m_decls_to_deport->begin();
621
622 m_decls_already_deported->insert(decl);
623 m_decls_to_deport->erase(decl);
624
625 DeclOrigin &origin = to_context_md->m_origins[decl];
Bruce Mitchenera026de02015-07-22 17:31:44 +0000626 (void)origin;
Sean Callanane55bc8a2013-03-30 02:31:21 +0000627
628 assert (origin.ctx == m_source_ctx); // otherwise we should never have added this
629 // because it doesn't need to be deported
630
631 Decl *original_decl = to_context_md->m_origins[decl].decl;
632
633 ClangASTContext::GetCompleteDecl (m_source_ctx, original_decl);
634
635 if (TagDecl *tag_decl = dyn_cast<TagDecl>(decl))
636 {
637 if (TagDecl *original_tag_decl = dyn_cast<TagDecl>(original_decl))
638 if (original_tag_decl->isCompleteDefinition())
639 ImportDefinitionTo(tag_decl, original_tag_decl);
640
641 tag_decl->setHasExternalLexicalStorage(false);
642 tag_decl->setHasExternalVisibleStorage(false);
643 }
644 else if (ObjCInterfaceDecl *interface_decl = dyn_cast<ObjCInterfaceDecl>(decl))
645 {
646 interface_decl->setHasExternalLexicalStorage(false);
647 interface_decl->setHasExternalVisibleStorage(false);
648 }
649
650 to_context_md->m_origins.erase(decl);
651 }
652
Ed Masted4612ad2014-04-20 13:17:36 +0000653 m_decls_to_deport = nullptr;
654 m_decls_already_deported = nullptr;
Sean Callanane55bc8a2013-03-30 02:31:21 +0000655}
656
657void
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000658ClangASTImporter::Minion::ImportDefinitionTo (clang::Decl *to, clang::Decl *from)
659{
660 ASTImporter::Imported(from, to);
Sean Callanan5b26f272012-02-04 08:49:35 +0000661
662 ObjCInterfaceDecl *to_objc_interface = dyn_cast<ObjCInterfaceDecl>(to);
663
664 /*
665 if (to_objc_interface)
666 to_objc_interface->startDefinition();
667
668 CXXRecordDecl *to_cxx_record = dyn_cast<CXXRecordDecl>(to);
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000669
Sean Callanan5b26f272012-02-04 08:49:35 +0000670 if (to_cxx_record)
671 to_cxx_record->startDefinition();
672 */
673
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000674 ImportDefinition(from);
Sean Callanan5b26f272012-02-04 08:49:35 +0000675
Sean Callanan2e93a2a2012-01-19 18:23:06 +0000676 // If we're dealing with an Objective-C class, ensure that the inheritance has
677 // been set up correctly. The ASTImporter may not do this correctly if the
678 // class was originally sourced from symbols.
679
Sean Callanan5b26f272012-02-04 08:49:35 +0000680 if (to_objc_interface)
Sean Callanan2e93a2a2012-01-19 18:23:06 +0000681 {
682 do
683 {
684 ObjCInterfaceDecl *to_superclass = to_objc_interface->getSuperClass();
685
686 if (to_superclass)
687 break; // we're not going to override it if it's set
688
689 ObjCInterfaceDecl *from_objc_interface = dyn_cast<ObjCInterfaceDecl>(from);
690
691 if (!from_objc_interface)
692 break;
693
694 ObjCInterfaceDecl *from_superclass = from_objc_interface->getSuperClass();
695
696 if (!from_superclass)
697 break;
698
699 Decl *imported_from_superclass_decl = Import(from_superclass);
700
701 if (!imported_from_superclass_decl)
702 break;
703
704 ObjCInterfaceDecl *imported_from_superclass = dyn_cast<ObjCInterfaceDecl>(imported_from_superclass_decl);
705
706 if (!imported_from_superclass)
707 break;
708
Sean Callanan5b26f272012-02-04 08:49:35 +0000709 if (!to_objc_interface->hasDefinition())
710 to_objc_interface->startDefinition();
711
Pavel Labath67add942015-07-07 10:11:16 +0000712 to_objc_interface->setSuperClass(
713 m_source_ctx->getTrivialTypeSourceInfo(m_source_ctx->getObjCInterfaceType(imported_from_superclass)));
Sean Callanan2e93a2a2012-01-19 18:23:06 +0000714 }
715 while (0);
716 }
Sean Callanancbbe3ac2012-01-13 22:55:55 +0000717}
718
Greg Clayton57ee3062013-07-11 22:46:58 +0000719clang::Decl *
720ClangASTImporter::Minion::Imported (clang::Decl *from, clang::Decl *to)
Sean Callanancc427fa2011-07-30 02:42:06 +0000721{
Sean Callanan8106d802013-03-08 20:04:57 +0000722 ClangASTMetrics::RegisterClangImport();
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000723
Greg Clayton5160ce52013-03-27 23:08:40 +0000724 Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000725
Sean Callanan608fb392014-08-01 22:42:38 +0000726 lldb::user_id_t user_id = LLDB_INVALID_UID;
727 ClangASTMetadata *metadata = m_master.GetDeclMetadata(from);
728 if (metadata)
729 user_id = metadata->GetUserID();
730
Sean Callanan00f43622011-11-18 03:28:09 +0000731 if (log)
732 {
733 if (NamedDecl *from_named_decl = dyn_cast<clang::NamedDecl>(from))
734 {
Sean Callanan48e894b2012-05-25 18:12:26 +0000735 std::string name_string;
736 llvm::raw_string_ostream name_stream(name_string);
737 from_named_decl->printName(name_stream);
738 name_stream.flush();
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000739
Daniel Malead01b2952012-11-29 21:49:15 +0000740 log->Printf(" [ClangASTImporter] Imported (%sDecl*)%p, named %s (from (Decl*)%p), metadata 0x%" PRIx64,
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000741 from->getDeclKindName(), static_cast<void*>(to),
742 name_string.c_str(), static_cast<void*>(from),
Jim Ingham379397632012-10-27 02:54:13 +0000743 user_id);
Sean Callanan00f43622011-11-18 03:28:09 +0000744 }
745 else
746 {
Daniel Malead01b2952012-11-29 21:49:15 +0000747 log->Printf(" [ClangASTImporter] Imported (%sDecl*)%p (from (Decl*)%p), metadata 0x%" PRIx64,
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000748 from->getDeclKindName(), static_cast<void*>(to),
749 static_cast<void*>(from), user_id);
Sean Callanan00f43622011-11-18 03:28:09 +0000750 }
751 }
752
Sean Callananb0b87a52011-11-16 22:23:28 +0000753 ASTContextMetadataSP to_context_md = m_master.GetContextMetadata(&to->getASTContext());
754 ASTContextMetadataSP from_context_md = m_master.MaybeGetContextMetadata(m_source_ctx);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000755
Sean Callananb0b87a52011-11-16 22:23:28 +0000756 if (from_context_md)
757 {
758 OriginMap &origins = from_context_md->m_origins;
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000759
Sean Callananb0b87a52011-11-16 22:23:28 +0000760 OriginMap::iterator origin_iter = origins.find(from);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000761
Sean Callananb0b87a52011-11-16 22:23:28 +0000762 if (origin_iter != origins.end())
Sean Callanan00f43622011-11-18 03:28:09 +0000763 {
Sean Callanan608fb392014-08-01 22:42:38 +0000764 if (to_context_md->m_origins.find(to) == to_context_md->m_origins.end() ||
765 user_id != LLDB_INVALID_UID)
766 {
Sean Callananabe140c2015-07-20 16:55:19 +0000767 if (origin_iter->second.ctx != &to->getASTContext())
768 to_context_md->m_origins[to] = origin_iter->second;
Sean Callanan608fb392014-08-01 22:42:38 +0000769 }
770
Sean Callanan5bc5a762011-12-20 23:55:47 +0000771 MinionSP direct_completer = m_master.GetMinion(&to->getASTContext(), origin_iter->second.ctx);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000772
Sean Callanan5bc5a762011-12-20 23:55:47 +0000773 if (direct_completer.get() != this)
774 direct_completer->ASTImporter::Imported(origin_iter->second.decl, to);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000775
Sean Callanan00f43622011-11-18 03:28:09 +0000776 if (log)
777 log->Printf(" [ClangASTImporter] Propagated origin (Decl*)%p/(ASTContext*)%p from (ASTContext*)%p to (ASTContext*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000778 static_cast<void*>(origin_iter->second.decl),
779 static_cast<void*>(origin_iter->second.ctx),
780 static_cast<void*>(&from->getASTContext()),
781 static_cast<void*>(&to->getASTContext()));
Sean Callanan00f43622011-11-18 03:28:09 +0000782 }
783 else
784 {
Sean Callanane55bc8a2013-03-30 02:31:21 +0000785 if (m_decls_to_deport && m_decls_already_deported)
786 {
787 if (isa<TagDecl>(to) || isa<ObjCInterfaceDecl>(to))
788 {
789 NamedDecl *to_named_decl = dyn_cast<NamedDecl>(to);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000790
Sean Callanane55bc8a2013-03-30 02:31:21 +0000791 if (!m_decls_already_deported->count(to_named_decl))
792 m_decls_to_deport->insert(to_named_decl);
793 }
Sean Callanane55bc8a2013-03-30 02:31:21 +0000794 }
Sean Callanan608fb392014-08-01 22:42:38 +0000795
796 if (to_context_md->m_origins.find(to) == to_context_md->m_origins.end() ||
797 user_id != LLDB_INVALID_UID)
798 {
799 to_context_md->m_origins[to] = DeclOrigin(m_source_ctx, from);
800 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000801
Sean Callanan00f43622011-11-18 03:28:09 +0000802 if (log)
803 log->Printf(" [ClangASTImporter] Decl has no origin information in (ASTContext*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000804 static_cast<void*>(&from->getASTContext()));
Sean Callanan00f43622011-11-18 03:28:09 +0000805 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000806
Sean Callananb0b87a52011-11-16 22:23:28 +0000807 if (clang::NamespaceDecl *to_namespace = dyn_cast<clang::NamespaceDecl>(to))
808 {
809 clang::NamespaceDecl *from_namespace = dyn_cast<clang::NamespaceDecl>(from);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000810
Sean Callananb0b87a52011-11-16 22:23:28 +0000811 NamespaceMetaMap &namespace_maps = from_context_md->m_namespace_maps;
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000812
Sean Callananb0b87a52011-11-16 22:23:28 +0000813 NamespaceMetaMap::iterator namespace_map_iter = namespace_maps.find(from_namespace);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000814
Sean Callananb0b87a52011-11-16 22:23:28 +0000815 if (namespace_map_iter != namespace_maps.end())
816 to_context_md->m_namespace_maps[to_namespace] = namespace_map_iter->second;
817 }
818 }
819 else
820 {
821 to_context_md->m_origins[to] = DeclOrigin (m_source_ctx, from);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000822
Sean Callanan00f43622011-11-18 03:28:09 +0000823 if (log)
824 log->Printf(" [ClangASTImporter] Sourced origin (Decl*)%p/(ASTContext*)%p into (ASTContext*)%p",
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000825 static_cast<void*>(from),
826 static_cast<void*>(m_source_ctx),
827 static_cast<void*>(&to->getASTContext()));
Sean Callananb0b87a52011-11-16 22:23:28 +0000828 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000829
Sean Callanancc427fa2011-07-30 02:42:06 +0000830 if (TagDecl *from_tag_decl = dyn_cast<TagDecl>(from))
831 {
832 TagDecl *to_tag_decl = dyn_cast<TagDecl>(to);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000833
Sean Callanancc427fa2011-07-30 02:42:06 +0000834 to_tag_decl->setHasExternalLexicalStorage();
Sean Callanan3d654b32012-09-24 22:25:51 +0000835 to_tag_decl->setMustBuildLookupTable();
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000836
Sean Callanancc427fa2011-07-30 02:42:06 +0000837 if (log)
Sean Callanan00f43622011-11-18 03:28:09 +0000838 log->Printf(" [ClangASTImporter] To is a TagDecl - attributes %s%s [%s->%s]",
Sean Callanancc427fa2011-07-30 02:42:06 +0000839 (to_tag_decl->hasExternalLexicalStorage() ? " Lexical" : ""),
Sean Callanan0730e9c2011-11-09 19:33:21 +0000840 (to_tag_decl->hasExternalVisibleStorage() ? " Visible" : ""),
841 (from_tag_decl->isCompleteDefinition() ? "complete" : "incomplete"),
842 (to_tag_decl->isCompleteDefinition() ? "complete" : "incomplete"));
Sean Callanancc427fa2011-07-30 02:42:06 +0000843 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000844
Sean Callananb2269162011-10-21 22:18:07 +0000845 if (isa<NamespaceDecl>(from))
846 {
847 NamespaceDecl *to_namespace_decl = dyn_cast<NamespaceDecl>(to);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000848
Sean Callananb2269162011-10-21 22:18:07 +0000849 m_master.BuildNamespaceMap(to_namespace_decl);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000850
Sean Callananb2269162011-10-21 22:18:07 +0000851 to_namespace_decl->setHasExternalVisibleStorage();
852 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000853
Sean Callanan00f43622011-11-18 03:28:09 +0000854 if (isa<ObjCInterfaceDecl>(from))
Sean Callanancc427fa2011-07-30 02:42:06 +0000855 {
856 ObjCInterfaceDecl *to_interface_decl = dyn_cast<ObjCInterfaceDecl>(to);
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000857
Sean Callanand5c17ed2011-11-15 02:11:17 +0000858 to_interface_decl->setHasExternalLexicalStorage();
Sean Callanan0730e9c2011-11-09 19:33:21 +0000859 to_interface_decl->setHasExternalVisibleStorage();
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000860
Sean Callanan5b26f272012-02-04 08:49:35 +0000861 /*to_interface_decl->setExternallyCompleted();*/
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000862
Sean Callanand5c17ed2011-11-15 02:11:17 +0000863 if (log)
Sean Callanan00f43622011-11-18 03:28:09 +0000864 log->Printf(" [ClangASTImporter] To is an ObjCInterfaceDecl - attributes %s%s%s",
Sean Callanand5c17ed2011-11-15 02:11:17 +0000865 (to_interface_decl->hasExternalLexicalStorage() ? " Lexical" : ""),
866 (to_interface_decl->hasExternalVisibleStorage() ? " Visible" : ""),
Sean Callanan5b26f272012-02-04 08:49:35 +0000867 (to_interface_decl->hasDefinition() ? " HasDefinition" : ""));
Sean Callanancc427fa2011-07-30 02:42:06 +0000868 }
Saleem Abdulrasool324a1032014-04-04 04:06:10 +0000869
Sean Callanancc427fa2011-07-30 02:42:06 +0000870 return clang::ASTImporter::Imported(from, to);
Greg Clayton3418c852011-08-10 02:10:13 +0000871}
Sean Callanan931a0de2013-10-09 22:33:34 +0000872
873clang::Decl *ClangASTImporter::Minion::GetOriginalDecl (clang::Decl *To)
874{
875 ASTContextMetadataSP to_context_md = m_master.GetContextMetadata(&To->getASTContext());
876
877 if (!to_context_md)
Ed Masted4612ad2014-04-20 13:17:36 +0000878 return nullptr;
Sean Callanan931a0de2013-10-09 22:33:34 +0000879
880 OriginMap::iterator iter = to_context_md->m_origins.find(To);
881
882 if (iter == to_context_md->m_origins.end())
Ed Masted4612ad2014-04-20 13:17:36 +0000883 return nullptr;
Sean Callanan931a0de2013-10-09 22:33:34 +0000884
885 return const_cast<clang::Decl*>(iter->second.decl);
886}