blob: 9831070c9be8c510fdcecd68d3c92b06837bdb40 [file] [log] [blame]
Greg Clayton1e591ce2010-07-16 18:28:27 +00001//===-- ClangASTSource.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
Chris Lattner24943d22010-06-08 16:52:24 +000010
Chris Lattner24943d22010-06-08 16:52:24 +000011#include "clang/AST/ASTContext.h"
Greg Claytonf4c7ae02010-10-15 03:36:13 +000012#include "lldb/Core/Log.h"
Greg Clayton6e0101c2011-09-17 06:21:20 +000013#include "lldb/Core/Module.h"
Sean Callanan73b520f2011-10-29 01:58:46 +000014#include "lldb/Core/ModuleList.h"
Sean Callananbb715f92011-10-29 02:28:18 +000015#include "lldb/Expression/ASTDumper.h"
Chris Lattner24943d22010-06-08 16:52:24 +000016#include "lldb/Expression/ClangASTSource.h"
17#include "lldb/Expression/ClangExpression.h"
Sean Callanan73b520f2011-10-29 01:58:46 +000018#include "lldb/Symbol/ClangNamespaceDecl.h"
19#include "lldb/Symbol/SymbolVendor.h"
Sean Callanan673f3db2011-11-30 22:11:59 +000020#include "lldb/Target/ObjCLanguageRuntime.h"
Sean Callanan73b520f2011-10-29 01:58:46 +000021#include "lldb/Target/Target.h"
Chris Lattner24943d22010-06-08 16:52:24 +000022
23using namespace clang;
24using namespace lldb_private;
25
Greg Claytonb01000f2011-01-17 03:46:26 +000026ClangASTSource::~ClangASTSource()
27{
Sean Callanana3d04472011-11-29 00:42:02 +000028 m_ast_importer->ForgetDestination(m_ast_context);
29
Johnny Chenfa21ffd2011-11-30 23:18:53 +000030 // We are in the process of destruction, don't create clang ast context on demand
31 // by passing false to Target::GetScratchClangASTContext(create_on_demand).
32 ClangASTContext *scratch_clang_ast_context = m_target->GetScratchClangASTContext(false);
Sean Callanana3d04472011-11-29 00:42:02 +000033
34 if (!scratch_clang_ast_context)
35 return;
36
37 clang::ASTContext *scratch_ast_context = scratch_clang_ast_context->getASTContext();
38
39 if (!scratch_ast_context)
40 return;
41
42 if (m_ast_context != scratch_ast_context)
43 m_ast_importer->ForgetSource(scratch_ast_context, m_ast_context);
Greg Claytonb01000f2011-01-17 03:46:26 +000044}
Chris Lattner24943d22010-06-08 16:52:24 +000045
Greg Claytonb01000f2011-01-17 03:46:26 +000046void
47ClangASTSource::StartTranslationUnit(ASTConsumer *Consumer)
48{
Sean Callananf76afff2011-10-28 23:38:38 +000049 if (!m_ast_context)
50 return;
51
52 m_ast_context->getTranslationUnitDecl()->setHasExternalVisibleStorage();
53 m_ast_context->getTranslationUnitDecl()->setHasExternalLexicalStorage();
Chris Lattner24943d22010-06-08 16:52:24 +000054}
55
Chris Lattner24943d22010-06-08 16:52:24 +000056// The core lookup interface.
Greg Claytonb01000f2011-01-17 03:46:26 +000057DeclContext::lookup_result
58ClangASTSource::FindExternalVisibleDeclsByName
Greg Claytonf4c7ae02010-10-15 03:36:13 +000059(
60 const DeclContext *decl_ctx,
Greg Clayton8de27c72010-10-15 22:48:33 +000061 DeclarationName clang_decl_name
Greg Claytonf4c7ae02010-10-15 03:36:13 +000062)
63{
Sean Callananf76afff2011-10-28 23:38:38 +000064 if (!m_ast_context)
65 return SetNoExternalVisibleDeclsForName(decl_ctx, clang_decl_name);
66
67 if (GetImportInProgress())
Greg Claytonb01000f2011-01-17 03:46:26 +000068 return SetNoExternalVisibleDeclsForName(decl_ctx, clang_decl_name);
69
70 std::string decl_name (clang_decl_name.getAsString());
71
72// if (m_decl_map.DoingASTImport ())
73// return DeclContext::lookup_result();
74//
Greg Clayton8de27c72010-10-15 22:48:33 +000075 switch (clang_decl_name.getNameKind()) {
Chris Lattner24943d22010-06-08 16:52:24 +000076 // Normal identifiers.
77 case DeclarationName::Identifier:
Greg Clayton8de27c72010-10-15 22:48:33 +000078 if (clang_decl_name.getAsIdentifierInfo()->getBuiltinID() != 0)
79 return SetNoExternalVisibleDeclsForName(decl_ctx, clang_decl_name);
80 break;
Chris Lattner24943d22010-06-08 16:52:24 +000081
82 // Operator names. Not important for now.
83 case DeclarationName::CXXOperatorName:
84 case DeclarationName::CXXLiteralOperatorName:
85 return DeclContext::lookup_result();
86
87 // Using directives found in this context.
88 // Tell Sema we didn't find any or we'll end up getting asked a *lot*.
89 case DeclarationName::CXXUsingDirective:
Greg Clayton8de27c72010-10-15 22:48:33 +000090 return SetNoExternalVisibleDeclsForName(decl_ctx, clang_decl_name);
Chris Lattner24943d22010-06-08 16:52:24 +000091
Chris Lattner24943d22010-06-08 16:52:24 +000092 case DeclarationName::ObjCZeroArgSelector:
93 case DeclarationName::ObjCOneArgSelector:
94 case DeclarationName::ObjCMultiArgSelector:
Sean Callanan9b714842011-11-09 19:33:21 +000095 {
96 llvm::SmallVector<NamedDecl*, 1> method_decls;
Chris Lattner24943d22010-06-08 16:52:24 +000097
Sean Callanan9b714842011-11-09 19:33:21 +000098 NameSearchContext method_search_context (*this, method_decls, clang_decl_name, decl_ctx);
99
100 FindObjCMethodDecls(method_search_context);
101
102 return SetExternalVisibleDeclsForName (decl_ctx, clang_decl_name, method_decls);
103 }
Chris Lattner24943d22010-06-08 16:52:24 +0000104 // These aren't possible in the global context.
105 case DeclarationName::CXXConstructorName:
106 case DeclarationName::CXXDestructorName:
107 case DeclarationName::CXXConversionFunctionName:
108 return DeclContext::lookup_result();
109 }
Greg Claytonf4c7ae02010-10-15 03:36:13 +0000110
Greg Claytonf4c7ae02010-10-15 03:36:13 +0000111
Sean Callananf76afff2011-10-28 23:38:38 +0000112 if (!GetLookupsEnabled())
Greg Clayton8de27c72010-10-15 22:48:33 +0000113 {
114 // Wait until we see a '$' at the start of a name before we start doing
115 // any lookups so we can avoid lookup up all of the builtin types.
116 if (!decl_name.empty() && decl_name[0] == '$')
117 {
Sean Callananf76afff2011-10-28 23:38:38 +0000118 SetLookupsEnabled (true);
Greg Clayton8de27c72010-10-15 22:48:33 +0000119 }
120 else
121 {
122 return SetNoExternalVisibleDeclsForName(decl_ctx, clang_decl_name);
123 }
Greg Claytonf4c7ae02010-10-15 03:36:13 +0000124 }
Greg Clayton8de27c72010-10-15 22:48:33 +0000125
Greg Clayton8de27c72010-10-15 22:48:33 +0000126 ConstString const_decl_name(decl_name.c_str());
Greg Clayton9ceed1e2010-11-13 04:18:24 +0000127
128 const char *uniqued_const_decl_name = const_decl_name.GetCString();
129 if (m_active_lookups.find (uniqued_const_decl_name) != m_active_lookups.end())
130 {
131 // We are currently looking up this name...
132 return DeclContext::lookup_result();
133 }
134 m_active_lookups.insert(uniqued_const_decl_name);
Greg Claytona8b278a2010-11-15 01:34:18 +0000135// static uint32_t g_depth = 0;
136// ++g_depth;
137// printf("[%5u] FindExternalVisibleDeclsByName() \"%s\"\n", g_depth, uniqued_const_decl_name);
Greg Clayton9ceed1e2010-11-13 04:18:24 +0000138 llvm::SmallVector<NamedDecl*, 4> name_decls;
139 NameSearchContext name_search_context(*this, name_decls, clang_decl_name, decl_ctx);
Sean Callananf76afff2011-10-28 23:38:38 +0000140 FindExternalVisibleDecls(name_search_context);
Greg Clayton9ceed1e2010-11-13 04:18:24 +0000141 DeclContext::lookup_result result (SetExternalVisibleDeclsForName (decl_ctx, clang_decl_name, name_decls));
Greg Claytona8b278a2010-11-15 01:34:18 +0000142// --g_depth;
Greg Clayton9ceed1e2010-11-13 04:18:24 +0000143 m_active_lookups.erase (uniqued_const_decl_name);
144 return result;
Chris Lattner24943d22010-06-08 16:52:24 +0000145}
146
Greg Claytonb01000f2011-01-17 03:46:26 +0000147void
148ClangASTSource::CompleteType (TagDecl *tag_decl)
Sean Callananbb715f92011-10-29 02:28:18 +0000149{
150 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
151
Sean Callananb2027ec2011-12-08 23:45:45 +0000152 static unsigned int invocation_id = 0;
153 unsigned int current_id = invocation_id++;
154
Sean Callananbb715f92011-10-29 02:28:18 +0000155 if (log)
156 {
Sean Callananb2027ec2011-12-08 23:45:45 +0000157 log->Printf(" CompleteTagDecl[%u] on (ASTContext*)%p Completing a TagDecl named %s",
158 invocation_id,
159 m_ast_context,
160 tag_decl->getName().str().c_str());
161
162 log->Printf(" CTD[%u] Before:", current_id);
Sean Callananbb715f92011-10-29 02:28:18 +0000163 ASTDumper dumper((Decl*)tag_decl);
164 dumper.ToLog(log, " [CTD] ");
165 }
166
Sean Callananb2027ec2011-12-08 23:45:45 +0000167 if (!m_ast_importer->CompleteTagDecl (tag_decl))
168 {
169 // We couldn't complete the type. Maybe there's a definition
170 // somewhere else that can be completed.
171
172 if (log)
173 log->Printf(" CTD[%u] Type could not be completed in the module in which it was first found.", current_id);
174
175 bool found = false;
176
177 DeclContext *decl_ctx = tag_decl->getDeclContext();
178
179 if (const NamespaceDecl *namespace_context = dyn_cast<NamespaceDecl>(decl_ctx))
180 {
181 ClangASTImporter::NamespaceMapSP namespace_map = m_ast_importer->GetNamespaceMap(namespace_context);
182
183 if (log && log->GetVerbose())
184 log->Printf(" CTD[%u] Inspecting namespace map %p (%d entries)",
185 current_id,
186 namespace_map.get(),
187 (int)namespace_map->size());
188
189 if (!namespace_map)
190 return;
191
192 for (ClangASTImporter::NamespaceMap::iterator i = namespace_map->begin(), e = namespace_map->end();
193 i != e && !found;
194 ++i)
195 {
196 if (log)
197 log->Printf(" CTD[%u] Searching namespace %s in module %s",
198 current_id,
199 i->second.GetNamespaceDecl()->getNameAsString().c_str(),
200 i->first->GetFileSpec().GetFilename().GetCString());
201
202 TypeList types;
203
204 SymbolContext null_sc;
205 ConstString name(tag_decl->getName().str().c_str());
206
207 i->first->FindTypes(null_sc, name, &i->second, true, UINT32_MAX, types);
208
209 for (uint32_t ti = 0, te = types.GetSize();
210 ti != te && !found;
211 ++ti)
212 {
213 lldb::TypeSP type = types.GetTypeAtIndex(ti);
214
215 if (!type)
216 continue;
217
218 lldb::clang_type_t opaque_type = type->GetClangFullType();
219
220 if (!opaque_type)
221 continue;
222
223 const TagType *tag_type = dyn_cast<TagType>(QualType::getFromOpaquePtr(opaque_type).getTypePtr());
224
225 if (!tag_type)
226 continue;
227
228 TagDecl *candidate_tag_decl = const_cast<TagDecl*>(tag_type->getDecl());
229
230 if (m_ast_importer->CompleteTagDeclWithOrigin (tag_decl, candidate_tag_decl))
231 found = true;
232 }
233 }
234 }
235 else
236 {
237 TypeList types;
238
239 SymbolContext null_sc;
240 ConstString name(tag_decl->getName().str().c_str());
241 ClangNamespaceDecl namespace_decl;
242
243 ModuleList &module_list = m_target->GetImages();
244
245 module_list.FindTypes(null_sc, name, true, UINT32_MAX, types);
246
247 for (uint32_t ti = 0, te = types.GetSize();
248 ti != te && !found;
249 ++ti)
250 {
251 lldb::TypeSP type = types.GetTypeAtIndex(ti);
252
253 if (!type)
254 continue;
255
256 lldb::clang_type_t opaque_type = type->GetClangFullType();
257
258 if (!opaque_type)
259 continue;
260
261 const TagType *tag_type = dyn_cast<TagType>(QualType::getFromOpaquePtr(opaque_type).getTypePtr());
262
263 if (!tag_type)
264 continue;
265
266 TagDecl *candidate_tag_decl = const_cast<TagDecl*>(tag_type->getDecl());
267
268 if (m_ast_importer->CompleteTagDeclWithOrigin (tag_decl, candidate_tag_decl))
269 found = true;
270 }
271 }
272 }
Sean Callananbb715f92011-10-29 02:28:18 +0000273
274 if (log)
275 {
276 log->Printf(" [CTD] After:");
277 ASTDumper dumper((Decl*)tag_decl);
278 dumper.ToLog(log, " [CTD] ");
279 }
Greg Claytonb01000f2011-01-17 03:46:26 +0000280}
281
282void
Sean Callananbb715f92011-10-29 02:28:18 +0000283ClangASTSource::CompleteType (clang::ObjCInterfaceDecl *interface_decl)
284{
285 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
286
287 if (log)
288 {
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000289 log->Printf(" [CompleteObjCInterfaceDecl] on (ASTContext*)%p Completing an ObjCInterfaceDecl named %s", m_ast_context, interface_decl->getName().str().c_str());
Sean Callananbb715f92011-10-29 02:28:18 +0000290 log->Printf(" [COID] Before:");
291 ASTDumper dumper((Decl*)interface_decl);
292 dumper.ToLog(log, " [COID] ");
293 }
294
295 m_ast_importer->CompleteObjCInterfaceDecl (interface_decl);
296
297 if (log)
298 {
299 log->Printf(" [COID] After:");
300 ASTDumper dumper((Decl*)interface_decl);
301 dumper.ToLog(log, " [COID] ");
302 }
Greg Claytonb01000f2011-01-17 03:46:26 +0000303}
304
Sean Callanan9b6898f2011-07-30 02:42:06 +0000305clang::ExternalLoadResult
Sean Callananbb715f92011-10-29 02:28:18 +0000306ClangASTSource::FindExternalLexicalDecls (const DeclContext *decl_context,
307 bool (*predicate)(Decl::Kind),
308 llvm::SmallVectorImpl<Decl*> &decls)
309{
310 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
311
312 const Decl *context_decl = dyn_cast<Decl>(decl_context);
313
314 if (!context_decl)
315 return ELR_Failure;
316
317 static unsigned int invocation_id = 0;
318 unsigned int current_id = invocation_id++;
319
320 if (log)
321 {
322 if (const NamedDecl *context_named_decl = dyn_cast<NamedDecl>(context_decl))
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000323 log->Printf("FindExternalLexicalDecls[%u] on (ASTContext*)%p in '%s' (%sDecl*)%p with %s predicate",
Sean Callananbb715f92011-10-29 02:28:18 +0000324 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000325 m_ast_context,
Sean Callananbb715f92011-10-29 02:28:18 +0000326 context_named_decl->getNameAsString().c_str(),
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000327 context_decl->getDeclKindName(),
328 context_decl,
Sean Callananbb715f92011-10-29 02:28:18 +0000329 (predicate ? "non-null" : "null"));
330 else if(context_decl)
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000331 log->Printf("FindExternalLexicalDecls[%u] on (ASTContext*)%p in (%sDecl*)%p with %s predicate",
Sean Callananbb715f92011-10-29 02:28:18 +0000332 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000333 m_ast_context,
Sean Callananbb715f92011-10-29 02:28:18 +0000334 context_decl->getDeclKindName(),
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000335 context_decl,
Sean Callananbb715f92011-10-29 02:28:18 +0000336 (predicate ? "non-null" : "null"));
337 else
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000338 log->Printf("FindExternalLexicalDecls[%u] on (ASTContext*)%p in a NULL context with %s predicate",
Sean Callananbb715f92011-10-29 02:28:18 +0000339 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000340 m_ast_context,
Sean Callananbb715f92011-10-29 02:28:18 +0000341 (predicate ? "non-null" : "null"));
342 }
343
344 Decl *original_decl = NULL;
345 ASTContext *original_ctx = NULL;
346
347 if (!m_ast_importer->ResolveDeclOrigin(context_decl, &original_decl, &original_ctx))
348 return ELR_Failure;
349
350 if (log)
351 {
352 log->Printf(" FELD[%u] Original decl:", current_id);
353 ASTDumper(original_decl).ToLog(log, " ");
354 }
355
356 if (TagDecl *original_tag_decl = dyn_cast<TagDecl>(original_decl))
357 {
358 ExternalASTSource *external_source = original_ctx->getExternalSource();
359
360 if (external_source)
361 external_source->CompleteType (original_tag_decl);
362 }
363
Sean Callananb2027ec2011-12-08 23:45:45 +0000364 const DeclContext *original_decl_context = dyn_cast<DeclContext>(original_decl);
Sean Callananbb715f92011-10-29 02:28:18 +0000365
366 if (!original_decl_context)
367 return ELR_Failure;
368
369 for (TagDecl::decl_iterator iter = original_decl_context->decls_begin();
370 iter != original_decl_context->decls_end();
371 ++iter)
372 {
373 Decl *decl = *iter;
374
375 if (!predicate || predicate(decl->getKind()))
376 {
377 if (log)
378 {
379 ASTDumper ast_dumper(decl);
380 if (const NamedDecl *context_named_decl = dyn_cast<NamedDecl>(context_decl))
381 log->Printf(" FELD[%d] Adding [to %s] lexical decl %s", current_id, context_named_decl->getNameAsString().c_str(), ast_dumper.GetCString());
382 else
383 log->Printf(" FELD[%d] Adding lexical decl %s", current_id, ast_dumper.GetCString());
384 }
385
Sean Callanan4938bd62011-11-16 18:20:47 +0000386 Decl *copied_decl = m_ast_importer->CopyDecl(m_ast_context, original_ctx, decl);
Sean Callananbb715f92011-10-29 02:28:18 +0000387
388 decls.push_back(copied_decl);
389 }
390 }
391
392 return ELR_AlreadyLoaded;
Chris Lattner24943d22010-06-08 16:52:24 +0000393}
394
Sean Callanan9394b5a2011-10-29 19:50:43 +0000395void
396ClangASTSource::FindExternalVisibleDecls (NameSearchContext &context)
397{
398 assert (m_ast_context);
399
400 const ConstString name(context.m_decl_name.getAsString().c_str());
401
402 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
403
404 static unsigned int invocation_id = 0;
405 unsigned int current_id = invocation_id++;
406
407 if (log)
408 {
409 if (!context.m_decl_context)
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000410 log->Printf("ClangASTSource::FindExternalVisibleDecls[%u] on (ASTContext*)%p for '%s' in a NULL DeclContext", current_id, m_ast_context, name.GetCString());
Sean Callanan9394b5a2011-10-29 19:50:43 +0000411 else if (const NamedDecl *context_named_decl = dyn_cast<NamedDecl>(context.m_decl_context))
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000412 log->Printf("ClangASTSource::FindExternalVisibleDecls[%u] on (ASTContext*)%p for '%s' in '%s'", current_id, m_ast_context, name.GetCString(), context_named_decl->getNameAsString().c_str());
Sean Callanan9394b5a2011-10-29 19:50:43 +0000413 else
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000414 log->Printf("ClangASTSource::FindExternalVisibleDecls[%u] on (ASTContext*)%p for '%s' in a '%s'", current_id, m_ast_context, name.GetCString(), context.m_decl_context->getDeclKindName());
Sean Callanan9394b5a2011-10-29 19:50:43 +0000415 }
416
417 context.m_namespace_map.reset(new ClangASTImporter::NamespaceMap);
418
419 if (const NamespaceDecl *namespace_context = dyn_cast<NamespaceDecl>(context.m_decl_context))
420 {
421 ClangASTImporter::NamespaceMapSP namespace_map = m_ast_importer->GetNamespaceMap(namespace_context);
422
423 if (log && log->GetVerbose())
424 log->Printf(" CAS::FEVD[%u] Inspecting namespace map %p (%d entries)",
425 current_id,
426 namespace_map.get(),
427 (int)namespace_map->size());
428
429 if (!namespace_map)
430 return;
431
432 for (ClangASTImporter::NamespaceMap::iterator i = namespace_map->begin(), e = namespace_map->end();
433 i != e;
434 ++i)
435 {
436 if (log)
437 log->Printf(" CAS::FEVD[%u] Searching namespace %s in module %s",
438 current_id,
439 i->second.GetNamespaceDecl()->getNameAsString().c_str(),
440 i->first->GetFileSpec().GetFilename().GetCString());
441
442 FindExternalVisibleDecls(context,
443 i->first,
444 i->second,
445 current_id);
446 }
447 }
Sean Callanand3812fa2011-11-15 21:50:18 +0000448 else if (isa<ObjCInterfaceDecl>(context.m_decl_context))
Sean Callanane6ea5fe2011-11-15 02:11:17 +0000449 {
450 FindObjCPropertyDecls(context);
451 }
Sean Callanan9394b5a2011-10-29 19:50:43 +0000452 else if (!isa<TranslationUnitDecl>(context.m_decl_context))
453 {
454 // we shouldn't be getting FindExternalVisibleDecls calls for these
455 return;
456 }
457 else
458 {
459 ClangNamespaceDecl namespace_decl;
460
461 if (log)
462 log->Printf(" CAS::FEVD[%u] Searching the root namespace", current_id);
463
464 FindExternalVisibleDecls(context,
465 lldb::ModuleSP(),
466 namespace_decl,
467 current_id);
468 }
469
470 if (!context.m_namespace_map->empty())
471 {
472 if (log && log->GetVerbose())
473 log->Printf(" CAS::FEVD[%u] Registering namespace map %p (%d entries)",
474 current_id,
475 context.m_namespace_map.get(),
476 (int)context.m_namespace_map->size());
477
478 NamespaceDecl *clang_namespace_decl = AddNamespace(context, context.m_namespace_map);
479
480 if (clang_namespace_decl)
481 clang_namespace_decl->setHasExternalVisibleStorage();
482 }
483}
484
485void
486ClangASTSource::FindExternalVisibleDecls (NameSearchContext &context,
487 lldb::ModuleSP module_sp,
488 ClangNamespaceDecl &namespace_decl,
489 unsigned int current_id)
490{
491 assert (m_ast_context);
492
493 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
494
495 SymbolContextList sc_list;
496
497 const ConstString name(context.m_decl_name.getAsString().c_str());
498
499 const char *name_unique_cstr = name.GetCString();
500
501 if (name_unique_cstr == NULL)
502 return;
503
504 // The ClangASTSource is not responsible for finding $-names.
505 if (name_unique_cstr[0] == '$')
506 return;
507
508 if (module_sp && namespace_decl)
509 {
510 ClangNamespaceDecl found_namespace_decl;
511
512 SymbolVendor *symbol_vendor = module_sp->GetSymbolVendor();
513
514 if (symbol_vendor)
515 {
516 SymbolContext null_sc;
517
518 found_namespace_decl = symbol_vendor->FindNamespace(null_sc, name, &namespace_decl);
519
520 if (found_namespace_decl)
521 {
522 context.m_namespace_map->push_back(std::pair<lldb::ModuleSP, ClangNamespaceDecl>(module_sp, found_namespace_decl));
523
524 if (log)
525 log->Printf(" CAS::FEVD[%u] Found namespace %s in module %s",
526 current_id,
527 name.GetCString(),
528 module_sp->GetFileSpec().GetFilename().GetCString());
529 }
530 }
531 }
532 else
533 {
534 ModuleList &images = m_target->GetImages();
535
536 for (uint32_t i = 0, e = images.GetSize();
537 i != e;
538 ++i)
539 {
540 lldb::ModuleSP image = images.GetModuleAtIndex(i);
541
542 if (!image)
543 continue;
544
545 ClangNamespaceDecl found_namespace_decl;
546
547 SymbolVendor *symbol_vendor = image->GetSymbolVendor();
548
549 if (!symbol_vendor)
550 continue;
551
552 SymbolContext null_sc;
553
554 found_namespace_decl = symbol_vendor->FindNamespace(null_sc, name, &namespace_decl);
555
556 if (found_namespace_decl)
557 {
558 context.m_namespace_map->push_back(std::pair<lldb::ModuleSP, ClangNamespaceDecl>(image, found_namespace_decl));
559
560 if (log)
561 log->Printf(" CAS::FEVD[%u] Found namespace %s in module %s",
562 current_id,
563 name.GetCString(),
564 image->GetFileSpec().GetFilename().GetCString());
565 }
566 }
567 }
568
569 static ConstString id_name("id");
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000570 static ConstString Class_name("Class");
Sean Callanan9394b5a2011-10-29 19:50:43 +0000571
572 do
573 {
574 TypeList types;
575 SymbolContext null_sc;
576
577 if (module_sp && namespace_decl)
578 module_sp->FindTypes(null_sc, name, &namespace_decl, true, 1, types);
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000579 else if(name != id_name && name != Class_name)
Sean Callanane1301a62011-12-06 03:41:14 +0000580 m_target->GetImages().FindTypes(null_sc, name, true, 1, types);
Sean Callanan9394b5a2011-10-29 19:50:43 +0000581 else
582 break;
583
584 if (types.GetSize())
585 {
586 lldb::TypeSP type_sp = types.GetTypeAtIndex(0);
587
588 if (log)
589 {
590 const char *name_string = type_sp->GetName().GetCString();
591
592 log->Printf(" CAS::FEVD[%u] Matching type found for \"%s\": %s",
593 current_id,
594 name.GetCString(),
595 (name_string ? name_string : "<anonymous>"));
596 }
597
Sean Callanane1301a62011-12-06 03:41:14 +0000598
Sean Callanan9394b5a2011-10-29 19:50:43 +0000599 void *copied_type = GuardedCopyType(m_ast_context, type_sp->GetClangAST(), type_sp->GetClangFullType());
Sean Callanane1301a62011-12-06 03:41:14 +0000600
Sean Callanandc5fce12011-12-01 21:04:37 +0000601 if (!copied_type)
602 {
603 if (log)
Sean Callanane1301a62011-12-06 03:41:14 +0000604 log->Printf(" CAS::FEVD[%u] - Couldn't export the type for a constant integer result",
605 current_id);
606
Sean Callanandc5fce12011-12-01 21:04:37 +0000607 break;
608 }
609
Sean Callanan9394b5a2011-10-29 19:50:43 +0000610 context.AddTypeDecl(copied_type);
611 }
Sean Callanan673f3db2011-11-30 22:11:59 +0000612
Sean Callanan9394b5a2011-10-29 19:50:43 +0000613 } while(0);
614}
615
Sean Callanan9b714842011-11-09 19:33:21 +0000616void
617ClangASTSource::FindObjCMethodDecls (NameSearchContext &context)
618{
619 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
620
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000621 static unsigned int invocation_id = 0;
622 unsigned int current_id = invocation_id++;
623
Sean Callanan9b714842011-11-09 19:33:21 +0000624 const DeclarationName &decl_name(context.m_decl_name);
625 const DeclContext *decl_ctx(context.m_decl_context);
626
627 const ObjCInterfaceDecl *interface_decl = dyn_cast<ObjCInterfaceDecl>(decl_ctx);
628
629 if (!interface_decl)
630 return;
631
632 StreamString ss;
Sean Callanane1301a62011-12-06 03:41:14 +0000633
Sean Callanan9b714842011-11-09 19:33:21 +0000634 if (decl_name.isObjCZeroArgSelector())
635 {
636 ss.Printf("%s", decl_name.getAsString().c_str());
637 }
638 else if (decl_name.isObjCOneArgSelector())
639 {
Sean Callanan1d9ffe22011-11-14 18:29:46 +0000640 ss.Printf("%s", decl_name.getAsString().c_str());
Sean Callanan9b714842011-11-09 19:33:21 +0000641 }
642 else
643 {
644 clang::Selector sel = decl_name.getObjCSelector();
645
646 for (unsigned i = 0, e = sel.getNumArgs();
647 i != e;
648 ++i)
649 {
650 llvm::StringRef r = sel.getNameForSlot(i);
651 ss.Printf("%s:", r.str().c_str());
652 }
653 }
654 ss.Flush();
655
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000656 ConstString selector_name(ss.GetData());
657
Sean Callanan9b714842011-11-09 19:33:21 +0000658 if (log)
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000659 log->Printf("ClangASTSource::FindObjCMethodDecls[%d] on (ASTContext*)%p for selector [%s %s]",
660 current_id,
661 m_ast_context,
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000662 interface_decl->getNameAsString().c_str(),
663 selector_name.AsCString());
664
Sean Callanane1301a62011-12-06 03:41:14 +0000665 ClangASTImporter::ObjCInterfaceMapSP interface_map = m_ast_importer->GetObjCInterfaceMap(interface_decl);
666
667 if (interface_map)
668 {
669 for (ClangASTImporter::ObjCInterfaceMap::iterator i = interface_map->begin(), e = interface_map->end();
670 i != e;
671 ++i)
672 {
673 lldb::clang_type_t backing_type = i->GetOpaqueQualType();
674
675 if (!backing_type)
676 continue;
677
678 QualType backing_qual_type = QualType::getFromOpaquePtr(backing_type);
679
680 const ObjCInterfaceType *backing_interface_type = dyn_cast<ObjCInterfaceType>(backing_qual_type.getTypePtr());
681
682 if (!backing_interface_type)
683 continue;
684
685 const ObjCInterfaceDecl *backing_interface_decl = backing_interface_type->getDecl();
686
687 if (!backing_interface_decl)
688 continue;
689
690 if (backing_interface_decl->decls_begin() == backing_interface_decl->decls_end())
691 continue; // don't waste time creating a DeclarationName here
692
693 clang::ASTContext &backing_ast_context = backing_interface_decl->getASTContext();
694
695 llvm::SmallVector<clang::IdentifierInfo *, 3> selector_components;
Sean Callanan3d8540a2011-12-07 22:39:39 +0000696 int num_arguments = 0;
Sean Callanane1301a62011-12-06 03:41:14 +0000697
698 if (decl_name.isObjCZeroArgSelector())
699 {
700 selector_components.push_back (&backing_ast_context.Idents.get(decl_name.getAsString().c_str()));
701 }
702 else if (decl_name.isObjCOneArgSelector())
703 {
704 selector_components.push_back (&backing_ast_context.Idents.get(decl_name.getAsString().c_str()));
Sean Callanan3d8540a2011-12-07 22:39:39 +0000705 num_arguments = 1;
Sean Callanane1301a62011-12-06 03:41:14 +0000706 }
707 else
708 {
709 clang::Selector sel = decl_name.getObjCSelector();
710
711 for (unsigned i = 0, e = sel.getNumArgs();
712 i != e;
713 ++i)
714 {
715 llvm::StringRef r = sel.getNameForSlot(i);
716
717 selector_components.push_back (&backing_ast_context.Idents.get(r.str().c_str()));
Sean Callanan3d8540a2011-12-07 22:39:39 +0000718 num_arguments++;
Sean Callanane1301a62011-12-06 03:41:14 +0000719 }
720 }
721
Sean Callanan3d8540a2011-12-07 22:39:39 +0000722 Selector backing_selector = backing_interface_decl->getASTContext().Selectors.getSelector(num_arguments, selector_components.data());
Sean Callanane1301a62011-12-06 03:41:14 +0000723 DeclarationName backing_decl_name = DeclarationName(backing_selector);
724
725 DeclContext::lookup_const_result lookup_result = backing_interface_decl->lookup(backing_decl_name);
726
727 if (lookup_result.first == lookup_result.second)
728 continue;
729
730 ObjCMethodDecl *method_decl = dyn_cast<ObjCMethodDecl>(*lookup_result.first);
731
732 if (!method_decl)
733 continue;
734
735 Decl *copied_decl = m_ast_importer->CopyDecl(m_ast_context, &backing_ast_context, *lookup_result.first);
736
Sean Callanan3d8540a2011-12-07 22:39:39 +0000737 if (!copied_decl)
738 {
Greg Clayton2e87f6a2011-12-08 01:32:28 +0000739 if (log)
740 log->Printf(" CAS::FOMD[%d] couldn't import method from symbols", current_id);
Sean Callanan3d8540a2011-12-07 22:39:39 +0000741 continue;
742 }
743
Sean Callanane1301a62011-12-06 03:41:14 +0000744 ObjCMethodDecl *copied_method_decl = dyn_cast<ObjCMethodDecl> (copied_decl);
745
746 if (!copied_method_decl)
747 continue;
748
749 if (log)
750 {
751 ASTDumper dumper((Decl*)copied_method_decl);
752 log->Printf(" CAS::FOMD[%d] found (in symbols) %s", current_id, dumper.GetCString());
753 }
754
755 context.AddNamedDecl(copied_method_decl);
756 }
757 }
758
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000759 SymbolContextList sc_list;
760
761 const bool include_symbols = false;
762 const bool append = false;
763
764 m_target->GetImages().FindFunctions(selector_name, lldb::eFunctionNameTypeSelector, include_symbols, append, sc_list);
765
766 for (uint32_t i = 0, e = sc_list.GetSize();
767 i != e;
768 ++i)
769 {
770 SymbolContext sc;
771
772 if (!sc_list.GetContextAtIndex(i, sc))
773 continue;
774
775 if (!sc.function)
776 continue;
777
778 DeclContext *function_ctx = sc.function->GetClangDeclContext();
779
780 if (!function_ctx)
781 continue;
782
783 ObjCMethodDecl *method_decl = dyn_cast<ObjCMethodDecl>(function_ctx);
784
785 if (!method_decl)
786 continue;
787
788 ObjCInterfaceDecl *found_interface_decl = method_decl->getClassInterface();
789
790 if (!found_interface_decl)
791 continue;
792
793 if (found_interface_decl->getName() == interface_decl->getName())
794 {
Sean Callanan4938bd62011-11-16 18:20:47 +0000795 Decl *copied_decl = m_ast_importer->CopyDecl(m_ast_context, &method_decl->getASTContext(), method_decl);
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000796
797 if (!copied_decl)
798 continue;
799
800 ObjCMethodDecl *copied_method_decl = dyn_cast<ObjCMethodDecl>(copied_decl);
801
802 if (!copied_method_decl)
803 continue;
804
805 if (log)
806 {
807 ASTDumper dumper((Decl*)copied_method_decl);
Sean Callanane1301a62011-12-06 03:41:14 +0000808 log->Printf(" CAS::FOMD[%d] found (in debug info) %s", current_id, dumper.GetCString());
Sean Callananf2a0a5c2011-11-11 20:37:26 +0000809 }
810
811 context.AddNamedDecl(copied_method_decl);
812 }
813 }
Sean Callanan9b714842011-11-09 19:33:21 +0000814}
815
Sean Callanane6ea5fe2011-11-15 02:11:17 +0000816void
817ClangASTSource::FindObjCPropertyDecls (NameSearchContext &context)
818{
819 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
820
821 static unsigned int invocation_id = 0;
822 unsigned int current_id = invocation_id++;
823
824 const ObjCInterfaceDecl *iface_decl = cast<ObjCInterfaceDecl>(context.m_decl_context);
825 Decl *orig_decl;
826 ASTContext *orig_ast_ctx;
827
828 m_ast_importer->ResolveDeclOrigin(iface_decl, &orig_decl, &orig_ast_ctx);
829
830 if (!orig_decl)
831 return;
832
833 ObjCInterfaceDecl *orig_iface_decl = dyn_cast<ObjCInterfaceDecl>(orig_decl);
834
835 if (!orig_iface_decl)
836 return;
837
838 if (!ClangASTContext::GetCompleteDecl(orig_ast_ctx, orig_iface_decl))
839 return;
840
841 std::string property_name_str = context.m_decl_name.getAsString();
842 StringRef property_name(property_name_str.c_str());
843 ObjCPropertyDecl *property_decl = orig_iface_decl->FindPropertyDeclaration(&orig_ast_ctx->Idents.get(property_name));
844
845 if (log)
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000846 log->Printf("ClangASTSource::FindObjCPropertyDecls[%d] on (ASTContext*)%p for property '%s.%s'",
Sean Callanane6ea5fe2011-11-15 02:11:17 +0000847 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000848 m_ast_context,
Sean Callanane6ea5fe2011-11-15 02:11:17 +0000849 iface_decl->getNameAsString().c_str(),
850 property_name_str.c_str());
851
852 if (!property_decl)
853 return;
854
Sean Callanan4938bd62011-11-16 18:20:47 +0000855 Decl *copied_decl = m_ast_importer->CopyDecl(m_ast_context, orig_ast_ctx, property_decl);
Sean Callanane6ea5fe2011-11-15 02:11:17 +0000856
857 if (!copied_decl)
858 return;
859
860 ObjCPropertyDecl *copied_property_decl = dyn_cast<ObjCPropertyDecl>(copied_decl);
861
862 if (!copied_property_decl)
863 return;
864
865 if (log)
866 {
867 ASTDumper dumper((Decl*)copied_property_decl);
868 log->Printf(" CAS::FOPD[%d] found %s", current_id, dumper.GetCString());
869 }
870
871 context.AddNamedDecl(copied_property_decl);
872}
873
Sean Callanan73b520f2011-10-29 01:58:46 +0000874void
875ClangASTSource::CompleteNamespaceMap (ClangASTImporter::NamespaceMapSP &namespace_map,
876 const ConstString &name,
877 ClangASTImporter::NamespaceMapSP &parent_map) const
878{
879 static unsigned int invocation_id = 0;
880 unsigned int current_id = invocation_id++;
881
882 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
883
884 if (log)
885 {
886 if (parent_map && parent_map->size())
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000887 log->Printf("CompleteNamespaceMap[%u] on (ASTContext*)%p Searching for namespace %s in namespace %s",
Sean Callanan73b520f2011-10-29 01:58:46 +0000888 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000889 m_ast_context,
Sean Callanan73b520f2011-10-29 01:58:46 +0000890 name.GetCString(),
891 parent_map->begin()->second.GetNamespaceDecl()->getDeclName().getAsString().c_str());
892 else
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000893 log->Printf("CompleteNamespaceMap[%u] on (ASTContext*)%p Searching for namespace %s",
Sean Callanan73b520f2011-10-29 01:58:46 +0000894 current_id,
Sean Callanan5a55c7a2011-11-18 03:28:09 +0000895 m_ast_context,
Sean Callanan73b520f2011-10-29 01:58:46 +0000896 name.GetCString());
897 }
898
899
900 if (parent_map)
901 {
902 for (ClangASTImporter::NamespaceMap::iterator i = parent_map->begin(), e = parent_map->end();
903 i != e;
904 ++i)
905 {
906 ClangNamespaceDecl found_namespace_decl;
907
908 lldb::ModuleSP module_sp = i->first;
909 ClangNamespaceDecl module_parent_namespace_decl = i->second;
910
911 SymbolVendor *symbol_vendor = module_sp->GetSymbolVendor();
912
913 if (!symbol_vendor)
914 continue;
915
916 SymbolContext null_sc;
917
918 found_namespace_decl = symbol_vendor->FindNamespace(null_sc, name, &module_parent_namespace_decl);
919
920 if (!found_namespace_decl)
921 continue;
922
923 namespace_map->push_back(std::pair<lldb::ModuleSP, ClangNamespaceDecl>(module_sp, found_namespace_decl));
924
925 if (log)
926 log->Printf(" CMN[%u] Found namespace %s in module %s",
927 current_id,
928 name.GetCString(),
929 module_sp->GetFileSpec().GetFilename().GetCString());
930 }
931 }
932 else
933 {
934 ModuleList &images = m_target->GetImages();
935 ClangNamespaceDecl null_namespace_decl;
936
937 for (uint32_t i = 0, e = images.GetSize();
938 i != e;
939 ++i)
940 {
941 lldb::ModuleSP image = images.GetModuleAtIndex(i);
942
943 if (!image)
944 continue;
945
946 ClangNamespaceDecl found_namespace_decl;
947
948 SymbolVendor *symbol_vendor = image->GetSymbolVendor();
949
950 if (!symbol_vendor)
951 continue;
952
953 SymbolContext null_sc;
954
955 found_namespace_decl = symbol_vendor->FindNamespace(null_sc, name, &null_namespace_decl);
956
957 if (!found_namespace_decl)
958 continue;
959
960 namespace_map->push_back(std::pair<lldb::ModuleSP, ClangNamespaceDecl>(image, found_namespace_decl));
961
962 if (log)
963 log->Printf(" CMN[%u] Found namespace %s in module %s",
964 current_id,
965 name.GetCString(),
966 image->GetFileSpec().GetFilename().GetCString());
967 }
968 }
969}
970
Sean Callanane1301a62011-12-06 03:41:14 +0000971void
972ClangASTSource::CompleteObjCInterfaceMap (ClangASTImporter::ObjCInterfaceMapSP &objc_interface_map,
973 const ConstString &name) const
974{
975 SymbolContext null_sc;
976
977 TypeList types;
978
979 m_target->GetImages().FindTypes(null_sc, name, true, UINT32_MAX, types);
980
981 for (uint32_t i = 0, e = types.GetSize();
982 i != e;
983 ++i)
984 {
985 lldb::TypeSP mapped_type_sp = types.GetTypeAtIndex(i);
986
987 if (!mapped_type_sp || !mapped_type_sp->GetClangFullType())
988 continue;
989
990 objc_interface_map->push_back (ClangASTType(mapped_type_sp->GetClangAST(), mapped_type_sp->GetClangFullType()));
991 }
992}
993
Sean Callananbb715f92011-10-29 02:28:18 +0000994NamespaceDecl *
995ClangASTSource::AddNamespace (NameSearchContext &context, ClangASTImporter::NamespaceMapSP &namespace_decls)
996{
997 if (namespace_decls.empty())
998 return NULL;
999
1000 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
1001
1002 const ClangNamespaceDecl &namespace_decl = namespace_decls->begin()->second;
1003
Sean Callanan4938bd62011-11-16 18:20:47 +00001004 Decl *copied_decl = m_ast_importer->CopyDecl(m_ast_context, namespace_decl.GetASTContext(), namespace_decl.GetNamespaceDecl());
Sean Callananbb715f92011-10-29 02:28:18 +00001005
1006 NamespaceDecl *copied_namespace_decl = dyn_cast<NamespaceDecl>(copied_decl);
1007
1008 m_ast_importer->RegisterNamespaceMap(copied_namespace_decl, namespace_decls);
1009
1010 return dyn_cast<NamespaceDecl>(copied_decl);
1011}
1012
Sean Callanan9394b5a2011-10-29 19:50:43 +00001013void *
1014ClangASTSource::GuardedCopyType (ASTContext *dest_context,
1015 ASTContext *source_context,
1016 void *clang_type)
1017{
1018 SetImportInProgress(true);
1019
Sean Callanan4938bd62011-11-16 18:20:47 +00001020 QualType ret_qual_type = m_ast_importer->CopyType (m_ast_context, source_context, QualType::getFromOpaquePtr(clang_type));
Sean Callanan9394b5a2011-10-29 19:50:43 +00001021
1022 void *ret = ret_qual_type.getAsOpaquePtr();
1023
1024 SetImportInProgress(false);
1025
1026 return ret;
1027}
1028
Greg Claytonb01000f2011-01-17 03:46:26 +00001029clang::NamedDecl *
1030NameSearchContext::AddVarDecl(void *type)
1031{
Greg Clayton8de27c72010-10-15 22:48:33 +00001032 IdentifierInfo *ii = m_decl_name.getAsIdentifierInfo();
Sean Callanan1ddd9fe2010-11-30 00:27:43 +00001033
1034 assert (type && "Type for variable must be non-NULL!");
Sean Callanancc074622010-09-14 21:59:34 +00001035
Sean Callananf76afff2011-10-28 23:38:38 +00001036 clang::NamedDecl *Decl = VarDecl::Create(*m_ast_source.m_ast_context,
Greg Clayton8de27c72010-10-15 22:48:33 +00001037 const_cast<DeclContext*>(m_decl_context),
Chris Lattner24943d22010-06-08 16:52:24 +00001038 SourceLocation(),
Sean Callanan279584c2011-03-15 00:17:19 +00001039 SourceLocation(),
Sean Callanancc074622010-09-14 21:59:34 +00001040 ii,
Chris Lattner24943d22010-06-08 16:52:24 +00001041 QualType::getFromOpaquePtr(type),
1042 0,
Sean Callanan47a5c4c2010-09-23 03:01:22 +00001043 SC_Static,
1044 SC_Static);
Greg Clayton8de27c72010-10-15 22:48:33 +00001045 m_decls.push_back(Decl);
Chris Lattner24943d22010-06-08 16:52:24 +00001046
1047 return Decl;
1048}
Sean Callanan8f0dc342010-06-22 23:46:24 +00001049
Greg Claytonb01000f2011-01-17 03:46:26 +00001050clang::NamedDecl *
1051NameSearchContext::AddFunDecl (void *type)
1052{
Sean Callananf76afff2011-10-28 23:38:38 +00001053 clang::FunctionDecl *func_decl = FunctionDecl::Create (*m_ast_source.m_ast_context,
Greg Clayton8de27c72010-10-15 22:48:33 +00001054 const_cast<DeclContext*>(m_decl_context),
1055 SourceLocation(),
Sean Callanan279584c2011-03-15 00:17:19 +00001056 SourceLocation(),
Greg Clayton8de27c72010-10-15 22:48:33 +00001057 m_decl_name.getAsIdentifierInfo(),
1058 QualType::getFromOpaquePtr(type),
1059 NULL,
1060 SC_Static,
1061 SC_Static,
1062 false,
1063 true);
Sean Callanan8f0dc342010-06-22 23:46:24 +00001064
Sean Callananb291abe2010-08-12 23:45:38 +00001065 // We have to do more than just synthesize the FunctionDecl. We have to
1066 // synthesize ParmVarDecls for all of the FunctionDecl's arguments. To do
1067 // this, we raid the function's FunctionProtoType for types.
1068
Greg Clayton8de27c72010-10-15 22:48:33 +00001069 QualType qual_type (QualType::getFromOpaquePtr(type));
Sean Callanandc5fce12011-12-01 21:04:37 +00001070 const FunctionProtoType *func_proto_type = dyn_cast<FunctionProtoType>(qual_type.getTypePtr());
Sean Callanan8f0dc342010-06-22 23:46:24 +00001071
Greg Clayton8de27c72010-10-15 22:48:33 +00001072 if (func_proto_type)
Sean Callanan3c821cc2010-06-23 18:58:10 +00001073 {
Greg Clayton8de27c72010-10-15 22:48:33 +00001074 unsigned NumArgs = func_proto_type->getNumArgs();
Sean Callanan8f0dc342010-06-22 23:46:24 +00001075 unsigned ArgIndex;
1076
Sean Callananc1535182011-10-07 23:18:13 +00001077 SmallVector<ParmVarDecl *, 5> parm_var_decls;
1078
Sean Callanan8f0dc342010-06-22 23:46:24 +00001079 for (ArgIndex = 0; ArgIndex < NumArgs; ++ArgIndex)
1080 {
Greg Clayton8de27c72010-10-15 22:48:33 +00001081 QualType arg_qual_type (func_proto_type->getArgType(ArgIndex));
Sean Callanan8f0dc342010-06-22 23:46:24 +00001082
Sean Callananf76afff2011-10-28 23:38:38 +00001083 parm_var_decls.push_back(ParmVarDecl::Create (*m_ast_source.m_ast_context,
Sean Callananc1535182011-10-07 23:18:13 +00001084 const_cast<DeclContext*>(m_decl_context),
1085 SourceLocation(),
1086 SourceLocation(),
1087 NULL,
1088 arg_qual_type,
1089 NULL,
1090 SC_Static,
1091 SC_Static,
1092 NULL));
Sean Callanan8f0dc342010-06-22 23:46:24 +00001093 }
1094
Sean Callananc1535182011-10-07 23:18:13 +00001095 func_decl->setParams(ArrayRef<ParmVarDecl*>(parm_var_decls));
Sean Callanan8f0dc342010-06-22 23:46:24 +00001096 }
Sean Callanandc5fce12011-12-01 21:04:37 +00001097 else
1098 {
1099 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
1100
1101 log->Printf("Function type wasn't a FunctionProtoType");
1102 }
Sean Callanan8f0dc342010-06-22 23:46:24 +00001103
Greg Clayton8de27c72010-10-15 22:48:33 +00001104 m_decls.push_back(func_decl);
Sean Callanan8f0dc342010-06-22 23:46:24 +00001105
Greg Clayton8de27c72010-10-15 22:48:33 +00001106 return func_decl;
Sean Callanan8f0dc342010-06-22 23:46:24 +00001107}
Sean Callanan0fc73582010-07-27 00:55:47 +00001108
Greg Claytonb01000f2011-01-17 03:46:26 +00001109clang::NamedDecl *
1110NameSearchContext::AddGenericFunDecl()
Sean Callanan0fc73582010-07-27 00:55:47 +00001111{
Sean Callananad293092011-01-18 23:32:05 +00001112 FunctionProtoType::ExtProtoInfo proto_info;
1113
1114 proto_info.Variadic = true;
1115
Sean Callananf76afff2011-10-28 23:38:38 +00001116 QualType generic_function_type(m_ast_source.m_ast_context->getFunctionType (m_ast_source.m_ast_context->UnknownAnyTy, // result
1117 NULL, // argument types
1118 0, // number of arguments
1119 proto_info));
Greg Clayton8de27c72010-10-15 22:48:33 +00001120
Sean Callanan0fc73582010-07-27 00:55:47 +00001121 return AddFunDecl(generic_function_type.getAsOpaquePtr());
1122}
Sean Callanan93a4b1a2010-08-04 01:02:13 +00001123
Greg Claytonb01000f2011-01-17 03:46:26 +00001124clang::NamedDecl *
1125NameSearchContext::AddTypeDecl(void *type)
Sean Callanan93a4b1a2010-08-04 01:02:13 +00001126{
Greg Claytona1aaaff2011-01-23 00:34:52 +00001127 if (type)
1128 {
1129 QualType qual_type = QualType::getFromOpaquePtr(type);
Sean Callanan93a4b1a2010-08-04 01:02:13 +00001130
Sean Callanand5b3c352011-01-27 04:42:51 +00001131 if (const TagType *tag_type = dyn_cast<clang::TagType>(qual_type))
Greg Claytona1aaaff2011-01-23 00:34:52 +00001132 {
1133 TagDecl *tag_decl = tag_type->getDecl();
1134
1135 m_decls.push_back(tag_decl);
1136
1137 return tag_decl;
1138 }
Sean Callanand5b3c352011-01-27 04:42:51 +00001139 else if (const ObjCObjectType *objc_object_type = dyn_cast<clang::ObjCObjectType>(qual_type))
Greg Claytona1aaaff2011-01-23 00:34:52 +00001140 {
1141 ObjCInterfaceDecl *interface_decl = objc_object_type->getInterface();
1142
1143 m_decls.push_back((NamedDecl*)interface_decl);
1144
1145 return (NamedDecl*)interface_decl;
1146 }
Sean Callanan93a4b1a2010-08-04 01:02:13 +00001147 }
Greg Claytona1aaaff2011-01-23 00:34:52 +00001148 return NULL;
Sean Callanan93a4b1a2010-08-04 01:02:13 +00001149}
Greg Claytone6d72ca2011-06-25 00:44:06 +00001150
1151void
1152NameSearchContext::AddLookupResult (clang::DeclContextLookupConstResult result)
1153{
1154 for (clang::NamedDecl * const *decl_iterator = result.first;
1155 decl_iterator != result.second;
1156 ++decl_iterator)
1157 m_decls.push_back (*decl_iterator);
1158}
1159
1160void
1161NameSearchContext::AddNamedDecl (clang::NamedDecl *decl)
1162{
1163 m_decls.push_back (decl);
1164}