blob: 5929ebb45c81ae12b03c98c68967a40482283dc4 [file] [log] [blame]
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001//===-- ClangASTContext.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
Eli Friedman932197d2010-06-13 19:06:42 +000010#include "lldb/Symbol/ClangASTContext.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000011
12// C Includes
13// C++ Includes
14#include <string>
15
16// Other libraries and framework includes
Greg Clayton6beaaa62011-01-17 03:46:26 +000017
18// Clang headers like to use NDEBUG inside of them to enable/disable debug
19// releated features using "#ifndef NDEBUG" preprocessor blocks to do one thing
20// or another. This is bad because it means that if clang was built in release
21// mode, it assumes that you are building in release mode which is not always
22// the case. You can end up with functions that are defined as empty in header
23// files when NDEBUG is not defined, and this can cause link errors with the
24// clang .a files that you have since you might be missing functions in the .a
25// file. So we have to define NDEBUG when including clang headers to avoid any
26// mismatches. This is covered by rdar://problem/8691220
27
Sean Callanan3b1d4f62011-10-26 17:46:51 +000028#if !defined(NDEBUG) && !defined(LLVM_NDEBUG_OFF)
Greg Clayton6beaaa62011-01-17 03:46:26 +000029#define LLDB_DEFINED_NDEBUG_FOR_CLANG
Sean Callanan246549c2010-07-08 18:16:16 +000030#define NDEBUG
Greg Clayton6beaaa62011-01-17 03:46:26 +000031// Need to include assert.h so it is as clang would expect it to be (disabled)
32#include <assert.h>
33#endif
34
Chris Lattner30fdc8d2010-06-08 16:52:24 +000035#include "clang/AST/ASTContext.h"
36#include "clang/AST/ASTImporter.h"
37#include "clang/AST/CXXInheritance.h"
Greg Clayton8cf05932010-07-22 18:30:50 +000038#include "clang/AST/DeclObjC.h"
Greg Claytonf0705c82011-10-22 03:33:13 +000039#include "clang/AST/DeclTemplate.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000040#include "clang/AST/RecordLayout.h"
41#include "clang/AST/Type.h"
42#include "clang/Basic/Builtins.h"
Sean Callanan7e2863b2012-02-06 21:28:03 +000043#include "clang/Basic/Diagnostic.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000044#include "clang/Basic/FileManager.h"
Sean Callanan79439e82010-11-18 02:56:27 +000045#include "clang/Basic/FileSystemOptions.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000046#include "clang/Basic/SourceManager.h"
47#include "clang/Basic/TargetInfo.h"
48#include "clang/Basic/TargetOptions.h"
49#include "clang/Frontend/FrontendOptions.h"
50#include "clang/Frontend/LangStandard.h"
Greg Clayton6beaaa62011-01-17 03:46:26 +000051
52#ifdef LLDB_DEFINED_NDEBUG_FOR_CLANG
Sean Callanan246549c2010-07-08 18:16:16 +000053#undef NDEBUG
Greg Clayton6beaaa62011-01-17 03:46:26 +000054#undef LLDB_DEFINED_NDEBUG_FOR_CLANG
55// Need to re-include assert.h so it is as _we_ would expect it to be (enabled)
56#include <assert.h>
57#endif
Chris Lattner30fdc8d2010-06-08 16:52:24 +000058
Greg Clayton514487e2011-02-15 21:59:32 +000059#include "lldb/Core/ArchSpec.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000060#include "lldb/Core/dwarf.h"
Greg Clayton73b472d2010-10-27 03:32:59 +000061#include "lldb/Core/Flags.h"
Sean Callananfb8b7092010-10-28 18:19:36 +000062#include "lldb/Core/Log.h"
Greg Claytonf0705c82011-10-22 03:33:13 +000063#include "lldb/Core/RegularExpression.h"
64#include "lldb/Expression/ASTDumper.h"
Sean Callanan3b107b12011-12-03 03:15:28 +000065#include "lldb/Symbol/ClangExternalASTSourceCommon.h"
Sean Callanan5e9e1992011-10-26 01:06:27 +000066#include "lldb/Symbol/VerifyDecl.h"
Jim Inghamd555bac2011-06-24 22:03:24 +000067#include "lldb/Target/ExecutionContext.h"
68#include "lldb/Target/Process.h"
69#include "lldb/Target/ObjCLanguageRuntime.h"
70
Chris Lattner30fdc8d2010-06-08 16:52:24 +000071
Eli Friedman932197d2010-06-13 19:06:42 +000072#include <stdio.h>
73
Greg Claytonc86103d2010-08-05 01:57:25 +000074using namespace lldb;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000075using namespace lldb_private;
76using namespace llvm;
77using namespace clang;
78
Greg Clayton6beaaa62011-01-17 03:46:26 +000079
80static bool
Enrico Granata86027e92012-03-24 01:11:14 +000081GetCompleteQualType (clang::ASTContext *ast, clang::QualType qual_type, bool allow_completion = true)
Greg Clayton6beaaa62011-01-17 03:46:26 +000082{
83 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
84 switch (type_class)
85 {
Sean Callanan5b26f272012-02-04 08:49:35 +000086 case clang::Type::ConstantArray:
87 {
88 const clang::ArrayType *array_type = dyn_cast<clang::ArrayType>(qual_type.getTypePtr());
89
90 if (array_type)
Enrico Granata86027e92012-03-24 01:11:14 +000091 return GetCompleteQualType (ast, array_type->getElementType(), allow_completion);
Sean Callanan5b26f272012-02-04 08:49:35 +000092 }
93 break;
94
Greg Clayton6beaaa62011-01-17 03:46:26 +000095 case clang::Type::Record:
96 case clang::Type::Enum:
97 {
Sean Callanan78e37602011-01-27 04:42:51 +000098 const clang::TagType *tag_type = dyn_cast<clang::TagType>(qual_type.getTypePtr());
Greg Clayton6beaaa62011-01-17 03:46:26 +000099 if (tag_type)
100 {
101 clang::TagDecl *tag_decl = tag_type->getDecl();
102 if (tag_decl)
103 {
Greg Clayton219cf312012-03-30 00:51:13 +0000104 if (tag_decl->isCompleteDefinition())
Greg Clayton6beaaa62011-01-17 03:46:26 +0000105 return true;
Enrico Granata86027e92012-03-24 01:11:14 +0000106
107 if (!allow_completion)
108 return false;
Greg Clayton6beaaa62011-01-17 03:46:26 +0000109
110 if (tag_decl->hasExternalLexicalStorage())
111 {
Greg Clayton007d5be2011-05-30 00:49:24 +0000112 if (ast)
Greg Clayton6beaaa62011-01-17 03:46:26 +0000113 {
Greg Clayton007d5be2011-05-30 00:49:24 +0000114 ExternalASTSource *external_ast_source = ast->getExternalSource();
115 if (external_ast_source)
116 {
117 external_ast_source->CompleteType(tag_decl);
118 return !tag_type->isIncompleteType();
119 }
Greg Clayton6beaaa62011-01-17 03:46:26 +0000120 }
121 }
122 return false;
123 }
124 }
125
126 }
127 break;
128
129 case clang::Type::ObjCObject:
130 case clang::Type::ObjCInterface:
131 {
Sean Callanan78e37602011-01-27 04:42:51 +0000132 const clang::ObjCObjectType *objc_class_type = dyn_cast<clang::ObjCObjectType>(qual_type);
Greg Clayton6beaaa62011-01-17 03:46:26 +0000133 if (objc_class_type)
134 {
135 clang::ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
136 // We currently can't complete objective C types through the newly added ASTContext
137 // because it only supports TagDecl objects right now...
Enrico Granata9dd75c82011-07-15 23:30:15 +0000138 if (class_interface_decl)
Greg Clayton6beaaa62011-01-17 03:46:26 +0000139 {
Sean Callanan5b26f272012-02-04 08:49:35 +0000140 if (class_interface_decl->getDefinition())
141 return true;
142
Enrico Granata86027e92012-03-24 01:11:14 +0000143 if (!allow_completion)
144 return false;
Greg Clayton20533982012-03-30 23:48:28 +0000145
Sean Callanan5b26f272012-02-04 08:49:35 +0000146 if (class_interface_decl->hasExternalLexicalStorage())
Greg Clayton6beaaa62011-01-17 03:46:26 +0000147 {
Enrico Granata0a3958e2011-07-02 00:25:22 +0000148 if (ast)
Greg Clayton007d5be2011-05-30 00:49:24 +0000149 {
Enrico Granata0a3958e2011-07-02 00:25:22 +0000150 ExternalASTSource *external_ast_source = ast->getExternalSource();
151 if (external_ast_source)
152 {
153 external_ast_source->CompleteType (class_interface_decl);
Sean Callanan5b26f272012-02-04 08:49:35 +0000154 return !objc_class_type->isIncompleteType();
Enrico Granata0a3958e2011-07-02 00:25:22 +0000155 }
Greg Clayton007d5be2011-05-30 00:49:24 +0000156 }
Greg Clayton6beaaa62011-01-17 03:46:26 +0000157 }
Enrico Granata0a3958e2011-07-02 00:25:22 +0000158 return false;
Sean Callanan5b26f272012-02-04 08:49:35 +0000159 }
Greg Clayton6beaaa62011-01-17 03:46:26 +0000160 }
161 }
162 break;
163
164 case clang::Type::Typedef:
Enrico Granata86027e92012-03-24 01:11:14 +0000165 return GetCompleteQualType (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType(), allow_completion);
Sean Callanan912855f2011-08-11 23:56:13 +0000166
167 case clang::Type::Elaborated:
Enrico Granata86027e92012-03-24 01:11:14 +0000168 return GetCompleteQualType (ast, cast<ElaboratedType>(qual_type)->getNamedType(), allow_completion);
Greg Clayton6beaaa62011-01-17 03:46:26 +0000169
170 default:
171 break;
172 }
173
174 return true;
175}
176
Greg Clayton8cf05932010-07-22 18:30:50 +0000177static AccessSpecifier
Greg Claytonc86103d2010-08-05 01:57:25 +0000178ConvertAccessTypeToAccessSpecifier (AccessType access)
Greg Clayton8cf05932010-07-22 18:30:50 +0000179{
180 switch (access)
181 {
Greg Claytonc86103d2010-08-05 01:57:25 +0000182 default: break;
183 case eAccessNone: return AS_none;
184 case eAccessPublic: return AS_public;
185 case eAccessPrivate: return AS_private;
186 case eAccessProtected: return AS_protected;
Greg Clayton8cf05932010-07-22 18:30:50 +0000187 }
188 return AS_none;
189}
190
191static ObjCIvarDecl::AccessControl
Greg Claytonc86103d2010-08-05 01:57:25 +0000192ConvertAccessTypeToObjCIvarAccessControl (AccessType access)
Greg Clayton8cf05932010-07-22 18:30:50 +0000193{
194 switch (access)
195 {
Greg Claytonc86103d2010-08-05 01:57:25 +0000196 default: break;
197 case eAccessNone: return ObjCIvarDecl::None;
198 case eAccessPublic: return ObjCIvarDecl::Public;
199 case eAccessPrivate: return ObjCIvarDecl::Private;
200 case eAccessProtected: return ObjCIvarDecl::Protected;
201 case eAccessPackage: return ObjCIvarDecl::Package;
Greg Clayton8cf05932010-07-22 18:30:50 +0000202 }
203 return ObjCIvarDecl::None;
204}
205
206
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000207static void
208ParseLangArgs
209(
210 LangOptions &Opts,
Greg Clayton94e5d782010-06-13 17:34:29 +0000211 InputKind IK
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000212)
213{
214 // FIXME: Cleanup per-file based stuff.
215
216 // Set some properties which depend soley on the input kind; it would be nice
217 // to move these to the language standard, and have the driver resolve the
218 // input kind + language standard.
Greg Clayton94e5d782010-06-13 17:34:29 +0000219 if (IK == IK_Asm) {
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000220 Opts.AsmPreprocessor = 1;
Greg Clayton94e5d782010-06-13 17:34:29 +0000221 } else if (IK == IK_ObjC ||
222 IK == IK_ObjCXX ||
223 IK == IK_PreprocessedObjC ||
224 IK == IK_PreprocessedObjCXX) {
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000225 Opts.ObjC1 = Opts.ObjC2 = 1;
226 }
227
228 LangStandard::Kind LangStd = LangStandard::lang_unspecified;
229
230 if (LangStd == LangStandard::lang_unspecified) {
231 // Based on the base language, pick one.
232 switch (IK) {
Greg Clayton94e5d782010-06-13 17:34:29 +0000233 case IK_None:
234 case IK_AST:
Sean Callananfb0b7582011-03-15 00:17:19 +0000235 case IK_LLVM_IR:
Greg Clayton6beaaa62011-01-17 03:46:26 +0000236 assert (!"Invalid input kind!");
Greg Clayton94e5d782010-06-13 17:34:29 +0000237 case IK_OpenCL:
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000238 LangStd = LangStandard::lang_opencl;
239 break;
Sean Callananfb0b7582011-03-15 00:17:19 +0000240 case IK_CUDA:
241 LangStd = LangStandard::lang_cuda;
242 break;
Greg Clayton94e5d782010-06-13 17:34:29 +0000243 case IK_Asm:
244 case IK_C:
245 case IK_PreprocessedC:
246 case IK_ObjC:
247 case IK_PreprocessedObjC:
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000248 LangStd = LangStandard::lang_gnu99;
249 break;
Greg Clayton94e5d782010-06-13 17:34:29 +0000250 case IK_CXX:
251 case IK_PreprocessedCXX:
252 case IK_ObjCXX:
253 case IK_PreprocessedObjCXX:
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000254 LangStd = LangStandard::lang_gnucxx98;
255 break;
256 }
257 }
258
259 const LangStandard &Std = LangStandard::getLangStandardForKind(LangStd);
260 Opts.BCPLComment = Std.hasBCPLComments();
261 Opts.C99 = Std.isC99();
262 Opts.CPlusPlus = Std.isCPlusPlus();
263 Opts.CPlusPlus0x = Std.isCPlusPlus0x();
264 Opts.Digraphs = Std.hasDigraphs();
265 Opts.GNUMode = Std.isGNUMode();
266 Opts.GNUInline = !Std.isC99();
267 Opts.HexFloats = Std.hasHexFloats();
268 Opts.ImplicitInt = Std.hasImplicitInt();
269
270 // OpenCL has some additional defaults.
271 if (LangStd == LangStandard::lang_opencl) {
272 Opts.OpenCL = 1;
273 Opts.AltiVec = 1;
274 Opts.CXXOperatorNames = 1;
275 Opts.LaxVectorConversions = 1;
276 }
277
278 // OpenCL and C++ both have bool, true, false keywords.
279 Opts.Bool = Opts.OpenCL || Opts.CPlusPlus;
280
281// if (Opts.CPlusPlus)
282// Opts.CXXOperatorNames = !Args.hasArg(OPT_fno_operator_names);
283//
284// if (Args.hasArg(OPT_fobjc_gc_only))
285// Opts.setGCMode(LangOptions::GCOnly);
286// else if (Args.hasArg(OPT_fobjc_gc))
287// Opts.setGCMode(LangOptions::HybridGC);
288//
289// if (Args.hasArg(OPT_print_ivar_layout))
290// Opts.ObjCGCBitmapPrint = 1;
291//
292// if (Args.hasArg(OPT_faltivec))
293// Opts.AltiVec = 1;
294//
295// if (Args.hasArg(OPT_pthread))
296// Opts.POSIXThreads = 1;
297//
298// llvm::StringRef Vis = getLastArgValue(Args, OPT_fvisibility,
299// "default");
300// if (Vis == "default")
Sean Callanan31e851c2010-10-29 18:38:40 +0000301 Opts.setVisibilityMode(DefaultVisibility);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000302// else if (Vis == "hidden")
303// Opts.setVisibilityMode(LangOptions::Hidden);
304// else if (Vis == "protected")
305// Opts.setVisibilityMode(LangOptions::Protected);
306// else
307// Diags.Report(diag::err_drv_invalid_value)
308// << Args.getLastArg(OPT_fvisibility)->getAsString(Args) << Vis;
309
310// Opts.OverflowChecking = Args.hasArg(OPT_ftrapv);
311
312 // Mimicing gcc's behavior, trigraphs are only enabled if -trigraphs
313 // is specified, or -std is set to a conforming mode.
314 Opts.Trigraphs = !Opts.GNUMode;
315// if (Args.hasArg(OPT_trigraphs))
316// Opts.Trigraphs = 1;
317//
318// Opts.DollarIdents = Args.hasFlag(OPT_fdollars_in_identifiers,
319// OPT_fno_dollars_in_identifiers,
320// !Opts.AsmPreprocessor);
321// Opts.PascalStrings = Args.hasArg(OPT_fpascal_strings);
322// Opts.Microsoft = Args.hasArg(OPT_fms_extensions);
323// Opts.WritableStrings = Args.hasArg(OPT_fwritable_strings);
324// if (Args.hasArg(OPT_fno_lax_vector_conversions))
325// Opts.LaxVectorConversions = 0;
326// Opts.Exceptions = Args.hasArg(OPT_fexceptions);
327// Opts.RTTI = !Args.hasArg(OPT_fno_rtti);
328// Opts.Blocks = Args.hasArg(OPT_fblocks);
329// Opts.CharIsSigned = !Args.hasArg(OPT_fno_signed_char);
330// Opts.ShortWChar = Args.hasArg(OPT_fshort_wchar);
331// Opts.Freestanding = Args.hasArg(OPT_ffreestanding);
332// Opts.NoBuiltin = Args.hasArg(OPT_fno_builtin) || Opts.Freestanding;
333// Opts.AssumeSaneOperatorNew = !Args.hasArg(OPT_fno_assume_sane_operator_new);
334// Opts.HeinousExtensions = Args.hasArg(OPT_fheinous_gnu_extensions);
335// Opts.AccessControl = Args.hasArg(OPT_faccess_control);
336// Opts.ElideConstructors = !Args.hasArg(OPT_fno_elide_constructors);
337// Opts.MathErrno = !Args.hasArg(OPT_fno_math_errno);
338// Opts.InstantiationDepth = getLastArgIntValue(Args, OPT_ftemplate_depth, 99,
339// Diags);
340// Opts.NeXTRuntime = !Args.hasArg(OPT_fgnu_runtime);
341// Opts.ObjCConstantStringClass = getLastArgValue(Args,
342// OPT_fconstant_string_class);
343// Opts.ObjCNonFragileABI = Args.hasArg(OPT_fobjc_nonfragile_abi);
344// Opts.CatchUndefined = Args.hasArg(OPT_fcatch_undefined_behavior);
345// Opts.EmitAllDecls = Args.hasArg(OPT_femit_all_decls);
346// Opts.PICLevel = getLastArgIntValue(Args, OPT_pic_level, 0, Diags);
347// Opts.Static = Args.hasArg(OPT_static_define);
348 Opts.OptimizeSize = 0;
349
350 // FIXME: Eliminate this dependency.
351// unsigned Opt =
352// Args.hasArg(OPT_Os) ? 2 : getLastArgIntValue(Args, OPT_O, 0, Diags);
353// Opts.Optimize = Opt != 0;
354 unsigned Opt = 0;
355
356 // This is the __NO_INLINE__ define, which just depends on things like the
357 // optimization level and -fno-inline, not actually whether the backend has
358 // inlining enabled.
359 //
360 // FIXME: This is affected by other options (-fno-inline).
Sean Callanan3d654b32012-09-24 22:25:51 +0000361 Opts.NoInlineDefine = !Opt;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000362
363// unsigned SSP = getLastArgIntValue(Args, OPT_stack_protector, 0, Diags);
364// switch (SSP) {
365// default:
366// Diags.Report(diag::err_drv_invalid_value)
367// << Args.getLastArg(OPT_stack_protector)->getAsString(Args) << SSP;
368// break;
369// case 0: Opts.setStackProtectorMode(LangOptions::SSPOff); break;
370// case 1: Opts.setStackProtectorMode(LangOptions::SSPOn); break;
371// case 2: Opts.setStackProtectorMode(LangOptions::SSPReq); break;
372// }
373}
374
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000375
Greg Clayton6beaaa62011-01-17 03:46:26 +0000376ClangASTContext::ClangASTContext (const char *target_triple) :
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000377 m_target_triple(),
Greg Clayton6beaaa62011-01-17 03:46:26 +0000378 m_ast_ap(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000379 m_language_options_ap(),
380 m_source_manager_ap(),
Sean Callanan880e6802011-10-07 23:18:13 +0000381 m_diagnostics_engine_ap(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000382 m_target_options_ap(),
383 m_target_info_ap(),
384 m_identifier_table_ap(),
385 m_selector_table_ap(),
Greg Clayton6beaaa62011-01-17 03:46:26 +0000386 m_builtins_ap(),
387 m_callback_tag_decl (NULL),
388 m_callback_objc_decl (NULL),
389 m_callback_baton (NULL)
390
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000391{
392 if (target_triple && target_triple[0])
Greg Clayton880cbb02011-07-30 01:26:02 +0000393 SetTargetTriple (target_triple);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000394}
395
396//----------------------------------------------------------------------
397// Destructor
398//----------------------------------------------------------------------
399ClangASTContext::~ClangASTContext()
400{
401 m_builtins_ap.reset();
402 m_selector_table_ap.reset();
403 m_identifier_table_ap.reset();
404 m_target_info_ap.reset();
405 m_target_options_ap.reset();
Sean Callanan880e6802011-10-07 23:18:13 +0000406 m_diagnostics_engine_ap.reset();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000407 m_source_manager_ap.reset();
408 m_language_options_ap.reset();
Greg Clayton6beaaa62011-01-17 03:46:26 +0000409 m_ast_ap.reset();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000410}
411
412
413void
414ClangASTContext::Clear()
415{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000416 m_ast_ap.reset();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000417 m_language_options_ap.reset();
418 m_source_manager_ap.reset();
Sean Callanan880e6802011-10-07 23:18:13 +0000419 m_diagnostics_engine_ap.reset();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000420 m_target_options_ap.reset();
421 m_target_info_ap.reset();
422 m_identifier_table_ap.reset();
423 m_selector_table_ap.reset();
424 m_builtins_ap.reset();
425}
426
427const char *
428ClangASTContext::GetTargetTriple ()
429{
430 return m_target_triple.c_str();
431}
432
433void
434ClangASTContext::SetTargetTriple (const char *target_triple)
435{
436 Clear();
437 m_target_triple.assign(target_triple);
438}
439
Greg Clayton514487e2011-02-15 21:59:32 +0000440void
441ClangASTContext::SetArchitecture (const ArchSpec &arch)
442{
Greg Clayton880cbb02011-07-30 01:26:02 +0000443 SetTargetTriple(arch.GetTriple().str().c_str());
Greg Clayton514487e2011-02-15 21:59:32 +0000444}
445
Greg Clayton6beaaa62011-01-17 03:46:26 +0000446bool
447ClangASTContext::HasExternalSource ()
448{
449 ASTContext *ast = getASTContext();
450 if (ast)
451 return ast->getExternalSource () != NULL;
452 return false;
453}
454
455void
456ClangASTContext::SetExternalSource (llvm::OwningPtr<ExternalASTSource> &ast_source_ap)
457{
458 ASTContext *ast = getASTContext();
459 if (ast)
460 {
461 ast->setExternalSource (ast_source_ap);
462 ast->getTranslationUnitDecl()->setHasExternalLexicalStorage(true);
463 //ast->getTranslationUnitDecl()->setHasExternalVisibleStorage(true);
464 }
465}
466
467void
468ClangASTContext::RemoveExternalSource ()
469{
470 ASTContext *ast = getASTContext();
471
472 if (ast)
473 {
474 llvm::OwningPtr<ExternalASTSource> empty_ast_source_ap;
475 ast->setExternalSource (empty_ast_source_ap);
476 ast->getTranslationUnitDecl()->setHasExternalLexicalStorage(false);
477 //ast->getTranslationUnitDecl()->setHasExternalVisibleStorage(false);
478 }
479}
480
481
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000482
483ASTContext *
484ClangASTContext::getASTContext()
485{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000486 if (m_ast_ap.get() == NULL)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000487 {
Greg Clayton6beaaa62011-01-17 03:46:26 +0000488 m_ast_ap.reset(new ASTContext (*getLanguageOptions(),
489 *getSourceManager(),
Sean Callanan880e6802011-10-07 23:18:13 +0000490 getTargetInfo(),
Greg Clayton6beaaa62011-01-17 03:46:26 +0000491 *getIdentifierTable(),
492 *getSelectorTable(),
493 *getBuiltinContext(),
494 0));
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000495
Greg Clayton6beaaa62011-01-17 03:46:26 +0000496 if ((m_callback_tag_decl || m_callback_objc_decl) && m_callback_baton)
497 {
498 m_ast_ap->getTranslationUnitDecl()->setHasExternalLexicalStorage();
499 //m_ast_ap->getTranslationUnitDecl()->setHasExternalVisibleStorage();
500 }
501
Sean Callanan880e6802011-10-07 23:18:13 +0000502 m_ast_ap->getDiagnostics().setClient(getDiagnosticConsumer(), false);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000503 }
Greg Clayton6beaaa62011-01-17 03:46:26 +0000504 return m_ast_ap.get();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000505}
506
507Builtin::Context *
508ClangASTContext::getBuiltinContext()
509{
510 if (m_builtins_ap.get() == NULL)
Sean Callanan880e6802011-10-07 23:18:13 +0000511 m_builtins_ap.reset (new Builtin::Context());
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000512 return m_builtins_ap.get();
513}
514
515IdentifierTable *
516ClangASTContext::getIdentifierTable()
517{
518 if (m_identifier_table_ap.get() == NULL)
519 m_identifier_table_ap.reset(new IdentifierTable (*ClangASTContext::getLanguageOptions(), NULL));
520 return m_identifier_table_ap.get();
521}
522
523LangOptions *
524ClangASTContext::getLanguageOptions()
525{
526 if (m_language_options_ap.get() == NULL)
527 {
528 m_language_options_ap.reset(new LangOptions());
Greg Clayton94e5d782010-06-13 17:34:29 +0000529 ParseLangArgs(*m_language_options_ap, IK_ObjCXX);
530// InitializeLangOptions(*m_language_options_ap, IK_ObjCXX);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000531 }
532 return m_language_options_ap.get();
533}
534
535SelectorTable *
536ClangASTContext::getSelectorTable()
537{
538 if (m_selector_table_ap.get() == NULL)
539 m_selector_table_ap.reset (new SelectorTable());
540 return m_selector_table_ap.get();
541}
542
Sean Callanan79439e82010-11-18 02:56:27 +0000543clang::FileManager *
544ClangASTContext::getFileManager()
545{
546 if (m_file_manager_ap.get() == NULL)
Greg Clayton38a61402010-12-02 23:20:03 +0000547 {
548 clang::FileSystemOptions file_system_options;
549 m_file_manager_ap.reset(new clang::FileManager(file_system_options));
550 }
Sean Callanan79439e82010-11-18 02:56:27 +0000551 return m_file_manager_ap.get();
552}
553
Greg Claytone1a916a2010-07-21 22:12:05 +0000554clang::SourceManager *
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000555ClangASTContext::getSourceManager()
556{
557 if (m_source_manager_ap.get() == NULL)
Sean Callanan880e6802011-10-07 23:18:13 +0000558 m_source_manager_ap.reset(new clang::SourceManager(*getDiagnosticsEngine(), *getFileManager()));
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000559 return m_source_manager_ap.get();
560}
561
Sean Callanan880e6802011-10-07 23:18:13 +0000562clang::DiagnosticsEngine *
563ClangASTContext::getDiagnosticsEngine()
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000564{
Sean Callanan880e6802011-10-07 23:18:13 +0000565 if (m_diagnostics_engine_ap.get() == NULL)
Greg Claytona651b532010-11-19 21:46:54 +0000566 {
567 llvm::IntrusiveRefCntPtr<DiagnosticIDs> diag_id_sp(new DiagnosticIDs());
Sean Callanan880e6802011-10-07 23:18:13 +0000568 m_diagnostics_engine_ap.reset(new DiagnosticsEngine(diag_id_sp));
Greg Claytona651b532010-11-19 21:46:54 +0000569 }
Sean Callanan880e6802011-10-07 23:18:13 +0000570 return m_diagnostics_engine_ap.get();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000571}
572
Sean Callanan880e6802011-10-07 23:18:13 +0000573class NullDiagnosticConsumer : public DiagnosticConsumer
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000574{
575public:
Sean Callanan880e6802011-10-07 23:18:13 +0000576 NullDiagnosticConsumer ()
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000577 {
578 m_log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS);
579 }
580
Sean Callanan880e6802011-10-07 23:18:13 +0000581 void HandleDiagnostic (DiagnosticsEngine::Level DiagLevel, const Diagnostic &info)
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000582 {
583 if (m_log)
584 {
Sean Callanan5b26f272012-02-04 08:49:35 +0000585 llvm::SmallVector<char, 32> diag_str(10);
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000586 info.FormatDiagnostic(diag_str);
587 diag_str.push_back('\0');
588 m_log->Printf("Compiler diagnostic: %s\n", diag_str.data());
589 }
590 }
Sean Callanan880e6802011-10-07 23:18:13 +0000591
592 DiagnosticConsumer *clone (DiagnosticsEngine &Diags) const
593 {
594 return new NullDiagnosticConsumer ();
595 }
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000596private:
597 LogSP m_log;
598};
599
Sean Callanan880e6802011-10-07 23:18:13 +0000600DiagnosticConsumer *
601ClangASTContext::getDiagnosticConsumer()
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000602{
Sean Callanan880e6802011-10-07 23:18:13 +0000603 if (m_diagnostic_consumer_ap.get() == NULL)
604 m_diagnostic_consumer_ap.reset(new NullDiagnosticConsumer);
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000605
Sean Callanan880e6802011-10-07 23:18:13 +0000606 return m_diagnostic_consumer_ap.get();
Sean Callanan7fddd4c2010-12-11 00:08:56 +0000607}
608
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000609TargetOptions *
610ClangASTContext::getTargetOptions()
611{
612 if (m_target_options_ap.get() == NULL && !m_target_triple.empty())
613 {
614 m_target_options_ap.reset (new TargetOptions());
615 if (m_target_options_ap.get())
616 m_target_options_ap->Triple = m_target_triple;
617 }
618 return m_target_options_ap.get();
619}
620
621
622TargetInfo *
623ClangASTContext::getTargetInfo()
624{
Greg Clayton70512312012-05-08 01:45:38 +0000625 // target_triple should be something like "x86_64-apple-macosx"
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000626 if (m_target_info_ap.get() == NULL && !m_target_triple.empty())
Sean Callanan880e6802011-10-07 23:18:13 +0000627 m_target_info_ap.reset (TargetInfo::CreateTargetInfo(*getDiagnosticsEngine(), *getTargetOptions()));
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000628 return m_target_info_ap.get();
629}
630
631#pragma mark Basic Types
632
633static inline bool
Greg Clayton6beaaa62011-01-17 03:46:26 +0000634QualTypeMatchesBitSize(const uint64_t bit_size, ASTContext *ast, QualType qual_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000635{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000636 uint64_t qual_type_bit_size = ast->getTypeSize(qual_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000637 if (qual_type_bit_size == bit_size)
638 return true;
639 return false;
640}
641
Greg Clayton1be10fc2010-09-29 01:12:09 +0000642clang_type_t
Greg Claytonc86103d2010-08-05 01:57:25 +0000643ClangASTContext::GetBuiltinTypeForEncodingAndBitSize (Encoding encoding, uint32_t bit_size)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000644{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000645 ASTContext *ast = getASTContext();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000646
Greg Clayton6beaaa62011-01-17 03:46:26 +0000647 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000648
Greg Clayton6beaaa62011-01-17 03:46:26 +0000649 return GetBuiltinTypeForEncodingAndBitSize (ast, encoding, bit_size);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000650}
651
Greg Clayton1be10fc2010-09-29 01:12:09 +0000652clang_type_t
Greg Clayton6beaaa62011-01-17 03:46:26 +0000653ClangASTContext::GetBuiltinTypeForEncodingAndBitSize (ASTContext *ast, Encoding encoding, uint32_t bit_size)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000654{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000655 if (!ast)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000656 return NULL;
657
658 switch (encoding)
659 {
Greg Claytonc86103d2010-08-05 01:57:25 +0000660 case eEncodingInvalid:
Greg Clayton6beaaa62011-01-17 03:46:26 +0000661 if (QualTypeMatchesBitSize (bit_size, ast, ast->VoidPtrTy))
662 return ast->VoidPtrTy.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000663 break;
664
Greg Claytonc86103d2010-08-05 01:57:25 +0000665 case eEncodingUint:
Greg Clayton6beaaa62011-01-17 03:46:26 +0000666 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedCharTy))
667 return ast->UnsignedCharTy.getAsOpaquePtr();
668 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedShortTy))
669 return ast->UnsignedShortTy.getAsOpaquePtr();
670 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedIntTy))
671 return ast->UnsignedIntTy.getAsOpaquePtr();
672 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongTy))
673 return ast->UnsignedLongTy.getAsOpaquePtr();
674 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongLongTy))
675 return ast->UnsignedLongLongTy.getAsOpaquePtr();
676 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedInt128Ty))
677 return ast->UnsignedInt128Ty.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000678 break;
679
Greg Claytonc86103d2010-08-05 01:57:25 +0000680 case eEncodingSint:
Greg Clayton6beaaa62011-01-17 03:46:26 +0000681 if (QualTypeMatchesBitSize (bit_size, ast, ast->CharTy))
682 return ast->CharTy.getAsOpaquePtr();
683 if (QualTypeMatchesBitSize (bit_size, ast, ast->ShortTy))
684 return ast->ShortTy.getAsOpaquePtr();
685 if (QualTypeMatchesBitSize (bit_size, ast, ast->IntTy))
686 return ast->IntTy.getAsOpaquePtr();
687 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongTy))
688 return ast->LongTy.getAsOpaquePtr();
689 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongLongTy))
690 return ast->LongLongTy.getAsOpaquePtr();
691 if (QualTypeMatchesBitSize (bit_size, ast, ast->Int128Ty))
692 return ast->Int128Ty.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000693 break;
694
Greg Claytonc86103d2010-08-05 01:57:25 +0000695 case eEncodingIEEE754:
Greg Clayton6beaaa62011-01-17 03:46:26 +0000696 if (QualTypeMatchesBitSize (bit_size, ast, ast->FloatTy))
697 return ast->FloatTy.getAsOpaquePtr();
698 if (QualTypeMatchesBitSize (bit_size, ast, ast->DoubleTy))
699 return ast->DoubleTy.getAsOpaquePtr();
700 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongDoubleTy))
701 return ast->LongDoubleTy.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000702 break;
703
Greg Claytonc86103d2010-08-05 01:57:25 +0000704 case eEncodingVector:
Johnny Chenc79c93a2012-03-07 01:12:24 +0000705 // Sanity check that bit_size is a multiple of 8's.
706 if (bit_size && !(bit_size & 0x7u))
707 return ast->getExtVectorType (ast->UnsignedCharTy, bit_size/8).getAsOpaquePtr();
708 break;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000709 default:
710 break;
711 }
712
713 return NULL;
714}
715
Greg Clayton1be10fc2010-09-29 01:12:09 +0000716clang_type_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000717ClangASTContext::GetBuiltinTypeForDWARFEncodingAndBitSize (const char *type_name, uint32_t dw_ate, uint32_t bit_size)
718{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000719 ASTContext *ast = getASTContext();
Sean Callanan38d4df52012-04-03 01:10:10 +0000720
721#define streq(a,b) strcmp(a,b) == 0
Greg Clayton6beaaa62011-01-17 03:46:26 +0000722 assert (ast != NULL);
723 if (ast)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000724 {
725 switch (dw_ate)
726 {
Sean Callanan38d4df52012-04-03 01:10:10 +0000727 default:
728 break;
Greg Clayton605684e2011-10-28 23:06:08 +0000729
Sean Callanan38d4df52012-04-03 01:10:10 +0000730 case DW_ATE_address:
731 if (QualTypeMatchesBitSize (bit_size, ast, ast->VoidPtrTy))
732 return ast->VoidPtrTy.getAsOpaquePtr();
733 break;
734
735 case DW_ATE_boolean:
736 if (QualTypeMatchesBitSize (bit_size, ast, ast->BoolTy))
737 return ast->BoolTy.getAsOpaquePtr();
738 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedCharTy))
739 return ast->UnsignedCharTy.getAsOpaquePtr();
740 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedShortTy))
741 return ast->UnsignedShortTy.getAsOpaquePtr();
742 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedIntTy))
743 return ast->UnsignedIntTy.getAsOpaquePtr();
744 break;
745
746 case DW_ATE_lo_user:
747 // This has been seen to mean DW_AT_complex_integer
748 if (type_name)
Greg Clayton605684e2011-10-28 23:06:08 +0000749 {
Sean Callanan38d4df52012-04-03 01:10:10 +0000750 if (::strstr(type_name, "complex"))
751 {
752 clang_type_t complex_int_clang_type = GetBuiltinTypeForDWARFEncodingAndBitSize ("int", DW_ATE_signed, bit_size/2);
753 return ast->getComplexType (QualType::getFromOpaquePtr(complex_int_clang_type)).getAsOpaquePtr();
754 }
Greg Clayton605684e2011-10-28 23:06:08 +0000755 }
Sean Callanan38d4df52012-04-03 01:10:10 +0000756 break;
757
758 case DW_ATE_complex_float:
759 if (QualTypeMatchesBitSize (bit_size, ast, ast->FloatComplexTy))
760 return ast->FloatComplexTy.getAsOpaquePtr();
761 else if (QualTypeMatchesBitSize (bit_size, ast, ast->DoubleComplexTy))
762 return ast->DoubleComplexTy.getAsOpaquePtr();
763 else if (QualTypeMatchesBitSize (bit_size, ast, ast->LongDoubleComplexTy))
764 return ast->LongDoubleComplexTy.getAsOpaquePtr();
765 else
Greg Clayton605684e2011-10-28 23:06:08 +0000766 {
Sean Callanan38d4df52012-04-03 01:10:10 +0000767 clang_type_t complex_float_clang_type = GetBuiltinTypeForDWARFEncodingAndBitSize ("float", DW_ATE_float, bit_size/2);
768 return ast->getComplexType (QualType::getFromOpaquePtr(complex_float_clang_type)).getAsOpaquePtr();
Greg Clayton605684e2011-10-28 23:06:08 +0000769 }
Sean Callanan38d4df52012-04-03 01:10:10 +0000770 break;
771
772 case DW_ATE_float:
773 if (QualTypeMatchesBitSize (bit_size, ast, ast->FloatTy))
774 return ast->FloatTy.getAsOpaquePtr();
775 if (QualTypeMatchesBitSize (bit_size, ast, ast->DoubleTy))
776 return ast->DoubleTy.getAsOpaquePtr();
777 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongDoubleTy))
778 return ast->LongDoubleTy.getAsOpaquePtr();
779 break;
780
781 case DW_ATE_signed:
782 if (type_name)
783 {
784 if (streq(type_name, "wchar_t") &&
785 QualTypeMatchesBitSize (bit_size, ast, ast->WCharTy))
786 return ast->WCharTy.getAsOpaquePtr();
787 if (streq(type_name, "void") &&
788 QualTypeMatchesBitSize (bit_size, ast, ast->VoidTy))
789 return ast->VoidTy.getAsOpaquePtr();
790 if (strstr(type_name, "long long") &&
791 QualTypeMatchesBitSize (bit_size, ast, ast->LongLongTy))
792 return ast->LongLongTy.getAsOpaquePtr();
793 if (strstr(type_name, "long") &&
794 QualTypeMatchesBitSize (bit_size, ast, ast->LongTy))
795 return ast->LongTy.getAsOpaquePtr();
796 if (strstr(type_name, "short") &&
797 QualTypeMatchesBitSize (bit_size, ast, ast->ShortTy))
798 return ast->ShortTy.getAsOpaquePtr();
799 if (strstr(type_name, "char"))
800 {
801 if (QualTypeMatchesBitSize (bit_size, ast, ast->CharTy))
802 return ast->CharTy.getAsOpaquePtr();
803 if (QualTypeMatchesBitSize (bit_size, ast, ast->SignedCharTy))
804 return ast->SignedCharTy.getAsOpaquePtr();
805 }
806 if (strstr(type_name, "int"))
807 {
808 if (QualTypeMatchesBitSize (bit_size, ast, ast->IntTy))
809 return ast->IntTy.getAsOpaquePtr();
810 if (QualTypeMatchesBitSize (bit_size, ast, ast->Int128Ty))
811 return ast->Int128Ty.getAsOpaquePtr();
812 }
813 }
814 // We weren't able to match up a type name, just search by size
815 if (QualTypeMatchesBitSize (bit_size, ast, ast->CharTy))
816 return ast->CharTy.getAsOpaquePtr();
817 if (QualTypeMatchesBitSize (bit_size, ast, ast->ShortTy))
818 return ast->ShortTy.getAsOpaquePtr();
819 if (QualTypeMatchesBitSize (bit_size, ast, ast->IntTy))
820 return ast->IntTy.getAsOpaquePtr();
821 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongTy))
822 return ast->LongTy.getAsOpaquePtr();
823 if (QualTypeMatchesBitSize (bit_size, ast, ast->LongLongTy))
824 return ast->LongLongTy.getAsOpaquePtr();
825 if (QualTypeMatchesBitSize (bit_size, ast, ast->Int128Ty))
826 return ast->Int128Ty.getAsOpaquePtr();
827 break;
828
829 case DW_ATE_signed_char:
830 if (type_name)
831 {
832 if (streq(type_name, "signed char"))
833 {
834 if (QualTypeMatchesBitSize (bit_size, ast, ast->SignedCharTy))
835 return ast->SignedCharTy.getAsOpaquePtr();
836 }
837 }
838 if (QualTypeMatchesBitSize (bit_size, ast, ast->CharTy))
839 return ast->CharTy.getAsOpaquePtr();
840 if (QualTypeMatchesBitSize (bit_size, ast, ast->SignedCharTy))
841 return ast->SignedCharTy.getAsOpaquePtr();
842 break;
843
844 case DW_ATE_unsigned:
845 if (type_name)
846 {
847 if (strstr(type_name, "long long"))
848 {
849 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongLongTy))
850 return ast->UnsignedLongLongTy.getAsOpaquePtr();
851 }
852 else if (strstr(type_name, "long"))
853 {
854 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongTy))
855 return ast->UnsignedLongTy.getAsOpaquePtr();
856 }
857 else if (strstr(type_name, "short"))
858 {
859 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedShortTy))
860 return ast->UnsignedShortTy.getAsOpaquePtr();
861 }
862 else if (strstr(type_name, "char"))
863 {
864 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedCharTy))
865 return ast->UnsignedCharTy.getAsOpaquePtr();
866 }
867 else if (strstr(type_name, "int"))
868 {
869 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedIntTy))
870 return ast->UnsignedIntTy.getAsOpaquePtr();
871 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedInt128Ty))
872 return ast->UnsignedInt128Ty.getAsOpaquePtr();
873 }
874 }
875 // We weren't able to match up a type name, just search by size
876 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedCharTy))
877 return ast->UnsignedCharTy.getAsOpaquePtr();
878 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedShortTy))
879 return ast->UnsignedShortTy.getAsOpaquePtr();
880 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedIntTy))
881 return ast->UnsignedIntTy.getAsOpaquePtr();
882 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongTy))
883 return ast->UnsignedLongTy.getAsOpaquePtr();
884 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedLongLongTy))
885 return ast->UnsignedLongLongTy.getAsOpaquePtr();
886 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedInt128Ty))
887 return ast->UnsignedInt128Ty.getAsOpaquePtr();
888 break;
889
890 case DW_ATE_unsigned_char:
891 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedCharTy))
892 return ast->UnsignedCharTy.getAsOpaquePtr();
893 if (QualTypeMatchesBitSize (bit_size, ast, ast->UnsignedShortTy))
894 return ast->UnsignedShortTy.getAsOpaquePtr();
895 break;
896
897 case DW_ATE_imaginary_float:
898 break;
899
900 case DW_ATE_UTF:
901 if (type_name)
902 {
903 if (streq(type_name, "char16_t"))
904 {
905 return ast->Char16Ty.getAsOpaquePtr();
906 }
907 else if (streq(type_name, "char32_t"))
908 {
909 return ast->Char32Ty.getAsOpaquePtr();
910 }
911 }
912 break;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000913 }
914 }
915 // This assert should fire for anything that we don't catch above so we know
916 // to fix any issues we run into.
Greg Claytondc968d12011-05-17 18:15:05 +0000917 if (type_name)
918 {
Greg Claytone38a5ed2012-01-05 03:57:59 +0000919 Host::SystemLog (Host::eSystemLogError, "error: need to add support for DW_TAG_base_type '%s' encoded with DW_ATE = 0x%x, bit_size = %u\n", type_name, dw_ate, bit_size);
Greg Claytondc968d12011-05-17 18:15:05 +0000920 }
921 else
922 {
Greg Claytone38a5ed2012-01-05 03:57:59 +0000923 Host::SystemLog (Host::eSystemLogError, "error: need to add support for DW_TAG_base_type encoded with DW_ATE = 0x%x, bit_size = %u\n", dw_ate, bit_size);
Greg Claytondc968d12011-05-17 18:15:05 +0000924 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000925 return NULL;
926}
927
Greg Clayton1be10fc2010-09-29 01:12:09 +0000928clang_type_t
Greg Clayton6beaaa62011-01-17 03:46:26 +0000929ClangASTContext::GetBuiltInType_void(ASTContext *ast)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000930{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000931 return ast->VoidTy.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000932}
933
Greg Clayton1be10fc2010-09-29 01:12:09 +0000934clang_type_t
Sean Callananf7c3e272010-11-19 02:52:21 +0000935ClangASTContext::GetBuiltInType_bool()
936{
937 return getASTContext()->BoolTy.getAsOpaquePtr();
938}
939
940clang_type_t
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000941ClangASTContext::GetBuiltInType_objc_id()
942{
Sean Callanand5c17ed2011-11-15 02:11:17 +0000943 return getASTContext()->getObjCIdType().getAsOpaquePtr();
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000944}
945
Greg Clayton1be10fc2010-09-29 01:12:09 +0000946clang_type_t
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000947ClangASTContext::GetBuiltInType_objc_Class()
948{
Sean Callanand5c17ed2011-11-15 02:11:17 +0000949 return getASTContext()->getObjCClassType().getAsOpaquePtr();
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000950}
951
Greg Clayton1be10fc2010-09-29 01:12:09 +0000952clang_type_t
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000953ClangASTContext::GetBuiltInType_objc_selector()
954{
Sean Callanand5c17ed2011-11-15 02:11:17 +0000955 return getASTContext()->getObjCSelType().getAsOpaquePtr();
Greg Claytonb0b9fe62010-08-03 00:35:52 +0000956}
957
Greg Clayton1be10fc2010-09-29 01:12:09 +0000958clang_type_t
Sean Callanan77502262011-05-12 23:54:16 +0000959ClangASTContext::GetUnknownAnyType(clang::ASTContext *ast)
960{
961 return ast->UnknownAnyTy.getAsOpaquePtr();
962}
963
964clang_type_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000965ClangASTContext::GetCStringType (bool is_const)
966{
967 QualType char_type(getASTContext()->CharTy);
968
969 if (is_const)
970 char_type.addConst();
971
972 return getASTContext()->getPointerType(char_type).getAsOpaquePtr();
973}
974
Greg Clayton1be10fc2010-09-29 01:12:09 +0000975clang_type_t
Sean Callanana6582262012-04-05 00:12:52 +0000976ClangASTContext::GetVoidType()
977{
978 return GetVoidType(getASTContext());
979}
980
981clang_type_t
982ClangASTContext::GetVoidType(ASTContext *ast)
983{
984 return ast->VoidTy.getAsOpaquePtr();
985}
986
987clang_type_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000988ClangASTContext::GetVoidPtrType (bool is_const)
989{
990 return GetVoidPtrType(getASTContext(), is_const);
991}
992
Greg Clayton1be10fc2010-09-29 01:12:09 +0000993clang_type_t
Greg Clayton6beaaa62011-01-17 03:46:26 +0000994ClangASTContext::GetVoidPtrType (ASTContext *ast, bool is_const)
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000995{
Greg Clayton6beaaa62011-01-17 03:46:26 +0000996 QualType void_ptr_type(ast->VoidPtrTy);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000997
998 if (is_const)
999 void_ptr_type.addConst();
1000
1001 return void_ptr_type.getAsOpaquePtr();
1002}
1003
Sean Callanan09ab4b72011-11-30 22:11:59 +00001004clang::DeclContext *
1005ClangASTContext::GetTranslationUnitDecl (clang::ASTContext *ast)
1006{
1007 return ast->getTranslationUnitDecl();
1008}
1009
Greg Clayton1be10fc2010-09-29 01:12:09 +00001010clang_type_t
Greg Clayton38a61402010-12-02 23:20:03 +00001011ClangASTContext::CopyType (ASTContext *dst_ast,
1012 ASTContext *src_ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00001013 clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001014{
Sean Callanan79439e82010-11-18 02:56:27 +00001015 FileSystemOptions file_system_options;
Greg Clayton38a61402010-12-02 23:20:03 +00001016 FileManager file_manager (file_system_options);
1017 ASTImporter importer(*dst_ast, file_manager,
Sean Callanan2c777c42011-01-18 23:32:05 +00001018 *src_ast, file_manager,
1019 false);
Sean Callanan0617fcb2010-11-09 22:37:10 +00001020
Greg Clayton38a61402010-12-02 23:20:03 +00001021 QualType src (QualType::getFromOpaquePtr(clang_type));
1022 QualType dst (importer.Import(src));
Sean Callanan0617fcb2010-11-09 22:37:10 +00001023
1024 return dst.getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001025}
1026
Greg Clayton526e5af2010-11-13 03:52:47 +00001027
1028clang::Decl *
Greg Clayton38a61402010-12-02 23:20:03 +00001029ClangASTContext::CopyDecl (ASTContext *dst_ast,
1030 ASTContext *src_ast,
Greg Clayton526e5af2010-11-13 03:52:47 +00001031 clang::Decl *source_decl)
Sean Callanan7fddd4c2010-12-11 00:08:56 +00001032{
Sean Callanan79439e82010-11-18 02:56:27 +00001033 FileSystemOptions file_system_options;
Greg Clayton38a61402010-12-02 23:20:03 +00001034 FileManager file_manager (file_system_options);
1035 ASTImporter importer(*dst_ast, file_manager,
Sean Callanan2c777c42011-01-18 23:32:05 +00001036 *src_ast, file_manager,
1037 false);
Greg Clayton526e5af2010-11-13 03:52:47 +00001038
1039 return importer.Import(source_decl);
1040}
1041
Sean Callanan23a30272010-07-16 00:00:27 +00001042bool
Greg Clayton84db9102012-03-26 23:03:23 +00001043ClangASTContext::AreTypesSame (ASTContext *ast,
1044 clang_type_t type1,
1045 clang_type_t type2,
1046 bool ignore_qualifiers)
Sean Callanan4dcca2622010-07-15 22:30:52 +00001047{
Greg Clayton55995eb2012-04-06 17:38:55 +00001048 if (type1 == type2)
1049 return true;
1050
Sean Callanan5056ab02012-02-18 02:01:03 +00001051 QualType type1_qual = QualType::getFromOpaquePtr(type1);
1052 QualType type2_qual = QualType::getFromOpaquePtr(type2);
1053
1054 if (ignore_qualifiers)
1055 {
1056 type1_qual = type1_qual.getUnqualifiedType();
1057 type2_qual = type2_qual.getUnqualifiedType();
1058 }
1059
1060 return ast->hasSameType (type1_qual,
1061 type2_qual);
Sean Callanan4dcca2622010-07-15 22:30:52 +00001062}
1063
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001064#pragma mark CVR modifiers
1065
Greg Clayton1be10fc2010-09-29 01:12:09 +00001066clang_type_t
1067ClangASTContext::AddConstModifier (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001068{
1069 if (clang_type)
1070 {
1071 QualType result(QualType::getFromOpaquePtr(clang_type));
1072 result.addConst();
1073 return result.getAsOpaquePtr();
1074 }
1075 return NULL;
1076}
1077
Greg Clayton1be10fc2010-09-29 01:12:09 +00001078clang_type_t
1079ClangASTContext::AddRestrictModifier (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001080{
1081 if (clang_type)
1082 {
1083 QualType result(QualType::getFromOpaquePtr(clang_type));
1084 result.getQualifiers().setRestrict (true);
1085 return result.getAsOpaquePtr();
1086 }
1087 return NULL;
1088}
1089
Greg Clayton1be10fc2010-09-29 01:12:09 +00001090clang_type_t
1091ClangASTContext::AddVolatileModifier (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001092{
1093 if (clang_type)
1094 {
1095 QualType result(QualType::getFromOpaquePtr(clang_type));
1096 result.getQualifiers().setVolatile (true);
1097 return result.getAsOpaquePtr();
1098 }
1099 return NULL;
1100}
1101
Greg Clayton6beaaa62011-01-17 03:46:26 +00001102
1103clang_type_t
1104ClangASTContext::GetTypeForDecl (TagDecl *decl)
1105{
1106 // No need to call the getASTContext() accessor (which can create the AST
1107 // if it isn't created yet, because we can't have created a decl in this
1108 // AST if our AST didn't already exist...
1109 if (m_ast_ap.get())
1110 return m_ast_ap->getTagDeclType(decl).getAsOpaquePtr();
1111 return NULL;
1112}
1113
1114clang_type_t
1115ClangASTContext::GetTypeForDecl (ObjCInterfaceDecl *decl)
1116{
1117 // No need to call the getASTContext() accessor (which can create the AST
1118 // if it isn't created yet, because we can't have created a decl in this
1119 // AST if our AST didn't already exist...
1120 if (m_ast_ap.get())
1121 return m_ast_ap->getObjCInterfaceType(decl).getAsOpaquePtr();
1122 return NULL;
1123}
1124
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001125#pragma mark Structure, Unions, Classes
1126
Greg Clayton1be10fc2010-09-29 01:12:09 +00001127clang_type_t
Sean Callananad880762012-04-18 01:06:17 +00001128ClangASTContext::CreateRecordType (DeclContext *decl_ctx, AccessType access_type, const char *name, int kind, LanguageType language, uint64_t metadata)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001129{
Greg Clayton6beaaa62011-01-17 03:46:26 +00001130 ASTContext *ast = getASTContext();
1131 assert (ast != NULL);
Sean Callananad880762012-04-18 01:06:17 +00001132
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001133 if (decl_ctx == NULL)
Greg Clayton6beaaa62011-01-17 03:46:26 +00001134 decl_ctx = ast->getTranslationUnitDecl();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001135
Greg Clayton9e409562010-07-28 02:04:09 +00001136
Greg Claytone1be9962011-08-24 23:50:00 +00001137 if (language == eLanguageTypeObjC || language == eLanguageTypeObjC_plus_plus)
Greg Clayton9e409562010-07-28 02:04:09 +00001138 {
Greg Claytonaaf99e02010-10-11 02:25:34 +00001139 bool isForwardDecl = true;
Greg Clayton9e409562010-07-28 02:04:09 +00001140 bool isInternal = false;
Sean Callananad880762012-04-18 01:06:17 +00001141 return CreateObjCClass (name, decl_ctx, isForwardDecl, isInternal, metadata);
Greg Clayton9e409562010-07-28 02:04:09 +00001142 }
1143
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001144 // NOTE: Eventually CXXRecordDecl will be merged back into RecordDecl and
1145 // we will need to update this code. I was told to currently always use
1146 // the CXXRecordDecl class since we often don't know from debug information
1147 // if something is struct or a class, so we default to always use the more
1148 // complete definition just in case.
Greg Claytonf0705c82011-10-22 03:33:13 +00001149 CXXRecordDecl *decl = CXXRecordDecl::Create (*ast,
1150 (TagDecl::TagKind)kind,
1151 decl_ctx,
1152 SourceLocation(),
1153 SourceLocation(),
1154 name && name[0] ? &ast->Idents.get(name) : NULL);
Sean Callanan7282e2a2012-01-13 22:10:18 +00001155
Sean Callananad880762012-04-18 01:06:17 +00001156 if (decl)
1157 SetMetadata(ast, (uintptr_t)decl, metadata);
Sean Callanan60217122012-04-13 00:10:03 +00001158
Greg Clayton55561e92011-10-26 03:31:36 +00001159 if (decl_ctx)
1160 {
1161 if (access_type != eAccessNone)
1162 decl->setAccess (ConvertAccessTypeToAccessSpecifier (access_type));
1163 decl_ctx->addDecl (decl);
1164 }
Greg Clayton6beaaa62011-01-17 03:46:26 +00001165 return ast->getTagDeclType(decl).getAsOpaquePtr();
1166}
1167
Greg Clayton3c2e3ae2012-02-06 06:42:51 +00001168static TemplateParameterList *
1169CreateTemplateParameterList (ASTContext *ast,
Sean Callanan3d654b32012-09-24 22:25:51 +00001170 const ClangASTContext::TemplateParameterInfos &template_param_infos,
Greg Clayton3c2e3ae2012-02-06 06:42:51 +00001171 llvm::SmallVector<NamedDecl *, 8> &template_param_decls)
1172{
1173 const bool parameter_pack = false;
1174 const bool is_typename = false;
1175 const unsigned depth = 0;
1176 const size_t num_template_params = template_param_infos.GetSize();
1177 for (size_t i=0; i<num_template_params; ++i)
1178 {
1179 const char *name = template_param_infos.names[i];
Sean Callanan3d654b32012-09-24 22:25:51 +00001180 if (template_param_infos.args[i].getKind() == TemplateArgument::Integral)
Greg Clayton3c2e3ae2012-02-06 06:42:51 +00001181 {
1182 template_param_decls.push_back (NonTypeTemplateParmDecl::Create (*ast,
1183 ast->getTranslationUnitDecl(), // Is this the right decl context?, SourceLocation StartLoc,
1184 SourceLocation(),
1185 SourceLocation(),
1186 depth,
1187 i,
1188 &ast->Idents.get(name),
1189 template_param_infos.args[i].getIntegralType(),
1190 parameter_pack,
1191 NULL));
1192
1193 }
1194 else
1195 {
1196 template_param_decls.push_back (TemplateTypeParmDecl::Create (*ast,
1197 ast->getTranslationUnitDecl(), // Is this the right decl context?
1198 SourceLocation(),
1199 SourceLocation(),
1200 depth,
1201 i,
1202 &ast->Idents.get(name),
1203 is_typename,
1204 parameter_pack));
1205 }
1206 }
1207
1208 TemplateParameterList *template_param_list = TemplateParameterList::Create (*ast,
1209 SourceLocation(),
1210 SourceLocation(),
1211 &template_param_decls.front(),
1212 template_param_decls.size(),
1213 SourceLocation());
1214 return template_param_list;
1215}
1216
1217clang::FunctionTemplateDecl *
1218ClangASTContext::CreateFunctionTemplateDecl (clang::DeclContext *decl_ctx,
1219 clang::FunctionDecl *func_decl,
1220 const char *name,
1221 const TemplateParameterInfos &template_param_infos)
1222{
1223// /// \brief Create a function template node.
1224 ASTContext *ast = getASTContext();
1225
1226 llvm::SmallVector<NamedDecl *, 8> template_param_decls;
1227
1228 TemplateParameterList *template_param_list = CreateTemplateParameterList (ast,
1229 template_param_infos,
1230 template_param_decls);
1231 FunctionTemplateDecl *func_tmpl_decl = FunctionTemplateDecl::Create (*ast,
1232 decl_ctx,
1233 func_decl->getLocation(),
1234 func_decl->getDeclName(),
1235 template_param_list,
1236 func_decl);
1237
1238 for (size_t i=0, template_param_decl_count = template_param_decls.size();
1239 i < template_param_decl_count;
1240 ++i)
1241 {
1242 // TODO: verify which decl context we should put template_param_decls into..
1243 template_param_decls[i]->setDeclContext (func_decl);
1244 }
1245
1246 return func_tmpl_decl;
1247}
1248
1249void
1250ClangASTContext::CreateFunctionTemplateSpecializationInfo (FunctionDecl *func_decl,
1251 clang::FunctionTemplateDecl *func_tmpl_decl,
1252 const TemplateParameterInfos &infos)
1253{
1254 TemplateArgumentList template_args (TemplateArgumentList::OnStack,
1255 infos.args.data(),
1256 infos.args.size());
1257
1258 func_decl->setFunctionTemplateSpecialization (func_tmpl_decl,
1259 &template_args,
1260 NULL);
1261}
1262
1263
Greg Claytonf0705c82011-10-22 03:33:13 +00001264ClassTemplateDecl *
1265ClangASTContext::CreateClassTemplateDecl (DeclContext *decl_ctx,
Greg Clayton55561e92011-10-26 03:31:36 +00001266 lldb::AccessType access_type,
Greg Claytonf0705c82011-10-22 03:33:13 +00001267 const char *class_name,
1268 int kind,
1269 const TemplateParameterInfos &template_param_infos)
1270{
1271 ASTContext *ast = getASTContext();
1272
1273 ClassTemplateDecl *class_template_decl = NULL;
1274 if (decl_ctx == NULL)
1275 decl_ctx = ast->getTranslationUnitDecl();
1276
1277 IdentifierInfo &identifier_info = ast->Idents.get(class_name);
1278 DeclarationName decl_name (&identifier_info);
1279
1280 clang::DeclContext::lookup_result result = decl_ctx->lookup(decl_name);
1281 for (clang::DeclContext::lookup_iterator pos = result.first, end = result.second; pos != end; ++pos)
1282 {
1283 class_template_decl = dyn_cast<clang::ClassTemplateDecl>(*pos);
1284 if (class_template_decl)
1285 return class_template_decl;
1286 }
1287
1288 llvm::SmallVector<NamedDecl *, 8> template_param_decls;
Greg Claytonf0705c82011-10-22 03:33:13 +00001289
Greg Clayton3c2e3ae2012-02-06 06:42:51 +00001290 TemplateParameterList *template_param_list = CreateTemplateParameterList (ast,
1291 template_param_infos,
1292 template_param_decls);
Greg Claytonf0705c82011-10-22 03:33:13 +00001293
1294 CXXRecordDecl *template_cxx_decl = CXXRecordDecl::Create (*ast,
1295 (TagDecl::TagKind)kind,
1296 decl_ctx, // What decl context do we use here? TU? The actual decl context?
1297 SourceLocation(),
1298 SourceLocation(),
1299 &identifier_info);
Greg Claytone04741d2011-12-02 02:09:28 +00001300
1301 for (size_t i=0, template_param_decl_count = template_param_decls.size();
1302 i < template_param_decl_count;
1303 ++i)
1304 {
1305 template_param_decls[i]->setDeclContext (template_cxx_decl);
1306 }
1307
Sean Callananb5c79622011-11-19 01:35:08 +00001308 // With templated classes, we say that a class is templated with
1309 // specializations, but that the bare class has no functions.
1310 template_cxx_decl->startDefinition();
1311 template_cxx_decl->completeDefinition();
1312
Greg Claytonf0705c82011-10-22 03:33:13 +00001313 class_template_decl = ClassTemplateDecl::Create (*ast,
1314 decl_ctx, // What decl context do we use here? TU? The actual decl context?
1315 SourceLocation(),
1316 decl_name,
1317 template_param_list,
1318 template_cxx_decl,
1319 NULL);
1320
1321 if (class_template_decl)
Sean Callanan5e9e1992011-10-26 01:06:27 +00001322 {
Greg Clayton55561e92011-10-26 03:31:36 +00001323 if (access_type != eAccessNone)
1324 class_template_decl->setAccess (ConvertAccessTypeToAccessSpecifier (access_type));
Sean Callanan5b26f272012-02-04 08:49:35 +00001325
1326 //if (TagDecl *ctx_tag_decl = dyn_cast<TagDecl>(decl_ctx))
1327 // CompleteTagDeclarationDefinition(GetTypeForDecl(ctx_tag_decl));
1328
Greg Claytonf0705c82011-10-22 03:33:13 +00001329 decl_ctx->addDecl (class_template_decl);
Sean Callanan5e9e1992011-10-26 01:06:27 +00001330
1331#ifdef LLDB_CONFIGURATION_DEBUG
1332 VerifyDecl(class_template_decl);
1333#endif
1334 }
Greg Claytonf0705c82011-10-22 03:33:13 +00001335
1336 return class_template_decl;
1337}
1338
1339
1340ClassTemplateSpecializationDecl *
1341ClangASTContext::CreateClassTemplateSpecializationDecl (DeclContext *decl_ctx,
1342 ClassTemplateDecl *class_template_decl,
1343 int kind,
1344 const TemplateParameterInfos &template_param_infos)
1345{
1346 ASTContext *ast = getASTContext();
1347 ClassTemplateSpecializationDecl *class_template_specialization_decl = ClassTemplateSpecializationDecl::Create (*ast,
1348 (TagDecl::TagKind)kind,
1349 decl_ctx,
1350 SourceLocation(),
1351 SourceLocation(),
1352 class_template_decl,
1353 &template_param_infos.args.front(),
1354 template_param_infos.args.size(),
1355 NULL);
1356
1357 return class_template_specialization_decl;
1358}
1359
1360lldb::clang_type_t
1361ClangASTContext::CreateClassTemplateSpecializationType (ClassTemplateSpecializationDecl *class_template_specialization_decl)
1362{
1363 if (class_template_specialization_decl)
1364 {
1365 ASTContext *ast = getASTContext();
1366 if (ast)
1367 return ast->getTagDeclType(class_template_specialization_decl).getAsOpaquePtr();
1368 }
1369 return NULL;
1370}
1371
Greg Clayton6beaaa62011-01-17 03:46:26 +00001372bool
1373ClangASTContext::SetHasExternalStorage (clang_type_t clang_type, bool has_extern)
1374{
1375 if (clang_type == NULL)
1376 return false;
1377
1378 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
1379
1380 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
1381 switch (type_class)
1382 {
1383 case clang::Type::Record:
1384 {
1385 CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
1386 if (cxx_record_decl)
1387 {
1388 cxx_record_decl->setHasExternalLexicalStorage (has_extern);
Greg Claytonc432c192011-01-20 04:18:48 +00001389 cxx_record_decl->setHasExternalVisibleStorage (has_extern);
Greg Clayton6beaaa62011-01-17 03:46:26 +00001390 return true;
1391 }
1392 }
1393 break;
1394
1395 case clang::Type::Enum:
1396 {
1397 EnumDecl *enum_decl = cast<EnumType>(qual_type)->getDecl();
1398 if (enum_decl)
1399 {
1400 enum_decl->setHasExternalLexicalStorage (has_extern);
Greg Claytonc432c192011-01-20 04:18:48 +00001401 enum_decl->setHasExternalVisibleStorage (has_extern);
Greg Clayton6beaaa62011-01-17 03:46:26 +00001402 return true;
1403 }
1404 }
1405 break;
1406
1407 case clang::Type::ObjCObject:
1408 case clang::Type::ObjCInterface:
1409 {
Sean Callanan78e37602011-01-27 04:42:51 +00001410 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
Greg Clayton6beaaa62011-01-17 03:46:26 +00001411 assert (objc_class_type);
1412 if (objc_class_type)
1413 {
1414 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
1415
1416 if (class_interface_decl)
1417 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00001418 class_interface_decl->setHasExternalLexicalStorage (has_extern);
Greg Claytonc432c192011-01-20 04:18:48 +00001419 class_interface_decl->setHasExternalVisibleStorage (has_extern);
Greg Clayton6beaaa62011-01-17 03:46:26 +00001420 return true;
1421 }
1422 }
1423 }
1424 break;
1425
1426 case clang::Type::Typedef:
1427 return ClangASTContext::SetHasExternalStorage (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(), has_extern);
Sean Callanan912855f2011-08-11 23:56:13 +00001428
1429 case clang::Type::Elaborated:
1430 return ClangASTContext::SetHasExternalStorage (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(), has_extern);
Greg Clayton6beaaa62011-01-17 03:46:26 +00001431
1432 default:
1433 break;
1434 }
1435 return false;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001436}
1437
Greg Claytona3c444a2010-10-01 23:13:49 +00001438static bool
1439IsOperator (const char *name, OverloadedOperatorKind &op_kind)
1440{
1441 if (name == NULL || name[0] == '\0')
1442 return false;
1443
Sean Callanana43f20d2010-12-10 19:51:54 +00001444#define OPERATOR_PREFIX "operator"
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001445#define OPERATOR_PREFIX_LENGTH (sizeof (OPERATOR_PREFIX) - 1)
Sean Callananbfeff8c2010-12-10 02:15:55 +00001446
1447 const char *post_op_name = NULL;
1448
Sean Callanana43f20d2010-12-10 19:51:54 +00001449 bool no_space = true;
Sean Callananbfeff8c2010-12-10 02:15:55 +00001450
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001451 if (::strncmp(name, OPERATOR_PREFIX, OPERATOR_PREFIX_LENGTH))
Greg Claytona3c444a2010-10-01 23:13:49 +00001452 return false;
1453
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001454 post_op_name = name + OPERATOR_PREFIX_LENGTH;
1455
Sean Callanana43f20d2010-12-10 19:51:54 +00001456 if (post_op_name[0] == ' ')
1457 {
1458 post_op_name++;
1459 no_space = false;
1460 }
1461
1462#undef OPERATOR_PREFIX
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001463#undef OPERATOR_PREFIX_LENGTH
Sean Callanana43f20d2010-12-10 19:51:54 +00001464
Greg Claytona3c444a2010-10-01 23:13:49 +00001465 // This is an operator, set the overloaded operator kind to invalid
1466 // in case this is a conversion operator...
1467 op_kind = NUM_OVERLOADED_OPERATORS;
1468
1469 switch (post_op_name[0])
1470 {
Sean Callananbfeff8c2010-12-10 02:15:55 +00001471 default:
1472 if (no_space)
1473 return false;
1474 break;
Greg Claytona3c444a2010-10-01 23:13:49 +00001475 case 'n':
Sean Callananbfeff8c2010-12-10 02:15:55 +00001476 if (no_space)
1477 return false;
Greg Claytona3c444a2010-10-01 23:13:49 +00001478 if (strcmp (post_op_name, "new") == 0)
1479 op_kind = OO_New;
1480 else if (strcmp (post_op_name, "new[]") == 0)
1481 op_kind = OO_Array_New;
1482 break;
1483
1484 case 'd':
Sean Callananbfeff8c2010-12-10 02:15:55 +00001485 if (no_space)
1486 return false;
Greg Claytona3c444a2010-10-01 23:13:49 +00001487 if (strcmp (post_op_name, "delete") == 0)
1488 op_kind = OO_Delete;
1489 else if (strcmp (post_op_name, "delete[]") == 0)
1490 op_kind = OO_Array_Delete;
1491 break;
1492
1493 case '+':
1494 if (post_op_name[1] == '\0')
1495 op_kind = OO_Plus;
1496 else if (post_op_name[2] == '\0')
1497 {
1498 if (post_op_name[1] == '=')
1499 op_kind = OO_PlusEqual;
1500 else if (post_op_name[1] == '+')
1501 op_kind = OO_PlusPlus;
1502 }
1503 break;
1504
1505 case '-':
1506 if (post_op_name[1] == '\0')
1507 op_kind = OO_Minus;
1508 else if (post_op_name[2] == '\0')
1509 {
1510 switch (post_op_name[1])
1511 {
1512 case '=': op_kind = OO_MinusEqual; break;
1513 case '-': op_kind = OO_MinusMinus; break;
1514 case '>': op_kind = OO_Arrow; break;
1515 }
1516 }
1517 else if (post_op_name[3] == '\0')
1518 {
1519 if (post_op_name[2] == '*')
1520 op_kind = OO_ArrowStar; break;
1521 }
1522 break;
1523
1524 case '*':
1525 if (post_op_name[1] == '\0')
1526 op_kind = OO_Star;
1527 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1528 op_kind = OO_StarEqual;
1529 break;
1530
1531 case '/':
1532 if (post_op_name[1] == '\0')
1533 op_kind = OO_Slash;
1534 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1535 op_kind = OO_SlashEqual;
1536 break;
1537
1538 case '%':
1539 if (post_op_name[1] == '\0')
1540 op_kind = OO_Percent;
1541 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1542 op_kind = OO_PercentEqual;
1543 break;
1544
1545
1546 case '^':
1547 if (post_op_name[1] == '\0')
1548 op_kind = OO_Caret;
1549 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1550 op_kind = OO_CaretEqual;
1551 break;
1552
1553 case '&':
1554 if (post_op_name[1] == '\0')
1555 op_kind = OO_Amp;
1556 else if (post_op_name[2] == '\0')
1557 {
1558 switch (post_op_name[1])
1559 {
1560 case '=': op_kind = OO_AmpEqual; break;
1561 case '&': op_kind = OO_AmpAmp; break;
1562 }
1563 }
1564 break;
1565
1566 case '|':
1567 if (post_op_name[1] == '\0')
1568 op_kind = OO_Pipe;
1569 else if (post_op_name[2] == '\0')
1570 {
1571 switch (post_op_name[1])
1572 {
1573 case '=': op_kind = OO_PipeEqual; break;
1574 case '|': op_kind = OO_PipePipe; break;
1575 }
1576 }
1577 break;
1578
1579 case '~':
1580 if (post_op_name[1] == '\0')
1581 op_kind = OO_Tilde;
1582 break;
1583
1584 case '!':
1585 if (post_op_name[1] == '\0')
1586 op_kind = OO_Exclaim;
1587 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1588 op_kind = OO_ExclaimEqual;
1589 break;
1590
1591 case '=':
1592 if (post_op_name[1] == '\0')
1593 op_kind = OO_Equal;
1594 else if (post_op_name[1] == '=' && post_op_name[2] == '\0')
1595 op_kind = OO_EqualEqual;
1596 break;
1597
1598 case '<':
1599 if (post_op_name[1] == '\0')
1600 op_kind = OO_Less;
1601 else if (post_op_name[2] == '\0')
1602 {
1603 switch (post_op_name[1])
1604 {
1605 case '<': op_kind = OO_LessLess; break;
1606 case '=': op_kind = OO_LessEqual; break;
1607 }
1608 }
1609 else if (post_op_name[3] == '\0')
1610 {
1611 if (post_op_name[2] == '=')
1612 op_kind = OO_LessLessEqual;
1613 }
1614 break;
1615
1616 case '>':
1617 if (post_op_name[1] == '\0')
1618 op_kind = OO_Greater;
1619 else if (post_op_name[2] == '\0')
1620 {
1621 switch (post_op_name[1])
1622 {
1623 case '>': op_kind = OO_GreaterGreater; break;
1624 case '=': op_kind = OO_GreaterEqual; break;
1625 }
1626 }
1627 else if (post_op_name[1] == '>' &&
1628 post_op_name[2] == '=' &&
1629 post_op_name[3] == '\0')
1630 {
1631 op_kind = OO_GreaterGreaterEqual;
1632 }
1633 break;
1634
1635 case ',':
1636 if (post_op_name[1] == '\0')
1637 op_kind = OO_Comma;
1638 break;
1639
1640 case '(':
1641 if (post_op_name[1] == ')' && post_op_name[2] == '\0')
1642 op_kind = OO_Call;
1643 break;
1644
1645 case '[':
1646 if (post_op_name[1] == ']' && post_op_name[2] == '\0')
1647 op_kind = OO_Subscript;
1648 break;
1649 }
1650
1651 return true;
1652}
Greg Clayton6beaaa62011-01-17 03:46:26 +00001653
Greg Clayton090d0982011-06-19 03:43:27 +00001654static inline bool
Sean Callanan6d9f5db2011-10-15 01:15:07 +00001655check_op_param (uint32_t op_kind, bool unary, bool binary, uint32_t num_params)
Greg Clayton090d0982011-06-19 03:43:27 +00001656{
Sean Callanan6d9f5db2011-10-15 01:15:07 +00001657 // Special-case call since it can take any number of operands
1658 if(op_kind == OO_Call)
1659 return true;
1660
Greg Clayton090d0982011-06-19 03:43:27 +00001661 // The parameter count doens't include "this"
1662 if (num_params == 0)
1663 return unary;
1664 if (num_params == 1)
1665 return binary;
Sean Callanan6d9f5db2011-10-15 01:15:07 +00001666 else
Greg Clayton090d0982011-06-19 03:43:27 +00001667 return false;
1668}
Daniel Dunbardacdfb52011-10-31 22:50:57 +00001669
Greg Clayton090d0982011-06-19 03:43:27 +00001670bool
1671ClangASTContext::CheckOverloadedOperatorKindParameterCount (uint32_t op_kind, uint32_t num_params)
1672{
Sean Callanan5b26f272012-02-04 08:49:35 +00001673 switch (op_kind)
1674 {
1675 default:
1676 break;
1677 // C++ standard allows any number of arguments to new/delete
1678 case OO_New:
1679 case OO_Array_New:
1680 case OO_Delete:
1681 case OO_Array_Delete:
1682 return true;
1683 }
1684
Sean Callanan6d9f5db2011-10-15 01:15:07 +00001685#define OVERLOADED_OPERATOR(Name,Spelling,Token,Unary,Binary,MemberOnly) case OO_##Name: return check_op_param (op_kind, Unary, Binary, num_params);
Greg Clayton090d0982011-06-19 03:43:27 +00001686 switch (op_kind)
1687 {
1688#include "clang/Basic/OperatorKinds.def"
1689 default: break;
1690 }
1691 return false;
1692}
1693
Greg Claytona51ed9b2010-09-23 01:09:21 +00001694CXXMethodDecl *
Sean Callanan61da09b2010-09-17 02:58:26 +00001695ClangASTContext::AddMethodToCXXRecordType
1696(
Greg Clayton6beaaa62011-01-17 03:46:26 +00001697 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00001698 clang_type_t record_opaque_type,
Greg Claytona51ed9b2010-09-23 01:09:21 +00001699 const char *name,
Greg Clayton1be10fc2010-09-29 01:12:09 +00001700 clang_type_t method_opaque_type,
Greg Claytona51ed9b2010-09-23 01:09:21 +00001701 lldb::AccessType access,
Greg Clayton0fffff52010-09-24 05:15:53 +00001702 bool is_virtual,
1703 bool is_static,
Greg Claytonf51de672010-10-01 02:31:07 +00001704 bool is_inline,
Sean Callananc1b732d2011-11-01 18:07:13 +00001705 bool is_explicit,
Sean Callanandbb58392011-11-02 01:38:59 +00001706 bool is_attr_used,
1707 bool is_artificial
Greg Claytona51ed9b2010-09-23 01:09:21 +00001708)
Sean Callanan61da09b2010-09-17 02:58:26 +00001709{
Sean Callananfc55f5d2010-09-21 00:44:12 +00001710 if (!record_opaque_type || !method_opaque_type || !name)
Johnny Chend440bcc2010-09-28 16:10:54 +00001711 return NULL;
Sean Callanan61da09b2010-09-17 02:58:26 +00001712
Greg Clayton6beaaa62011-01-17 03:46:26 +00001713 assert(ast);
Sean Callanan61da09b2010-09-17 02:58:26 +00001714
Greg Clayton6beaaa62011-01-17 03:46:26 +00001715 IdentifierTable *identifier_table = &ast->Idents;
Sean Callanan61da09b2010-09-17 02:58:26 +00001716
1717 assert(identifier_table);
1718
Sean Callananfc55f5d2010-09-21 00:44:12 +00001719 QualType record_qual_type(QualType::getFromOpaquePtr(record_opaque_type));
Greg Clayton0fffff52010-09-24 05:15:53 +00001720
Greg Clayton6beaaa62011-01-17 03:46:26 +00001721 CXXRecordDecl *cxx_record_decl = record_qual_type->getAsCXXRecordDecl();
Sean Callanan61da09b2010-09-17 02:58:26 +00001722
Greg Clayton0fffff52010-09-24 05:15:53 +00001723 if (cxx_record_decl == NULL)
Greg Claytona51ed9b2010-09-23 01:09:21 +00001724 return NULL;
Sean Callanan61da09b2010-09-17 02:58:26 +00001725
Greg Clayton0fffff52010-09-24 05:15:53 +00001726 QualType method_qual_type (QualType::getFromOpaquePtr (method_opaque_type));
Sean Callananfc55f5d2010-09-21 00:44:12 +00001727
Greg Claytonf51de672010-10-01 02:31:07 +00001728 CXXMethodDecl *cxx_method_decl = NULL;
Sean Callanan61da09b2010-09-17 02:58:26 +00001729
Greg Claytonf51de672010-10-01 02:31:07 +00001730 DeclarationName decl_name (&identifier_table->get(name));
Greg Clayton878eaf12010-10-01 03:45:20 +00001731
Sean Callanan78e37602011-01-27 04:42:51 +00001732 const clang::FunctionType *function_Type = dyn_cast<FunctionType>(method_qual_type.getTypePtr());
Greg Clayton878eaf12010-10-01 03:45:20 +00001733
Greg Clayton90a2acd2010-10-02 01:40:05 +00001734 if (function_Type == NULL)
Greg Clayton878eaf12010-10-01 03:45:20 +00001735 return NULL;
1736
Sean Callanan78e37602011-01-27 04:42:51 +00001737 const FunctionProtoType *method_function_prototype (dyn_cast<FunctionProtoType>(function_Type));
Greg Clayton878eaf12010-10-01 03:45:20 +00001738
1739 if (!method_function_prototype)
1740 return NULL;
1741
1742 unsigned int num_params = method_function_prototype->getNumArgs();
1743
Sean Callanandbb58392011-11-02 01:38:59 +00001744 CXXDestructorDecl *cxx_dtor_decl(NULL);
1745 CXXConstructorDecl *cxx_ctor_decl(NULL);
1746
Greg Clayton878eaf12010-10-01 03:45:20 +00001747 if (name[0] == '~')
Greg Claytonf51de672010-10-01 02:31:07 +00001748 {
Sean Callanandbb58392011-11-02 01:38:59 +00001749 cxx_dtor_decl = CXXDestructorDecl::Create (*ast,
1750 cxx_record_decl,
1751 SourceLocation(),
1752 DeclarationNameInfo (ast->DeclarationNames.getCXXDestructorName (ast->getCanonicalType (record_qual_type)), SourceLocation()),
1753 method_qual_type,
1754 NULL,
1755 is_inline,
1756 is_artificial);
1757 cxx_method_decl = cxx_dtor_decl;
Greg Clayton878eaf12010-10-01 03:45:20 +00001758 }
Greg Clayton6beaaa62011-01-17 03:46:26 +00001759 else if (decl_name == cxx_record_decl->getDeclName())
Greg Clayton878eaf12010-10-01 03:45:20 +00001760 {
Sean Callanandbb58392011-11-02 01:38:59 +00001761 cxx_ctor_decl = CXXConstructorDecl::Create (*ast,
1762 cxx_record_decl,
1763 SourceLocation(),
1764 DeclarationNameInfo (ast->DeclarationNames.getCXXConstructorName (ast->getCanonicalType (record_qual_type)), SourceLocation()),
1765 method_qual_type,
1766 NULL, // TypeSourceInfo *
1767 is_explicit,
1768 is_inline,
1769 is_artificial,
1770 false /*is_constexpr*/);
1771 cxx_method_decl = cxx_ctor_decl;
Greg Claytonf51de672010-10-01 02:31:07 +00001772 }
1773 else
Greg Clayton878eaf12010-10-01 03:45:20 +00001774 {
Greg Claytona3c444a2010-10-01 23:13:49 +00001775
1776 OverloadedOperatorKind op_kind = NUM_OVERLOADED_OPERATORS;
1777 if (IsOperator (name, op_kind))
Greg Clayton878eaf12010-10-01 03:45:20 +00001778 {
Greg Claytona3c444a2010-10-01 23:13:49 +00001779 if (op_kind != NUM_OVERLOADED_OPERATORS)
1780 {
Greg Clayton090d0982011-06-19 03:43:27 +00001781 // Check the number of operator parameters. Sometimes we have
1782 // seen bad DWARF that doesn't correctly describe operators and
1783 // if we try to create a methed and add it to the class, clang
1784 // will assert and crash, so we need to make sure things are
1785 // acceptable.
1786 if (!ClangASTContext::CheckOverloadedOperatorKindParameterCount (op_kind, num_params))
1787 return NULL;
Greg Clayton6beaaa62011-01-17 03:46:26 +00001788 cxx_method_decl = CXXMethodDecl::Create (*ast,
Greg Clayton878eaf12010-10-01 03:45:20 +00001789 cxx_record_decl,
Sean Callananfb0b7582011-03-15 00:17:19 +00001790 SourceLocation(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00001791 DeclarationNameInfo (ast->DeclarationNames.getCXXOperatorName (op_kind), SourceLocation()),
Greg Clayton878eaf12010-10-01 03:45:20 +00001792 method_qual_type,
1793 NULL, // TypeSourceInfo *
Greg Claytona3c444a2010-10-01 23:13:49 +00001794 is_static,
1795 SC_None,
Sean Callananfb0b7582011-03-15 00:17:19 +00001796 is_inline,
Sean Callanan880e6802011-10-07 23:18:13 +00001797 false /*is_constexpr*/,
Sean Callananfb0b7582011-03-15 00:17:19 +00001798 SourceLocation());
Greg Claytona3c444a2010-10-01 23:13:49 +00001799 }
1800 else if (num_params == 0)
1801 {
1802 // Conversion operators don't take params...
Greg Clayton6beaaa62011-01-17 03:46:26 +00001803 cxx_method_decl = CXXConversionDecl::Create (*ast,
Greg Claytona3c444a2010-10-01 23:13:49 +00001804 cxx_record_decl,
Sean Callananfb0b7582011-03-15 00:17:19 +00001805 SourceLocation(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00001806 DeclarationNameInfo (ast->DeclarationNames.getCXXConversionFunctionName (ast->getCanonicalType (function_Type->getResultType())), SourceLocation()),
Greg Claytona3c444a2010-10-01 23:13:49 +00001807 method_qual_type,
1808 NULL, // TypeSourceInfo *
1809 is_inline,
Sean Callananfb0b7582011-03-15 00:17:19 +00001810 is_explicit,
Sean Callanan880e6802011-10-07 23:18:13 +00001811 false /*is_constexpr*/,
Sean Callananfb0b7582011-03-15 00:17:19 +00001812 SourceLocation());
Greg Claytona3c444a2010-10-01 23:13:49 +00001813 }
Greg Clayton878eaf12010-10-01 03:45:20 +00001814 }
Greg Claytona3c444a2010-10-01 23:13:49 +00001815
1816 if (cxx_method_decl == NULL)
Greg Clayton878eaf12010-10-01 03:45:20 +00001817 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00001818 cxx_method_decl = CXXMethodDecl::Create (*ast,
Greg Clayton878eaf12010-10-01 03:45:20 +00001819 cxx_record_decl,
Sean Callananfb0b7582011-03-15 00:17:19 +00001820 SourceLocation(),
Greg Claytona3c444a2010-10-01 23:13:49 +00001821 DeclarationNameInfo (decl_name, SourceLocation()),
Greg Clayton878eaf12010-10-01 03:45:20 +00001822 method_qual_type,
1823 NULL, // TypeSourceInfo *
1824 is_static,
1825 SC_None,
Sean Callananfb0b7582011-03-15 00:17:19 +00001826 is_inline,
Sean Callanan880e6802011-10-07 23:18:13 +00001827 false /*is_constexpr*/,
Sean Callananfb0b7582011-03-15 00:17:19 +00001828 SourceLocation());
Greg Clayton878eaf12010-10-01 03:45:20 +00001829 }
Greg Claytonf51de672010-10-01 02:31:07 +00001830 }
Greg Claytona3c444a2010-10-01 23:13:49 +00001831
Greg Clayton1be10fc2010-09-29 01:12:09 +00001832 AccessSpecifier access_specifier = ConvertAccessTypeToAccessSpecifier (access);
Greg Clayton0fffff52010-09-24 05:15:53 +00001833
1834 cxx_method_decl->setAccess (access_specifier);
1835 cxx_method_decl->setVirtualAsWritten (is_virtual);
Sean Callanane2ef6e32010-09-23 03:01:22 +00001836
Sean Callananc1b732d2011-11-01 18:07:13 +00001837 if (is_attr_used)
1838 cxx_method_decl->addAttr(::new (*ast) UsedAttr(SourceRange(), *ast));
1839
Sean Callananfc55f5d2010-09-21 00:44:12 +00001840 // Populate the method decl with parameter decls
Sean Callananfc55f5d2010-09-21 00:44:12 +00001841
Charles Davis8c444c42011-05-19 23:33:46 +00001842 llvm::SmallVector<ParmVarDecl *, 12> params;
Sean Callananfc55f5d2010-09-21 00:44:12 +00001843
1844 for (int param_index = 0;
1845 param_index < num_params;
1846 ++param_index)
1847 {
Charles Davis8c444c42011-05-19 23:33:46 +00001848 params.push_back (ParmVarDecl::Create (*ast,
1849 cxx_method_decl,
1850 SourceLocation(),
1851 SourceLocation(),
1852 NULL, // anonymous
1853 method_function_prototype->getArgType(param_index),
1854 NULL,
1855 SC_None,
1856 SC_None,
1857 NULL));
Sean Callananfc55f5d2010-09-21 00:44:12 +00001858 }
1859
Sean Callanan880e6802011-10-07 23:18:13 +00001860 cxx_method_decl->setParams (ArrayRef<ParmVarDecl*>(params));
Sean Callananfc55f5d2010-09-21 00:44:12 +00001861
Greg Clayton0fffff52010-09-24 05:15:53 +00001862 cxx_record_decl->addDecl (cxx_method_decl);
Sean Callanan5e9e1992011-10-26 01:06:27 +00001863
Greg Clayton8b867b42011-11-02 02:06:20 +00001864 // Sometimes the debug info will mention a constructor (default/copy/move),
1865 // destructor, or assignment operator (copy/move) but there won't be any
1866 // version of this in the code. So we check if the function was artificially
1867 // generated and if it is trivial and this lets the compiler/backend know
1868 // that it can inline the IR for these when it needs to and we can avoid a
1869 // "missing function" error when running expressions.
1870
Sean Callanandbb58392011-11-02 01:38:59 +00001871 if (is_artificial)
1872 {
Greg Clayton8b867b42011-11-02 02:06:20 +00001873 if (cxx_ctor_decl &&
1874 ((cxx_ctor_decl->isDefaultConstructor() && cxx_record_decl->hasTrivialDefaultConstructor ()) ||
1875 (cxx_ctor_decl->isCopyConstructor() && cxx_record_decl->hasTrivialCopyConstructor ()) ||
1876 (cxx_ctor_decl->isMoveConstructor() && cxx_record_decl->hasTrivialMoveConstructor ()) ))
Sean Callanandbb58392011-11-02 01:38:59 +00001877 {
1878 cxx_ctor_decl->setDefaulted();
1879 cxx_ctor_decl->setTrivial(true);
1880 }
Greg Clayton8b867b42011-11-02 02:06:20 +00001881 else if (cxx_dtor_decl)
Sean Callanandbb58392011-11-02 01:38:59 +00001882 {
Greg Clayton8b867b42011-11-02 02:06:20 +00001883 if (cxx_record_decl->hasTrivialDestructor())
1884 {
1885 cxx_dtor_decl->setDefaulted();
1886 cxx_dtor_decl->setTrivial(true);
1887 }
1888 }
1889 else if ((cxx_method_decl->isCopyAssignmentOperator() && cxx_record_decl->hasTrivialCopyAssignment()) ||
1890 (cxx_method_decl->isMoveAssignmentOperator() && cxx_record_decl->hasTrivialMoveAssignment()))
1891 {
1892 cxx_method_decl->setDefaulted();
1893 cxx_method_decl->setTrivial(true);
Sean Callanandbb58392011-11-02 01:38:59 +00001894 }
1895 }
1896
Sean Callanan5e9e1992011-10-26 01:06:27 +00001897#ifdef LLDB_CONFIGURATION_DEBUG
1898 VerifyDecl(cxx_method_decl);
1899#endif
Greg Claytonc432c192011-01-20 04:18:48 +00001900
1901// printf ("decl->isPolymorphic() = %i\n", cxx_record_decl->isPolymorphic());
1902// printf ("decl->isAggregate() = %i\n", cxx_record_decl->isAggregate());
1903// printf ("decl->isPOD() = %i\n", cxx_record_decl->isPOD());
1904// printf ("decl->isEmpty() = %i\n", cxx_record_decl->isEmpty());
1905// printf ("decl->isAbstract() = %i\n", cxx_record_decl->isAbstract());
1906// printf ("decl->hasTrivialConstructor() = %i\n", cxx_record_decl->hasTrivialConstructor());
1907// printf ("decl->hasTrivialCopyConstructor() = %i\n", cxx_record_decl->hasTrivialCopyConstructor());
1908// printf ("decl->hasTrivialCopyAssignment() = %i\n", cxx_record_decl->hasTrivialCopyAssignment());
1909// printf ("decl->hasTrivialDestructor() = %i\n", cxx_record_decl->hasTrivialDestructor());
Greg Claytona51ed9b2010-09-23 01:09:21 +00001910 return cxx_method_decl;
Sean Callanan61da09b2010-09-17 02:58:26 +00001911}
1912
Jim Inghame3ae82a2011-11-12 01:36:43 +00001913clang::FieldDecl *
Greg Clayton8cf05932010-07-22 18:30:50 +00001914ClangASTContext::AddFieldToRecordType
1915(
Greg Clayton6beaaa62011-01-17 03:46:26 +00001916 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00001917 clang_type_t record_clang_type,
Greg Clayton8cf05932010-07-22 18:30:50 +00001918 const char *name,
Greg Clayton1be10fc2010-09-29 01:12:09 +00001919 clang_type_t field_type,
Greg Clayton8cf05932010-07-22 18:30:50 +00001920 AccessType access,
1921 uint32_t bitfield_bit_size
1922)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001923{
1924 if (record_clang_type == NULL || field_type == NULL)
Jim Inghame3ae82a2011-11-12 01:36:43 +00001925 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001926
Jim Inghame3ae82a2011-11-12 01:36:43 +00001927 FieldDecl *field = NULL;
Greg Clayton6beaaa62011-01-17 03:46:26 +00001928 IdentifierTable *identifier_table = &ast->Idents;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001929
Greg Clayton6beaaa62011-01-17 03:46:26 +00001930 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001931 assert (identifier_table != NULL);
1932
1933 QualType record_qual_type(QualType::getFromOpaquePtr(record_clang_type));
1934
Sean Callanan78e37602011-01-27 04:42:51 +00001935 const clang::Type *clang_type = record_qual_type.getTypePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001936 if (clang_type)
1937 {
1938 const RecordType *record_type = dyn_cast<RecordType>(clang_type);
1939
1940 if (record_type)
1941 {
1942 RecordDecl *record_decl = record_type->getDecl();
1943
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001944 clang::Expr *bit_width = NULL;
1945 if (bitfield_bit_size != 0)
1946 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00001947 APInt bitfield_bit_size_apint(ast->getTypeSize(ast->IntTy), bitfield_bit_size);
1948 bit_width = new (*ast)IntegerLiteral (*ast, bitfield_bit_size_apint, ast->IntTy, SourceLocation());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001949 }
Jim Inghame3ae82a2011-11-12 01:36:43 +00001950 field = FieldDecl::Create (*ast,
Sean Callanan3d654b32012-09-24 22:25:51 +00001951 record_decl,
1952 SourceLocation(),
1953 SourceLocation(),
1954 name ? &identifier_table->get(name) : NULL, // Identifier
1955 QualType::getFromOpaquePtr(field_type), // Field type
1956 NULL, // TInfo *
1957 bit_width, // BitWidth
1958 false, // Mutable
1959 ICIS_NoInit); // HasInit
Sean Callanane8c0cfb2012-03-02 01:03:45 +00001960
Sean Callanan5ed3ac12012-07-13 20:01:02 +00001961 if (!name) {
1962 // Determine whether this field corresponds to an anonymous
1963 // struct or union.
1964 if (const TagType *TagT = field->getType()->getAs<TagType>()) {
1965 if (RecordDecl *Rec = dyn_cast<RecordDecl>(TagT->getDecl()))
1966 if (!Rec->getDeclName()) {
1967 Rec->setAnonymousStructOrUnion(true);
1968 field->setImplicit();
1969
1970 }
1971 }
1972 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001973
Greg Clayton8cf05932010-07-22 18:30:50 +00001974 field->setAccess (ConvertAccessTypeToAccessSpecifier (access));
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001975
1976 if (field)
1977 {
1978 record_decl->addDecl(field);
Sean Callanan5e9e1992011-10-26 01:06:27 +00001979
1980#ifdef LLDB_CONFIGURATION_DEBUG
1981 VerifyDecl(field);
1982#endif
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001983 }
1984 }
Greg Clayton9e409562010-07-28 02:04:09 +00001985 else
1986 {
Sean Callanan78e37602011-01-27 04:42:51 +00001987 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(clang_type);
Greg Clayton9e409562010-07-28 02:04:09 +00001988 if (objc_class_type)
1989 {
Greg Clayton0fffff52010-09-24 05:15:53 +00001990 bool is_synthesized = false;
Jim Inghame3ae82a2011-11-12 01:36:43 +00001991 field = ClangASTContext::AddObjCClassIVar (ast,
Sean Callanan6e6a7c72010-09-16 20:01:08 +00001992 record_clang_type,
Greg Clayton9e409562010-07-28 02:04:09 +00001993 name,
1994 field_type,
1995 access,
1996 bitfield_bit_size,
Greg Clayton0fffff52010-09-24 05:15:53 +00001997 is_synthesized);
Greg Clayton9e409562010-07-28 02:04:09 +00001998 }
1999 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002000 }
Jim Inghame3ae82a2011-11-12 01:36:43 +00002001 return field;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002002}
2003
Sean Callanane8c0cfb2012-03-02 01:03:45 +00002004static clang::AccessSpecifier UnifyAccessSpecifiers (clang::AccessSpecifier lhs,
2005 clang::AccessSpecifier rhs)
2006{
2007 clang::AccessSpecifier ret = lhs;
2008
2009 // Make the access equal to the stricter of the field and the nested field's access
2010 switch (ret)
2011 {
2012 case clang::AS_none:
2013 break;
2014 case clang::AS_private:
2015 break;
2016 case clang::AS_protected:
2017 if (rhs == AS_private)
2018 ret = AS_private;
2019 break;
2020 case clang::AS_public:
2021 ret = rhs;
2022 break;
2023 }
2024
2025 return ret;
2026}
2027
2028void
2029ClangASTContext::BuildIndirectFields (clang::ASTContext *ast,
2030 lldb::clang_type_t record_clang_type)
2031{
2032 QualType record_qual_type(QualType::getFromOpaquePtr(record_clang_type));
2033
2034 const RecordType *record_type = record_qual_type->getAs<RecordType>();
2035
2036 if (!record_type)
2037 return;
2038
2039 RecordDecl *record_decl = record_type->getDecl();
2040
2041 if (!record_decl)
2042 return;
2043
2044 typedef llvm::SmallVector <IndirectFieldDecl *, 1> IndirectFieldVector;
2045
2046 IndirectFieldVector indirect_fields;
2047
2048 for (RecordDecl::field_iterator fi = record_decl->field_begin(), fe = record_decl->field_end();
2049 fi != fe;
2050 ++fi)
2051 {
2052 if (fi->isAnonymousStructOrUnion())
2053 {
2054 QualType field_qual_type = fi->getType();
2055
2056 const RecordType *field_record_type = field_qual_type->getAs<RecordType>();
2057
2058 if (!field_record_type)
2059 continue;
2060
2061 RecordDecl *field_record_decl = field_record_type->getDecl();
2062
2063 if (!field_record_decl)
2064 continue;
2065
2066 for (RecordDecl::decl_iterator di = field_record_decl->decls_begin(), de = field_record_decl->decls_end();
2067 di != de;
2068 ++di)
2069 {
2070 if (FieldDecl *nested_field_decl = dyn_cast<FieldDecl>(*di))
2071 {
2072 NamedDecl **chain = new (*ast) NamedDecl*[2];
2073 chain[0] = *fi;
2074 chain[1] = nested_field_decl;
2075 IndirectFieldDecl *indirect_field = IndirectFieldDecl::Create(*ast,
2076 record_decl,
2077 SourceLocation(),
2078 nested_field_decl->getIdentifier(),
2079 nested_field_decl->getType(),
2080 chain,
2081 2);
2082
2083 indirect_field->setAccess(UnifyAccessSpecifiers(fi->getAccess(),
2084 nested_field_decl->getAccess()));
2085
2086 indirect_fields.push_back(indirect_field);
2087 }
2088 else if (IndirectFieldDecl *nested_indirect_field_decl = dyn_cast<IndirectFieldDecl>(*di))
2089 {
2090 int nested_chain_size = nested_indirect_field_decl->getChainingSize();
2091 NamedDecl **chain = new (*ast) NamedDecl*[nested_chain_size + 1];
2092 chain[0] = *fi;
2093
2094 int chain_index = 1;
2095 for (IndirectFieldDecl::chain_iterator nci = nested_indirect_field_decl->chain_begin(),
2096 nce = nested_indirect_field_decl->chain_end();
2097 nci < nce;
2098 ++nci)
2099 {
2100 chain[chain_index] = *nci;
2101 chain_index++;
2102 }
2103
2104 IndirectFieldDecl *indirect_field = IndirectFieldDecl::Create(*ast,
2105 record_decl,
2106 SourceLocation(),
2107 nested_indirect_field_decl->getIdentifier(),
2108 nested_indirect_field_decl->getType(),
2109 chain,
2110 nested_chain_size + 1);
2111
2112 indirect_field->setAccess(UnifyAccessSpecifiers(fi->getAccess(),
2113 nested_indirect_field_decl->getAccess()));
2114
2115 indirect_fields.push_back(indirect_field);
2116 }
2117 }
2118 }
2119 }
2120
2121 for (IndirectFieldVector::iterator ifi = indirect_fields.begin(), ife = indirect_fields.end();
2122 ifi < ife;
2123 ++ifi)
2124 {
2125 record_decl->addDecl(*ifi);
2126 }
2127}
2128
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002129bool
2130ClangASTContext::FieldIsBitfield (FieldDecl* field, uint32_t& bitfield_bit_size)
2131{
2132 return FieldIsBitfield(getASTContext(), field, bitfield_bit_size);
2133}
2134
2135bool
2136ClangASTContext::FieldIsBitfield
2137(
Greg Clayton6beaaa62011-01-17 03:46:26 +00002138 ASTContext *ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002139 FieldDecl* field,
2140 uint32_t& bitfield_bit_size
2141)
2142{
Greg Clayton6beaaa62011-01-17 03:46:26 +00002143 if (ast == NULL || field == NULL)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002144 return false;
2145
2146 if (field->isBitField())
2147 {
2148 Expr* bit_width_expr = field->getBitWidth();
2149 if (bit_width_expr)
2150 {
2151 llvm::APSInt bit_width_apsint;
Greg Clayton6beaaa62011-01-17 03:46:26 +00002152 if (bit_width_expr->isIntegerConstantExpr(bit_width_apsint, *ast))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002153 {
2154 bitfield_bit_size = bit_width_apsint.getLimitedValue(UINT32_MAX);
2155 return true;
2156 }
2157 }
2158 }
2159 return false;
2160}
2161
2162bool
2163ClangASTContext::RecordHasFields (const RecordDecl *record_decl)
2164{
2165 if (record_decl == NULL)
2166 return false;
2167
2168 if (!record_decl->field_empty())
2169 return true;
2170
2171 // No fields, lets check this is a CXX record and check the base classes
2172 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
2173 if (cxx_record_decl)
2174 {
2175 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
2176 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
2177 base_class != base_class_end;
2178 ++base_class)
2179 {
2180 const CXXRecordDecl *base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
2181 if (RecordHasFields(base_class_decl))
2182 return true;
2183 }
2184 }
2185 return false;
2186}
2187
2188void
Greg Clayton6beaaa62011-01-17 03:46:26 +00002189ClangASTContext::SetDefaultAccessForRecordFields (clang_type_t clang_type, int default_accessibility, int *assigned_accessibilities, size_t num_assigned_accessibilities)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002190{
Greg Clayton6beaaa62011-01-17 03:46:26 +00002191 if (clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002192 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002193 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
2194
Sean Callanan78e37602011-01-27 04:42:51 +00002195 const RecordType *record_type = dyn_cast<RecordType>(qual_type.getTypePtr());
Greg Clayton6beaaa62011-01-17 03:46:26 +00002196 if (record_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002197 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002198 RecordDecl *record_decl = record_type->getDecl();
2199 if (record_decl)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002200 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002201 uint32_t field_idx;
2202 RecordDecl::field_iterator field, field_end;
2203 for (field = record_decl->field_begin(), field_end = record_decl->field_end(), field_idx = 0;
2204 field != field_end;
2205 ++field, ++field_idx)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002206 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002207 // If no accessibility was assigned, assign the correct one
2208 if (field_idx < num_assigned_accessibilities && assigned_accessibilities[field_idx] == clang::AS_none)
2209 field->setAccess ((AccessSpecifier)default_accessibility);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002210 }
2211 }
2212 }
2213 }
2214}
2215
2216#pragma mark C++ Base Classes
2217
2218CXXBaseSpecifier *
Greg Clayton1be10fc2010-09-29 01:12:09 +00002219ClangASTContext::CreateBaseClassSpecifier (clang_type_t base_class_type, AccessType access, bool is_virtual, bool base_of_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002220{
2221 if (base_class_type)
Greg Claytone6371122010-07-30 20:30:44 +00002222 return new CXXBaseSpecifier (SourceRange(),
2223 is_virtual,
2224 base_of_class,
2225 ConvertAccessTypeToAccessSpecifier (access),
Sean Callanan2c777c42011-01-18 23:32:05 +00002226 getASTContext()->CreateTypeSourceInfo (QualType::getFromOpaquePtr(base_class_type)),
2227 SourceLocation());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002228 return NULL;
2229}
2230
Greg Clayton0b42ac32010-07-02 01:29:13 +00002231void
2232ClangASTContext::DeleteBaseClassSpecifiers (CXXBaseSpecifier **base_classes, unsigned num_base_classes)
2233{
2234 for (unsigned i=0; i<num_base_classes; ++i)
2235 {
2236 delete base_classes[i];
2237 base_classes[i] = NULL;
2238 }
2239}
2240
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002241bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00002242ClangASTContext::SetBaseClassesForClassType (clang_type_t class_clang_type, CXXBaseSpecifier const * const *base_classes, unsigned num_base_classes)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002243{
2244 if (class_clang_type)
2245 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002246 CXXRecordDecl *cxx_record_decl = QualType::getFromOpaquePtr(class_clang_type)->getAsCXXRecordDecl();
2247 if (cxx_record_decl)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002248 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002249 cxx_record_decl->setBases(base_classes, num_base_classes);
2250 return true;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002251 }
2252 }
2253 return false;
2254}
Greg Clayton8cf05932010-07-22 18:30:50 +00002255#pragma mark Objective C Classes
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002256
Greg Clayton1be10fc2010-09-29 01:12:09 +00002257clang_type_t
Sean Callananad880762012-04-18 01:06:17 +00002258ClangASTContext::CreateObjCClass
Greg Clayton8cf05932010-07-22 18:30:50 +00002259(
2260 const char *name,
2261 DeclContext *decl_ctx,
2262 bool isForwardDecl,
Sean Callananad880762012-04-18 01:06:17 +00002263 bool isInternal,
2264 uint64_t metadata
Greg Clayton8cf05932010-07-22 18:30:50 +00002265)
2266{
Greg Clayton6beaaa62011-01-17 03:46:26 +00002267 ASTContext *ast = getASTContext();
2268 assert (ast != NULL);
Greg Clayton8cf05932010-07-22 18:30:50 +00002269 assert (name && name[0]);
2270 if (decl_ctx == NULL)
Greg Clayton6beaaa62011-01-17 03:46:26 +00002271 decl_ctx = ast->getTranslationUnitDecl();
Greg Clayton8cf05932010-07-22 18:30:50 +00002272
2273 // NOTE: Eventually CXXRecordDecl will be merged back into RecordDecl and
2274 // we will need to update this code. I was told to currently always use
2275 // the CXXRecordDecl class since we often don't know from debug information
2276 // if something is struct or a class, so we default to always use the more
2277 // complete definition just in case.
Greg Clayton6beaaa62011-01-17 03:46:26 +00002278 ObjCInterfaceDecl *decl = ObjCInterfaceDecl::Create (*ast,
Greg Clayton8cf05932010-07-22 18:30:50 +00002279 decl_ctx,
2280 SourceLocation(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00002281 &ast->Idents.get(name),
Sean Callanan5b26f272012-02-04 08:49:35 +00002282 NULL,
Greg Clayton8cf05932010-07-22 18:30:50 +00002283 SourceLocation(),
Sean Callanan5b26f272012-02-04 08:49:35 +00002284 /*isForwardDecl,*/
Greg Clayton8cf05932010-07-22 18:30:50 +00002285 isInternal);
Greg Clayton9e409562010-07-28 02:04:09 +00002286
Sean Callananad880762012-04-18 01:06:17 +00002287 if (decl)
2288 SetMetadata(ast, (uintptr_t)decl, metadata);
2289
Greg Clayton6beaaa62011-01-17 03:46:26 +00002290 return ast->getObjCInterfaceType(decl).getAsOpaquePtr();
Greg Clayton8cf05932010-07-22 18:30:50 +00002291}
2292
2293bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00002294ClangASTContext::SetObjCSuperClass (clang_type_t class_opaque_type, clang_type_t super_opaque_type)
Greg Clayton8cf05932010-07-22 18:30:50 +00002295{
2296 if (class_opaque_type && super_opaque_type)
2297 {
2298 QualType class_qual_type(QualType::getFromOpaquePtr(class_opaque_type));
2299 QualType super_qual_type(QualType::getFromOpaquePtr(super_opaque_type));
Sean Callanan78e37602011-01-27 04:42:51 +00002300 const clang::Type *class_type = class_qual_type.getTypePtr();
2301 const clang::Type *super_type = super_qual_type.getTypePtr();
Greg Clayton8cf05932010-07-22 18:30:50 +00002302 if (class_type && super_type)
2303 {
Sean Callanan78e37602011-01-27 04:42:51 +00002304 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(class_type);
2305 const ObjCObjectType *objc_super_type = dyn_cast<ObjCObjectType>(super_type);
Greg Clayton8cf05932010-07-22 18:30:50 +00002306 if (objc_class_type && objc_super_type)
2307 {
2308 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
2309 ObjCInterfaceDecl *super_interface_decl = objc_super_type->getInterface();
2310 if (class_interface_decl && super_interface_decl)
2311 {
2312 class_interface_decl->setSuperClass(super_interface_decl);
2313 return true;
2314 }
2315 }
2316 }
2317 }
2318 return false;
2319}
2320
2321
Jim Inghame3ae82a2011-11-12 01:36:43 +00002322FieldDecl *
Greg Clayton8cf05932010-07-22 18:30:50 +00002323ClangASTContext::AddObjCClassIVar
2324(
Greg Clayton6beaaa62011-01-17 03:46:26 +00002325 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00002326 clang_type_t class_opaque_type,
Greg Clayton8cf05932010-07-22 18:30:50 +00002327 const char *name,
Greg Clayton1be10fc2010-09-29 01:12:09 +00002328 clang_type_t ivar_opaque_type,
Greg Clayton8cf05932010-07-22 18:30:50 +00002329 AccessType access,
2330 uint32_t bitfield_bit_size,
Greg Clayton0fffff52010-09-24 05:15:53 +00002331 bool is_synthesized
Greg Clayton8cf05932010-07-22 18:30:50 +00002332)
2333{
2334 if (class_opaque_type == NULL || ivar_opaque_type == NULL)
Jim Inghame3ae82a2011-11-12 01:36:43 +00002335 return NULL;
Greg Clayton8cf05932010-07-22 18:30:50 +00002336
Jim Inghame3ae82a2011-11-12 01:36:43 +00002337 ObjCIvarDecl *field = NULL;
2338
Greg Clayton6beaaa62011-01-17 03:46:26 +00002339 IdentifierTable *identifier_table = &ast->Idents;
Greg Clayton8cf05932010-07-22 18:30:50 +00002340
Greg Clayton6beaaa62011-01-17 03:46:26 +00002341 assert (ast != NULL);
Greg Clayton8cf05932010-07-22 18:30:50 +00002342 assert (identifier_table != NULL);
2343
2344 QualType class_qual_type(QualType::getFromOpaquePtr(class_opaque_type));
2345
Sean Callanan78e37602011-01-27 04:42:51 +00002346 const clang::Type *class_type = class_qual_type.getTypePtr();
Greg Clayton8cf05932010-07-22 18:30:50 +00002347 if (class_type)
2348 {
Sean Callanan78e37602011-01-27 04:42:51 +00002349 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(class_type);
Greg Clayton8cf05932010-07-22 18:30:50 +00002350
2351 if (objc_class_type)
2352 {
2353 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
2354
2355 if (class_interface_decl)
2356 {
2357 clang::Expr *bit_width = NULL;
2358 if (bitfield_bit_size != 0)
2359 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002360 APInt bitfield_bit_size_apint(ast->getTypeSize(ast->IntTy), bitfield_bit_size);
2361 bit_width = new (*ast)IntegerLiteral (*ast, bitfield_bit_size_apint, ast->IntTy, SourceLocation());
Greg Clayton8cf05932010-07-22 18:30:50 +00002362 }
2363
Jim Inghame3ae82a2011-11-12 01:36:43 +00002364 field = ObjCIvarDecl::Create (*ast,
2365 class_interface_decl,
2366 SourceLocation(),
2367 SourceLocation(),
2368 &identifier_table->get(name), // Identifier
2369 QualType::getFromOpaquePtr(ivar_opaque_type), // Field type
2370 NULL, // TypeSourceInfo *
2371 ConvertAccessTypeToObjCIvarAccessControl (access),
2372 bit_width,
2373 is_synthesized);
Greg Clayton9e409562010-07-28 02:04:09 +00002374
2375 if (field)
2376 {
2377 class_interface_decl->addDecl(field);
Sean Callanan5e9e1992011-10-26 01:06:27 +00002378
2379#ifdef LLDB_CONFIGURATION_DEBUG
2380 VerifyDecl(field);
2381#endif
2382
Jim Inghame3ae82a2011-11-12 01:36:43 +00002383 return field;
Greg Clayton9e409562010-07-28 02:04:09 +00002384 }
Greg Clayton8cf05932010-07-22 18:30:50 +00002385 }
2386 }
2387 }
Jim Inghame3ae82a2011-11-12 01:36:43 +00002388 return NULL;
2389}
2390
2391bool
2392ClangASTContext::AddObjCClassProperty
2393(
2394 ASTContext *ast,
2395 clang_type_t class_opaque_type,
2396 const char *property_name,
2397 clang_type_t property_opaque_type,
2398 ObjCIvarDecl *ivar_decl,
2399 const char *property_setter_name,
2400 const char *property_getter_name,
Sean Callananad880762012-04-18 01:06:17 +00002401 uint32_t property_attributes,
2402 uint64_t metadata
Jim Inghame3ae82a2011-11-12 01:36:43 +00002403)
2404{
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002405 if (class_opaque_type == NULL || property_name == NULL || property_name[0] == '\0')
Jim Inghame3ae82a2011-11-12 01:36:43 +00002406 return false;
2407
2408 IdentifierTable *identifier_table = &ast->Idents;
2409
2410 assert (ast != NULL);
2411 assert (identifier_table != NULL);
2412
2413 QualType class_qual_type(QualType::getFromOpaquePtr(class_opaque_type));
2414 const clang::Type *class_type = class_qual_type.getTypePtr();
2415 if (class_type)
2416 {
2417 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(class_type);
2418
2419 if (objc_class_type)
2420 {
2421 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
2422
Greg Clayton23f59502012-07-17 03:23:13 +00002423 clang_type_t property_opaque_type_to_access = NULL;
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002424
2425 if (property_opaque_type)
2426 property_opaque_type_to_access = property_opaque_type;
2427 else if (ivar_decl)
2428 property_opaque_type_to_access = ivar_decl->getType().getAsOpaquePtr();
2429
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002430 if (class_interface_decl && property_opaque_type_to_access)
Jim Inghame3ae82a2011-11-12 01:36:43 +00002431 {
2432 clang::TypeSourceInfo *prop_type_source;
2433 if (ivar_decl)
2434 prop_type_source = ast->CreateTypeSourceInfo (ivar_decl->getType());
2435 else
2436 prop_type_source = ast->CreateTypeSourceInfo (QualType::getFromOpaquePtr(property_opaque_type));
2437
2438 ObjCPropertyDecl *property_decl = ObjCPropertyDecl::Create(*ast,
2439 class_interface_decl,
2440 SourceLocation(), // Source Location
2441 &identifier_table->get(property_name),
2442 SourceLocation(), //Source Location for AT
Sean Callanand5f33a82012-03-01 02:03:47 +00002443 SourceLocation(), //Source location for (
Jim Inghame3ae82a2011-11-12 01:36:43 +00002444 prop_type_source
2445 );
Sean Callananad880762012-04-18 01:06:17 +00002446
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002447 if (property_decl)
2448 {
Sean Callananad880762012-04-18 01:06:17 +00002449 SetMetadata(ast, (uintptr_t)property_decl, metadata);
2450
Jim Inghame3ae82a2011-11-12 01:36:43 +00002451 class_interface_decl->addDecl (property_decl);
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002452
2453 Selector setter_sel, getter_sel;
2454
Jim Inghame3ae82a2011-11-12 01:36:43 +00002455 if (property_setter_name != NULL)
2456 {
2457 std::string property_setter_no_colon(property_setter_name, strlen(property_setter_name) - 1);
2458 clang::IdentifierInfo *setter_ident = &identifier_table->get(property_setter_no_colon.c_str());
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002459 setter_sel = ast->Selectors.getSelector(1, &setter_ident);
Jim Inghame3ae82a2011-11-12 01:36:43 +00002460 }
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002461 else if (!(property_attributes & DW_APPLE_PROPERTY_readonly))
2462 {
2463 std::string setter_sel_string("set");
2464 setter_sel_string.push_back(::toupper(property_name[0]));
2465 setter_sel_string.append(&property_name[1]);
2466 clang::IdentifierInfo *setter_ident = &identifier_table->get(setter_sel_string.c_str());
2467 setter_sel = ast->Selectors.getSelector(1, &setter_ident);
2468 }
Sean Callanana6582262012-04-05 00:12:52 +00002469 property_decl->setSetterName(setter_sel);
2470 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_setter);
Jim Inghame3ae82a2011-11-12 01:36:43 +00002471
2472 if (property_getter_name != NULL)
2473 {
2474 clang::IdentifierInfo *getter_ident = &identifier_table->get(property_getter_name);
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002475 getter_sel = ast->Selectors.getSelector(0, &getter_ident);
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002476 }
2477 else
2478 {
2479 clang::IdentifierInfo *getter_ident = &identifier_table->get(property_name);
2480 getter_sel = ast->Selectors.getSelector(0, &getter_ident);
Jim Inghame3ae82a2011-11-12 01:36:43 +00002481 }
Sean Callanana6582262012-04-05 00:12:52 +00002482 property_decl->setGetterName(getter_sel);
2483 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_getter);
Jim Inghame3ae82a2011-11-12 01:36:43 +00002484
2485 if (ivar_decl)
2486 property_decl->setPropertyIvarDecl (ivar_decl);
2487
2488 if (property_attributes & DW_APPLE_PROPERTY_readonly)
2489 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_readonly);
2490 if (property_attributes & DW_APPLE_PROPERTY_readwrite)
2491 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_readwrite);
2492 if (property_attributes & DW_APPLE_PROPERTY_assign)
2493 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_assign);
2494 if (property_attributes & DW_APPLE_PROPERTY_retain)
2495 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_retain);
2496 if (property_attributes & DW_APPLE_PROPERTY_copy)
2497 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_copy);
2498 if (property_attributes & DW_APPLE_PROPERTY_nonatomic)
2499 property_decl->setPropertyAttributes (clang::ObjCPropertyDecl::OBJC_PR_nonatomic);
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002500
2501 if (!getter_sel.isNull() && !class_interface_decl->lookupInstanceMethod(getter_sel))
2502 {
2503 QualType result_type = QualType::getFromOpaquePtr(property_opaque_type_to_access);
2504
2505 const bool isInstance = true;
2506 const bool isVariadic = false;
2507 const bool isSynthesized = false;
2508 const bool isImplicitlyDeclared = true;
2509 const bool isDefined = false;
2510 const ObjCMethodDecl::ImplementationControl impControl = ObjCMethodDecl::None;
2511 const bool HasRelatedResultType = false;
2512
2513 ObjCMethodDecl *getter = ObjCMethodDecl::Create(*ast,
2514 SourceLocation(),
2515 SourceLocation(),
2516 getter_sel,
2517 result_type,
2518 NULL,
2519 class_interface_decl,
2520 isInstance,
2521 isVariadic,
2522 isSynthesized,
2523 isImplicitlyDeclared,
2524 isDefined,
2525 impControl,
2526 HasRelatedResultType);
Sean Callananad880762012-04-18 01:06:17 +00002527
2528 if (getter)
2529 SetMetadata(ast, (uintptr_t)getter, metadata);
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002530
2531 getter->setMethodParams(*ast, ArrayRef<ParmVarDecl*>(), ArrayRef<SourceLocation>());
2532
2533 class_interface_decl->addDecl(getter);
2534 }
2535
2536 if (!setter_sel.isNull() && !class_interface_decl->lookupInstanceMethod(setter_sel))
2537 {
2538 QualType result_type = ast->VoidTy;
2539
2540 const bool isInstance = true;
2541 const bool isVariadic = false;
2542 const bool isSynthesized = false;
2543 const bool isImplicitlyDeclared = true;
2544 const bool isDefined = false;
2545 const ObjCMethodDecl::ImplementationControl impControl = ObjCMethodDecl::None;
2546 const bool HasRelatedResultType = false;
2547
2548 ObjCMethodDecl *setter = ObjCMethodDecl::Create(*ast,
2549 SourceLocation(),
2550 SourceLocation(),
2551 setter_sel,
2552 result_type,
2553 NULL,
2554 class_interface_decl,
2555 isInstance,
2556 isVariadic,
2557 isSynthesized,
2558 isImplicitlyDeclared,
2559 isDefined,
2560 impControl,
2561 HasRelatedResultType);
2562
Sean Callananad880762012-04-18 01:06:17 +00002563 if (setter)
2564 SetMetadata(ast, (uintptr_t)setter, metadata);
2565
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002566 llvm::SmallVector<ParmVarDecl *, 1> params;
2567
2568 params.push_back (ParmVarDecl::Create (*ast,
2569 setter,
2570 SourceLocation(),
2571 SourceLocation(),
2572 NULL, // anonymous
2573 QualType::getFromOpaquePtr(property_opaque_type_to_access),
2574 NULL,
2575 SC_Auto,
2576 SC_Auto,
2577 NULL));
2578
2579 setter->setMethodParams(*ast, ArrayRef<ParmVarDecl*>(params), ArrayRef<SourceLocation>());
2580
2581 class_interface_decl->addDecl(setter);
2582 }
Jim Inghame3ae82a2011-11-12 01:36:43 +00002583
2584 return true;
Sean Callanan8a6a6ac2011-12-09 23:24:26 +00002585 }
Jim Inghame3ae82a2011-11-12 01:36:43 +00002586 }
2587 }
2588 }
Greg Clayton8cf05932010-07-22 18:30:50 +00002589 return false;
2590}
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002591
Greg Clayton9e409562010-07-28 02:04:09 +00002592bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00002593ClangASTContext::ObjCTypeHasIVars (clang_type_t class_opaque_type, bool check_superclass)
Greg Clayton9e409562010-07-28 02:04:09 +00002594{
2595 QualType class_qual_type(QualType::getFromOpaquePtr(class_opaque_type));
2596
Sean Callanan78e37602011-01-27 04:42:51 +00002597 const clang::Type *class_type = class_qual_type.getTypePtr();
Greg Clayton9e409562010-07-28 02:04:09 +00002598 if (class_type)
2599 {
Sean Callanan78e37602011-01-27 04:42:51 +00002600 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(class_type);
Greg Clayton9e409562010-07-28 02:04:09 +00002601
2602 if (objc_class_type)
2603 return ObjCDeclHasIVars (objc_class_type->getInterface(), check_superclass);
2604 }
2605 return false;
2606}
2607
2608bool
2609ClangASTContext::ObjCDeclHasIVars (ObjCInterfaceDecl *class_interface_decl, bool check_superclass)
2610{
2611 while (class_interface_decl)
2612 {
2613 if (class_interface_decl->ivar_size() > 0)
2614 return true;
2615
2616 if (check_superclass)
2617 class_interface_decl = class_interface_decl->getSuperClass();
2618 else
2619 break;
2620 }
2621 return false;
2622}
Greg Clayton0fffff52010-09-24 05:15:53 +00002623
Greg Clayton1be10fc2010-09-29 01:12:09 +00002624ObjCMethodDecl *
Greg Clayton0fffff52010-09-24 05:15:53 +00002625ClangASTContext::AddMethodToObjCObjectType
2626(
Greg Clayton6beaaa62011-01-17 03:46:26 +00002627 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00002628 clang_type_t class_opaque_type,
Greg Clayton0fffff52010-09-24 05:15:53 +00002629 const char *name, // the full symbol name as seen in the symbol table ("-[NString stringWithCString:]")
Greg Clayton1be10fc2010-09-29 01:12:09 +00002630 clang_type_t method_opaque_type,
Greg Clayton0fffff52010-09-24 05:15:53 +00002631 lldb::AccessType access
2632)
2633{
2634 if (class_opaque_type == NULL || method_opaque_type == NULL)
2635 return NULL;
2636
Greg Clayton6beaaa62011-01-17 03:46:26 +00002637 IdentifierTable *identifier_table = &ast->Idents;
Greg Clayton0fffff52010-09-24 05:15:53 +00002638
Greg Clayton6beaaa62011-01-17 03:46:26 +00002639 assert (ast != NULL);
Greg Clayton0fffff52010-09-24 05:15:53 +00002640 assert (identifier_table != NULL);
2641
2642 QualType class_qual_type(QualType::getFromOpaquePtr(class_opaque_type));
2643
Sean Callanan78e37602011-01-27 04:42:51 +00002644 const clang::Type *class_type = class_qual_type.getTypePtr();
Greg Clayton0fffff52010-09-24 05:15:53 +00002645 if (class_type == NULL)
2646 return NULL;
2647
Sean Callanan78e37602011-01-27 04:42:51 +00002648 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(class_type);
Greg Clayton0fffff52010-09-24 05:15:53 +00002649
2650 if (objc_class_type == NULL)
2651 return NULL;
2652
2653 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
2654
2655 if (class_interface_decl == NULL)
2656 return NULL;
Greg Clayton9e409562010-07-28 02:04:09 +00002657
Greg Clayton0fffff52010-09-24 05:15:53 +00002658 const char *selector_start = ::strchr (name, ' ');
2659 if (selector_start == NULL)
2660 return NULL;
2661
2662 selector_start++;
2663 if (!(::isalpha (selector_start[0]) || selector_start[0] == '_'))
2664 return NULL;
2665 llvm::SmallVector<IdentifierInfo *, 12> selector_idents;
2666
Greg Clayton450e3f32010-10-12 02:24:53 +00002667 size_t len = 0;
Greg Clayton0fffff52010-09-24 05:15:53 +00002668 const char *start;
Greg Clayton450e3f32010-10-12 02:24:53 +00002669 //printf ("name = '%s'\n", name);
2670
2671 unsigned num_selectors_with_args = 0;
2672 for (start = selector_start;
Greg Clayton0fffff52010-09-24 05:15:53 +00002673 start && *start != '\0' && *start != ']';
Greg Clayton450e3f32010-10-12 02:24:53 +00002674 start += len)
Greg Clayton0fffff52010-09-24 05:15:53 +00002675 {
Greg Clayton450e3f32010-10-12 02:24:53 +00002676 len = ::strcspn(start, ":]");
Greg Clayton90f90cd2010-10-27 04:01:14 +00002677 bool has_arg = (start[len] == ':');
2678 if (has_arg)
Greg Clayton450e3f32010-10-12 02:24:53 +00002679 ++num_selectors_with_args;
Greg Clayton0fffff52010-09-24 05:15:53 +00002680 selector_idents.push_back (&identifier_table->get (StringRef (start, len)));
Greg Clayton90f90cd2010-10-27 04:01:14 +00002681 if (has_arg)
2682 len += 1;
Greg Clayton0fffff52010-09-24 05:15:53 +00002683 }
2684
2685
2686 if (selector_idents.size() == 0)
2687 return 0;
2688
Greg Clayton6beaaa62011-01-17 03:46:26 +00002689 clang::Selector method_selector = ast->Selectors.getSelector (num_selectors_with_args ? selector_idents.size() : 0,
Greg Clayton0fffff52010-09-24 05:15:53 +00002690 selector_idents.data());
2691
2692 QualType method_qual_type (QualType::getFromOpaquePtr (method_opaque_type));
2693
2694 // Populate the method decl with parameter decls
Sean Callanan78e37602011-01-27 04:42:51 +00002695 const clang::Type *method_type(method_qual_type.getTypePtr());
Greg Clayton0fffff52010-09-24 05:15:53 +00002696
2697 if (method_type == NULL)
2698 return NULL;
2699
Sean Callanan78e37602011-01-27 04:42:51 +00002700 const FunctionProtoType *method_function_prototype (dyn_cast<FunctionProtoType>(method_type));
Greg Clayton0fffff52010-09-24 05:15:53 +00002701
2702 if (!method_function_prototype)
2703 return NULL;
2704
2705
2706 bool is_variadic = false;
2707 bool is_synthesized = false;
2708 bool is_defined = false;
2709 ObjCMethodDecl::ImplementationControl imp_control = ObjCMethodDecl::None;
2710
2711 const unsigned num_args = method_function_prototype->getNumArgs();
2712
Greg Clayton6beaaa62011-01-17 03:46:26 +00002713 ObjCMethodDecl *objc_method_decl = ObjCMethodDecl::Create (*ast,
Greg Clayton0fffff52010-09-24 05:15:53 +00002714 SourceLocation(), // beginLoc,
2715 SourceLocation(), // endLoc,
2716 method_selector,
2717 method_function_prototype->getResultType(),
2718 NULL, // TypeSourceInfo *ResultTInfo,
2719 GetDeclContextForType (class_opaque_type),
2720 name[0] == '-',
2721 is_variadic,
2722 is_synthesized,
Sean Callanan880e6802011-10-07 23:18:13 +00002723 true, // is_implicitly_declared
Greg Clayton0fffff52010-09-24 05:15:53 +00002724 is_defined,
2725 imp_control,
Sean Callanan880e6802011-10-07 23:18:13 +00002726 false /*has_related_result_type*/);
Greg Clayton0fffff52010-09-24 05:15:53 +00002727
2728
2729 if (objc_method_decl == NULL)
2730 return NULL;
2731
2732 if (num_args > 0)
2733 {
2734 llvm::SmallVector<ParmVarDecl *, 12> params;
2735
2736 for (int param_index = 0; param_index < num_args; ++param_index)
2737 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00002738 params.push_back (ParmVarDecl::Create (*ast,
Greg Clayton0fffff52010-09-24 05:15:53 +00002739 objc_method_decl,
2740 SourceLocation(),
Sean Callananfb0b7582011-03-15 00:17:19 +00002741 SourceLocation(),
Greg Clayton0fffff52010-09-24 05:15:53 +00002742 NULL, // anonymous
2743 method_function_prototype->getArgType(param_index),
2744 NULL,
2745 SC_Auto,
2746 SC_Auto,
2747 NULL));
2748 }
2749
Sean Callanan880e6802011-10-07 23:18:13 +00002750 objc_method_decl->setMethodParams(*ast, ArrayRef<ParmVarDecl*>(params), ArrayRef<SourceLocation>());
Greg Clayton0fffff52010-09-24 05:15:53 +00002751 }
2752
2753 class_interface_decl->addDecl (objc_method_decl);
2754
Sean Callanan5e9e1992011-10-26 01:06:27 +00002755#ifdef LLDB_CONFIGURATION_DEBUG
2756 VerifyDecl(objc_method_decl);
2757#endif
Greg Clayton0fffff52010-09-24 05:15:53 +00002758
2759 return objc_method_decl;
2760}
2761
Greg Clayton402230e2012-02-03 01:30:30 +00002762size_t
2763ClangASTContext::GetNumTemplateArguments (clang::ASTContext *ast, clang_type_t clang_type)
2764{
2765 if (clang_type)
2766 {
2767 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
2768
2769 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
2770 switch (type_class)
2771 {
2772 case clang::Type::Record:
2773 if (GetCompleteQualType (ast, qual_type))
2774 {
2775 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
2776 if (cxx_record_decl)
2777 {
2778 const ClassTemplateSpecializationDecl *template_decl = dyn_cast<ClassTemplateSpecializationDecl>(cxx_record_decl);
2779 if (template_decl)
2780 return template_decl->getTemplateArgs().size();
2781 }
2782 }
2783 break;
2784
2785 case clang::Type::Typedef:
2786 return ClangASTContext::GetNumTemplateArguments (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
2787 default:
2788 break;
2789 }
2790 }
2791 return 0;
2792}
2793
2794clang_type_t
2795ClangASTContext::GetTemplateArgument (clang::ASTContext *ast, clang_type_t clang_type, size_t arg_idx, lldb::TemplateArgumentKind &kind)
2796{
2797 if (clang_type)
2798 {
2799 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
2800
2801 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
2802 switch (type_class)
2803 {
2804 case clang::Type::Record:
2805 if (GetCompleteQualType (ast, qual_type))
2806 {
2807 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
2808 if (cxx_record_decl)
2809 {
2810 const ClassTemplateSpecializationDecl *template_decl = dyn_cast<ClassTemplateSpecializationDecl>(cxx_record_decl);
2811 if (template_decl && arg_idx < template_decl->getTemplateArgs().size())
2812 {
2813 const TemplateArgument &template_arg = template_decl->getTemplateArgs()[arg_idx];
2814 switch (template_arg.getKind())
2815 {
2816 case clang::TemplateArgument::Null:
2817 kind = eTemplateArgumentKindNull;
2818 return NULL;
2819
2820 case clang::TemplateArgument::Type:
2821 kind = eTemplateArgumentKindType;
2822 return template_arg.getAsType().getAsOpaquePtr();
2823
2824 case clang::TemplateArgument::Declaration:
2825 kind = eTemplateArgumentKindDeclaration;
2826 return NULL;
2827
2828 case clang::TemplateArgument::Integral:
2829 kind = eTemplateArgumentKindIntegral;
2830 return template_arg.getIntegralType().getAsOpaquePtr();
2831
2832 case clang::TemplateArgument::Template:
2833 kind = eTemplateArgumentKindTemplate;
2834 return NULL;
2835
2836 case clang::TemplateArgument::TemplateExpansion:
2837 kind = eTemplateArgumentKindTemplateExpansion;
2838 return NULL;
2839
2840 case clang::TemplateArgument::Expression:
2841 kind = eTemplateArgumentKindExpression;
2842 return NULL;
2843
2844 case clang::TemplateArgument::Pack:
2845 kind = eTemplateArgumentKindPack;
2846 return NULL;
2847
2848 default:
2849 assert (!"Unhandled TemplateArgument::ArgKind");
2850 kind = eTemplateArgumentKindNull;
2851 return NULL;
2852 }
2853 }
2854 }
2855 }
2856 break;
2857
2858 case clang::Type::Typedef:
2859 return ClangASTContext::GetTemplateArgument (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(), arg_idx, kind);
2860 default:
2861 break;
2862 }
2863 }
2864 kind = eTemplateArgumentKindNull;
2865 return NULL;
2866}
Greg Clayton0fffff52010-09-24 05:15:53 +00002867
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002868uint32_t
Greg Clayton73b472d2010-10-27 03:32:59 +00002869ClangASTContext::GetTypeInfo
2870(
2871 clang_type_t clang_type,
Greg Clayton6beaaa62011-01-17 03:46:26 +00002872 clang::ASTContext *ast,
Greg Clayton73b472d2010-10-27 03:32:59 +00002873 clang_type_t *pointee_or_element_clang_type
2874)
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002875{
2876 if (clang_type == NULL)
Greg Clayton73b472d2010-10-27 03:32:59 +00002877 return 0;
2878
2879 if (pointee_or_element_clang_type)
2880 *pointee_or_element_clang_type = NULL;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002881
2882 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
2883
2884 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
2885 switch (type_class)
2886 {
Sean Callanana2424172010-10-25 00:29:48 +00002887 case clang::Type::Builtin:
2888 switch (cast<clang::BuiltinType>(qual_type)->getKind())
2889 {
Sean Callanana2424172010-10-25 00:29:48 +00002890 case clang::BuiltinType::ObjCId:
2891 case clang::BuiltinType::ObjCClass:
Greg Clayton6beaaa62011-01-17 03:46:26 +00002892 if (ast && pointee_or_element_clang_type)
2893 *pointee_or_element_clang_type = ast->ObjCBuiltinClassTy.getAsOpaquePtr();
Sean Callanana2424172010-10-25 00:29:48 +00002894 return eTypeIsBuiltIn | eTypeIsPointer | eTypeHasValue;
Enrico Granataf9fa6ee2011-07-12 00:18:11 +00002895 break;
2896 case clang::BuiltinType::Bool:
2897 case clang::BuiltinType::Char_U:
2898 case clang::BuiltinType::UChar:
2899 case clang::BuiltinType::WChar_U:
2900 case clang::BuiltinType::Char16:
2901 case clang::BuiltinType::Char32:
2902 case clang::BuiltinType::UShort:
2903 case clang::BuiltinType::UInt:
2904 case clang::BuiltinType::ULong:
2905 case clang::BuiltinType::ULongLong:
2906 case clang::BuiltinType::UInt128:
2907 case clang::BuiltinType::Char_S:
2908 case clang::BuiltinType::SChar:
2909 case clang::BuiltinType::WChar_S:
2910 case clang::BuiltinType::Short:
2911 case clang::BuiltinType::Int:
2912 case clang::BuiltinType::Long:
2913 case clang::BuiltinType::LongLong:
2914 case clang::BuiltinType::Int128:
2915 case clang::BuiltinType::Float:
2916 case clang::BuiltinType::Double:
2917 case clang::BuiltinType::LongDouble:
2918 return eTypeIsBuiltIn | eTypeHasValue | eTypeIsScalar;
Greg Clayton73b472d2010-10-27 03:32:59 +00002919 default:
2920 break;
Sean Callanana2424172010-10-25 00:29:48 +00002921 }
2922 return eTypeIsBuiltIn | eTypeHasValue;
Greg Clayton73b472d2010-10-27 03:32:59 +00002923
2924 case clang::Type::BlockPointer:
2925 if (pointee_or_element_clang_type)
2926 *pointee_or_element_clang_type = qual_type->getPointeeType().getAsOpaquePtr();
2927 return eTypeIsPointer | eTypeHasChildren | eTypeIsBlock;
2928
Greg Clayton49462ea2011-01-15 02:52:14 +00002929 case clang::Type::Complex: return eTypeIsBuiltIn | eTypeHasValue;
Greg Clayton73b472d2010-10-27 03:32:59 +00002930
2931 case clang::Type::ConstantArray:
2932 case clang::Type::DependentSizedArray:
2933 case clang::Type::IncompleteArray:
2934 case clang::Type::VariableArray:
2935 if (pointee_or_element_clang_type)
2936 *pointee_or_element_clang_type = cast<ArrayType>(qual_type.getTypePtr())->getElementType().getAsOpaquePtr();
2937 return eTypeHasChildren | eTypeIsArray;
2938
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002939 case clang::Type::DependentName: return 0;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002940 case clang::Type::DependentSizedExtVector: return eTypeHasChildren | eTypeIsVector;
2941 case clang::Type::DependentTemplateSpecialization: return eTypeIsTemplate;
2942 case clang::Type::Decltype: return 0;
Greg Clayton73b472d2010-10-27 03:32:59 +00002943
2944 case clang::Type::Enum:
2945 if (pointee_or_element_clang_type)
2946 *pointee_or_element_clang_type = cast<EnumType>(qual_type)->getDecl()->getIntegerType().getAsOpaquePtr();
2947 return eTypeIsEnumeration | eTypeHasValue;
2948
Sean Callanan912855f2011-08-11 23:56:13 +00002949 case clang::Type::Elaborated:
2950 return ClangASTContext::GetTypeInfo (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
2951 ast,
2952 pointee_or_element_clang_type);
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002953 case clang::Type::ExtVector: return eTypeHasChildren | eTypeIsVector;
2954 case clang::Type::FunctionProto: return eTypeIsFuncPrototype | eTypeHasValue;
2955 case clang::Type::FunctionNoProto: return eTypeIsFuncPrototype | eTypeHasValue;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002956 case clang::Type::InjectedClassName: return 0;
Greg Clayton73b472d2010-10-27 03:32:59 +00002957
2958 case clang::Type::LValueReference:
2959 case clang::Type::RValueReference:
2960 if (pointee_or_element_clang_type)
2961 *pointee_or_element_clang_type = cast<ReferenceType>(qual_type.getTypePtr())->getPointeeType().getAsOpaquePtr();
2962 return eTypeHasChildren | eTypeIsReference | eTypeHasValue;
2963
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002964 case clang::Type::MemberPointer: return eTypeIsPointer | eTypeIsMember | eTypeHasValue;
Greg Clayton73b472d2010-10-27 03:32:59 +00002965
2966 case clang::Type::ObjCObjectPointer:
2967 if (pointee_or_element_clang_type)
2968 *pointee_or_element_clang_type = qual_type->getPointeeType().getAsOpaquePtr();
2969 return eTypeHasChildren | eTypeIsObjC | eTypeIsClass | eTypeIsPointer | eTypeHasValue;
2970
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002971 case clang::Type::ObjCObject: return eTypeHasChildren | eTypeIsObjC | eTypeIsClass;
2972 case clang::Type::ObjCInterface: return eTypeHasChildren | eTypeIsObjC | eTypeIsClass;
Greg Clayton73b472d2010-10-27 03:32:59 +00002973
2974 case clang::Type::Pointer:
2975 if (pointee_or_element_clang_type)
2976 *pointee_or_element_clang_type = qual_type->getPointeeType().getAsOpaquePtr();
2977 return eTypeHasChildren | eTypeIsPointer | eTypeHasValue;
2978
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002979 case clang::Type::Record:
2980 if (qual_type->getAsCXXRecordDecl())
2981 return eTypeHasChildren | eTypeIsClass | eTypeIsCPlusPlus;
2982 else
2983 return eTypeHasChildren | eTypeIsStructUnion;
2984 break;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002985 case clang::Type::SubstTemplateTypeParm: return eTypeIsTemplate;
2986 case clang::Type::TemplateTypeParm: return eTypeIsTemplate;
2987 case clang::Type::TemplateSpecialization: return eTypeIsTemplate;
Greg Clayton73b472d2010-10-27 03:32:59 +00002988
2989 case clang::Type::Typedef:
Sean Callanan48114472010-12-13 01:26:27 +00002990 return eTypeIsTypedef | ClangASTContext::GetTypeInfo (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00002991 ast,
Greg Clayton73b472d2010-10-27 03:32:59 +00002992 pointee_or_element_clang_type);
2993
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002994 case clang::Type::TypeOfExpr: return 0;
2995 case clang::Type::TypeOf: return 0;
2996 case clang::Type::UnresolvedUsing: return 0;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00002997 case clang::Type::Vector: return eTypeHasChildren | eTypeIsVector;
2998 default: return 0;
2999 }
3000 return 0;
3001}
3002
Greg Clayton9e409562010-07-28 02:04:09 +00003003
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003004#pragma mark Aggregate Types
3005
3006bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00003007ClangASTContext::IsAggregateType (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003008{
3009 if (clang_type == NULL)
3010 return false;
3011
3012 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
3013
Greg Clayton737b9322010-09-13 03:32:57 +00003014 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3015 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003016 {
Greg Claytone1a916a2010-07-21 22:12:05 +00003017 case clang::Type::IncompleteArray:
3018 case clang::Type::VariableArray:
3019 case clang::Type::ConstantArray:
3020 case clang::Type::ExtVector:
3021 case clang::Type::Vector:
3022 case clang::Type::Record:
Greg Clayton9e409562010-07-28 02:04:09 +00003023 case clang::Type::ObjCObject:
3024 case clang::Type::ObjCInterface:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003025 return true;
Sean Callanan912855f2011-08-11 23:56:13 +00003026 case clang::Type::Elaborated:
3027 return ClangASTContext::IsAggregateType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Greg Claytone1a916a2010-07-21 22:12:05 +00003028 case clang::Type::Typedef:
Sean Callanan48114472010-12-13 01:26:27 +00003029 return ClangASTContext::IsAggregateType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003030
3031 default:
3032 break;
3033 }
3034 // The clang type does have a value
3035 return false;
3036}
3037
3038uint32_t
Greg Clayton6beaaa62011-01-17 03:46:26 +00003039ClangASTContext::GetNumChildren (clang::ASTContext *ast, clang_type_t clang_type, bool omit_empty_base_classes)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003040{
Greg Clayton6beaaa62011-01-17 03:46:26 +00003041 if (clang_type == NULL)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003042 return 0;
3043
3044 uint32_t num_children = 0;
Greg Clayton6beaaa62011-01-17 03:46:26 +00003045 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
Greg Clayton9e409562010-07-28 02:04:09 +00003046 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3047 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003048 {
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003049 case clang::Type::Builtin:
3050 switch (cast<clang::BuiltinType>(qual_type)->getKind())
3051 {
Greg Clayton73b472d2010-10-27 03:32:59 +00003052 case clang::BuiltinType::ObjCId: // child is Class
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003053 case clang::BuiltinType::ObjCClass: // child is Class
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003054 num_children = 1;
Greg Clayton73b472d2010-10-27 03:32:59 +00003055 break;
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003056
3057 default:
3058 break;
3059 }
3060 break;
Greg Clayton54979cd2010-12-15 05:08:08 +00003061
Greg Clayton49462ea2011-01-15 02:52:14 +00003062 case clang::Type::Complex: return 0;
Greg Clayton54979cd2010-12-15 05:08:08 +00003063
Greg Claytone1a916a2010-07-21 22:12:05 +00003064 case clang::Type::Record:
Greg Claytonc432c192011-01-20 04:18:48 +00003065 if (GetCompleteQualType (ast, qual_type))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003066 {
3067 const RecordType *record_type = cast<RecordType>(qual_type.getTypePtr());
3068 const RecordDecl *record_decl = record_type->getDecl();
3069 assert(record_decl);
3070 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
3071 if (cxx_record_decl)
3072 {
3073 if (omit_empty_base_classes)
3074 {
3075 // Check each base classes to see if it or any of its
3076 // base classes contain any fields. This can help
3077 // limit the noise in variable views by not having to
3078 // show base classes that contain no members.
3079 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
3080 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
3081 base_class != base_class_end;
3082 ++base_class)
3083 {
3084 const CXXRecordDecl *base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
3085
3086 // Skip empty base classes
3087 if (RecordHasFields(base_class_decl) == false)
3088 continue;
3089
3090 num_children++;
3091 }
3092 }
3093 else
3094 {
3095 // Include all base classes
3096 num_children += cxx_record_decl->getNumBases();
3097 }
3098
3099 }
3100 RecordDecl::field_iterator field, field_end;
3101 for (field = record_decl->field_begin(), field_end = record_decl->field_end(); field != field_end; ++field)
3102 ++num_children;
3103 }
3104 break;
3105
Greg Clayton9e409562010-07-28 02:04:09 +00003106 case clang::Type::ObjCObject:
3107 case clang::Type::ObjCInterface:
Greg Claytonc432c192011-01-20 04:18:48 +00003108 if (GetCompleteQualType (ast, qual_type))
Greg Clayton9e409562010-07-28 02:04:09 +00003109 {
Sean Callanan78e37602011-01-27 04:42:51 +00003110 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00003111 assert (objc_class_type);
3112 if (objc_class_type)
3113 {
3114 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3115
3116 if (class_interface_decl)
3117 {
3118
3119 ObjCInterfaceDecl *superclass_interface_decl = class_interface_decl->getSuperClass();
3120 if (superclass_interface_decl)
3121 {
3122 if (omit_empty_base_classes)
3123 {
3124 if (ClangASTContext::ObjCDeclHasIVars (superclass_interface_decl, true))
3125 ++num_children;
3126 }
3127 else
3128 ++num_children;
3129 }
3130
3131 num_children += class_interface_decl->ivar_size();
3132 }
3133 }
3134 }
3135 break;
3136
3137 case clang::Type::ObjCObjectPointer:
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003138 {
Sean Callanan78e37602011-01-27 04:42:51 +00003139 const ObjCObjectPointerType *pointer_type = cast<ObjCObjectPointerType>(qual_type.getTypePtr());
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003140 QualType pointee_type = pointer_type->getPointeeType();
Greg Clayton6beaaa62011-01-17 03:46:26 +00003141 uint32_t num_pointee_children = ClangASTContext::GetNumChildren (ast,
3142 pointee_type.getAsOpaquePtr(),
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003143 omit_empty_base_classes);
3144 // If this type points to a simple type, then it has 1 child
3145 if (num_pointee_children == 0)
3146 num_children = 1;
3147 else
3148 num_children = num_pointee_children;
3149 }
3150 break;
Greg Clayton9e409562010-07-28 02:04:09 +00003151
Greg Claytone1a916a2010-07-21 22:12:05 +00003152 case clang::Type::ConstantArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003153 num_children = cast<ConstantArrayType>(qual_type.getTypePtr())->getSize().getLimitedValue();
3154 break;
3155
Greg Claytone1a916a2010-07-21 22:12:05 +00003156 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003157 {
Sean Callanan78e37602011-01-27 04:42:51 +00003158 const PointerType *pointer_type = cast<PointerType>(qual_type.getTypePtr());
Greg Clayton54979cd2010-12-15 05:08:08 +00003159 QualType pointee_type (pointer_type->getPointeeType());
Greg Clayton6beaaa62011-01-17 03:46:26 +00003160 uint32_t num_pointee_children = ClangASTContext::GetNumChildren (ast,
3161 pointee_type.getAsOpaquePtr(),
Greg Clayton9e409562010-07-28 02:04:09 +00003162 omit_empty_base_classes);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003163 if (num_pointee_children == 0)
Greg Clayton54979cd2010-12-15 05:08:08 +00003164 {
3165 // We have a pointer to a pointee type that claims it has no children.
3166 // We will want to look at
3167 num_children = ClangASTContext::GetNumPointeeChildren (pointee_type.getAsOpaquePtr());
3168 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003169 else
3170 num_children = num_pointee_children;
3171 }
3172 break;
3173
Greg Clayton73b472d2010-10-27 03:32:59 +00003174 case clang::Type::LValueReference:
3175 case clang::Type::RValueReference:
3176 {
Sean Callanan78e37602011-01-27 04:42:51 +00003177 const ReferenceType *reference_type = cast<ReferenceType>(qual_type.getTypePtr());
Greg Clayton73b472d2010-10-27 03:32:59 +00003178 QualType pointee_type = reference_type->getPointeeType();
Greg Clayton6beaaa62011-01-17 03:46:26 +00003179 uint32_t num_pointee_children = ClangASTContext::GetNumChildren (ast,
3180 pointee_type.getAsOpaquePtr(),
Greg Clayton73b472d2010-10-27 03:32:59 +00003181 omit_empty_base_classes);
3182 // If this type points to a simple type, then it has 1 child
3183 if (num_pointee_children == 0)
3184 num_children = 1;
3185 else
3186 num_children = num_pointee_children;
3187 }
3188 break;
3189
3190
Greg Claytone1a916a2010-07-21 22:12:05 +00003191 case clang::Type::Typedef:
Greg Clayton6beaaa62011-01-17 03:46:26 +00003192 num_children = ClangASTContext::GetNumChildren (ast,
3193 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
3194 omit_empty_base_classes);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003195 break;
Sean Callanan912855f2011-08-11 23:56:13 +00003196
3197 case clang::Type::Elaborated:
3198 num_children = ClangASTContext::GetNumChildren (ast,
3199 cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
3200 omit_empty_base_classes);
3201 break;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003202
3203 default:
3204 break;
3205 }
3206 return num_children;
3207}
3208
Greg Claytonbf2331c2011-09-09 23:04:00 +00003209uint32_t
3210ClangASTContext::GetNumDirectBaseClasses (clang::ASTContext *ast, clang_type_t clang_type)
3211{
3212 if (clang_type == NULL)
3213 return 0;
3214
3215 uint32_t count = 0;
3216 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3217 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3218 switch (type_class)
3219 {
3220 case clang::Type::Record:
3221 if (GetCompleteQualType (ast, qual_type))
3222 {
3223 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
3224 if (cxx_record_decl)
3225 count = cxx_record_decl->getNumBases();
3226 }
3227 break;
3228
3229 case clang::Type::ObjCObject:
3230 case clang::Type::ObjCInterface:
3231 if (GetCompleteQualType (ast, qual_type))
3232 {
3233 const ObjCObjectType *objc_class_type = qual_type->getAsObjCQualifiedInterfaceType();
3234 if (objc_class_type)
3235 {
3236 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3237
3238 if (class_interface_decl && class_interface_decl->getSuperClass())
3239 count = 1;
3240 }
3241 }
3242 break;
3243
3244
3245 case clang::Type::Typedef:
3246 count = ClangASTContext::GetNumDirectBaseClasses (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
3247 break;
3248
3249 case clang::Type::Elaborated:
3250 count = ClangASTContext::GetNumDirectBaseClasses (ast, cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
3251 break;
3252
3253 default:
3254 break;
3255 }
3256 return count;
3257}
3258
3259uint32_t
3260ClangASTContext::GetNumVirtualBaseClasses (clang::ASTContext *ast,
3261 clang_type_t clang_type)
3262{
3263 if (clang_type == NULL)
3264 return 0;
3265
3266 uint32_t count = 0;
3267 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3268 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3269 switch (type_class)
3270 {
3271 case clang::Type::Record:
3272 if (GetCompleteQualType (ast, qual_type))
3273 {
3274 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
3275 if (cxx_record_decl)
3276 count = cxx_record_decl->getNumVBases();
3277 }
3278 break;
3279
3280 case clang::Type::Typedef:
3281 count = ClangASTContext::GetNumVirtualBaseClasses (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
3282 break;
3283
3284 case clang::Type::Elaborated:
3285 count = ClangASTContext::GetNumVirtualBaseClasses (ast, cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
3286 break;
3287
3288 default:
3289 break;
3290 }
3291 return count;
3292}
3293
3294uint32_t
3295ClangASTContext::GetNumFields (clang::ASTContext *ast, clang_type_t clang_type)
3296{
3297 if (clang_type == NULL)
3298 return 0;
3299
3300 uint32_t count = 0;
3301 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3302 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3303 switch (type_class)
3304 {
3305 case clang::Type::Record:
3306 if (GetCompleteQualType (ast, qual_type))
3307 {
3308 const RecordType *record_type = dyn_cast<RecordType>(qual_type.getTypePtr());
3309 if (record_type)
3310 {
3311 RecordDecl *record_decl = record_type->getDecl();
3312 if (record_decl)
3313 {
3314 uint32_t field_idx = 0;
3315 RecordDecl::field_iterator field, field_end;
3316 for (field = record_decl->field_begin(), field_end = record_decl->field_end(); field != field_end; ++field)
3317 ++field_idx;
3318 count = field_idx;
3319 }
3320 }
3321 }
3322 break;
3323
3324 case clang::Type::Typedef:
3325 count = ClangASTContext::GetNumFields (ast, cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
3326 break;
3327
3328 case clang::Type::Elaborated:
3329 count = ClangASTContext::GetNumFields (ast, cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
3330 break;
3331
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003332 case clang::Type::ObjCObject:
3333 case clang::Type::ObjCInterface:
3334 if (GetCompleteQualType (ast, qual_type))
3335 {
3336 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
3337 if (objc_class_type)
3338 {
3339 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3340
3341 if (class_interface_decl)
3342 count = class_interface_decl->ivar_size();
3343 }
3344 }
3345 break;
3346
Greg Claytonbf2331c2011-09-09 23:04:00 +00003347 default:
3348 break;
3349 }
3350 return count;
3351}
3352
3353clang_type_t
3354ClangASTContext::GetDirectBaseClassAtIndex (clang::ASTContext *ast,
3355 clang_type_t clang_type,
3356 uint32_t idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003357 uint32_t *bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003358{
3359 if (clang_type == NULL)
3360 return 0;
3361
3362 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3363 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3364 switch (type_class)
3365 {
3366 case clang::Type::Record:
3367 if (GetCompleteQualType (ast, qual_type))
3368 {
3369 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
3370 if (cxx_record_decl)
3371 {
3372 uint32_t curr_idx = 0;
3373 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
3374 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
3375 base_class != base_class_end;
3376 ++base_class, ++curr_idx)
3377 {
3378 if (curr_idx == idx)
3379 {
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003380 if (bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003381 {
3382 const ASTRecordLayout &record_layout = ast->getASTRecordLayout(cxx_record_decl);
3383 const CXXRecordDecl *base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
3384// if (base_class->isVirtual())
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003385// *bit_offset_ptr = record_layout.getVBaseClassOffset(base_class_decl).getQuantity() * 8;
Greg Claytonbf2331c2011-09-09 23:04:00 +00003386// else
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003387 *bit_offset_ptr = record_layout.getBaseClassOffset(base_class_decl).getQuantity() * 8;
Greg Claytonbf2331c2011-09-09 23:04:00 +00003388 }
3389 return base_class->getType().getAsOpaquePtr();
3390 }
3391 }
3392 }
3393 }
3394 break;
3395
3396 case clang::Type::ObjCObject:
3397 case clang::Type::ObjCInterface:
3398 if (idx == 0 && GetCompleteQualType (ast, qual_type))
3399 {
3400 const ObjCObjectType *objc_class_type = qual_type->getAsObjCQualifiedInterfaceType();
3401 if (objc_class_type)
3402 {
3403 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3404
3405 if (class_interface_decl)
3406 {
3407 ObjCInterfaceDecl *superclass_interface_decl = class_interface_decl->getSuperClass();
3408 if (superclass_interface_decl)
3409 {
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003410 if (bit_offset_ptr)
3411 *bit_offset_ptr = 0;
Greg Claytonbf2331c2011-09-09 23:04:00 +00003412 return ast->getObjCInterfaceType(superclass_interface_decl).getAsOpaquePtr();
3413 }
3414 }
3415 }
3416 }
3417 break;
3418
3419
3420 case clang::Type::Typedef:
3421 return ClangASTContext::GetDirectBaseClassAtIndex (ast,
3422 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
3423 idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003424 bit_offset_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003425
3426 case clang::Type::Elaborated:
3427 return ClangASTContext::GetDirectBaseClassAtIndex (ast,
3428 cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
3429 idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003430 bit_offset_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003431
3432 default:
3433 break;
3434 }
3435 return NULL;
3436}
3437
3438clang_type_t
3439ClangASTContext::GetVirtualBaseClassAtIndex (clang::ASTContext *ast,
3440 clang_type_t clang_type,
3441 uint32_t idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003442 uint32_t *bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003443{
3444 if (clang_type == NULL)
3445 return 0;
3446
3447 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3448 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3449 switch (type_class)
3450 {
3451 case clang::Type::Record:
3452 if (GetCompleteQualType (ast, qual_type))
3453 {
3454 const CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
3455 if (cxx_record_decl)
3456 {
3457 uint32_t curr_idx = 0;
3458 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
3459 for (base_class = cxx_record_decl->vbases_begin(), base_class_end = cxx_record_decl->vbases_end();
3460 base_class != base_class_end;
3461 ++base_class, ++curr_idx)
3462 {
3463 if (curr_idx == idx)
3464 {
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003465 if (bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003466 {
3467 const ASTRecordLayout &record_layout = ast->getASTRecordLayout(cxx_record_decl);
3468 const CXXRecordDecl *base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003469 *bit_offset_ptr = record_layout.getVBaseClassOffset(base_class_decl).getQuantity() * 8;
Greg Claytonbf2331c2011-09-09 23:04:00 +00003470
3471 }
3472 return base_class->getType().getAsOpaquePtr();
3473 }
3474 }
3475 }
3476 }
3477 break;
3478
3479 case clang::Type::Typedef:
3480 return ClangASTContext::GetVirtualBaseClassAtIndex (ast,
3481 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
3482 idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003483 bit_offset_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003484
3485 case clang::Type::Elaborated:
3486 return ClangASTContext::GetVirtualBaseClassAtIndex (ast,
3487 cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
3488 idx,
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003489 bit_offset_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003490
3491 default:
3492 break;
3493 }
3494 return NULL;
3495}
3496
3497clang_type_t
3498ClangASTContext::GetFieldAtIndex (clang::ASTContext *ast,
3499 clang_type_t clang_type,
3500 uint32_t idx,
3501 std::string& name,
Greg Clayton1811b4f2012-07-31 23:39:10 +00003502 uint64_t *bit_offset_ptr,
3503 uint32_t *bitfield_bit_size_ptr,
3504 bool *is_bitfield_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003505{
3506 if (clang_type == NULL)
3507 return 0;
3508
3509 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3510 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3511 switch (type_class)
3512 {
3513 case clang::Type::Record:
3514 if (GetCompleteQualType (ast, qual_type))
3515 {
3516 const RecordType *record_type = cast<RecordType>(qual_type.getTypePtr());
3517 const RecordDecl *record_decl = record_type->getDecl();
3518 uint32_t field_idx = 0;
3519 RecordDecl::field_iterator field, field_end;
3520 for (field = record_decl->field_begin(), field_end = record_decl->field_end(); field != field_end; ++field, ++field_idx)
3521 {
3522 if (idx == field_idx)
3523 {
3524 // Print the member type if requested
3525 // Print the member name and equal sign
3526 name.assign(field->getNameAsString());
3527
3528 // Figure out the type byte size (field_type_info.first) and
3529 // alignment (field_type_info.second) from the AST context.
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003530 if (bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003531 {
3532 const ASTRecordLayout &record_layout = ast->getASTRecordLayout(record_decl);
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003533 *bit_offset_ptr = record_layout.getFieldOffset (field_idx);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003534 }
3535
Greg Clayton1811b4f2012-07-31 23:39:10 +00003536 const bool is_bitfield = field->isBitField();
3537
3538 if (bitfield_bit_size_ptr)
3539 {
3540 *bitfield_bit_size_ptr = 0;
3541
3542 if (is_bitfield && ast)
3543 {
3544 Expr *bitfield_bit_size_expr = field->getBitWidth();
3545 llvm::APSInt bitfield_apsint;
3546 if (bitfield_bit_size_expr && bitfield_bit_size_expr->EvaluateAsInt(bitfield_apsint, *ast))
3547 {
3548 *bitfield_bit_size_ptr = bitfield_apsint.getLimitedValue();
3549 }
3550 }
3551 }
3552 if (is_bitfield_ptr)
3553 *is_bitfield_ptr = is_bitfield;
3554
Greg Claytonbf2331c2011-09-09 23:04:00 +00003555 return field->getType().getAsOpaquePtr();
3556 }
3557 }
3558 }
3559 break;
3560
3561 case clang::Type::ObjCObject:
3562 case clang::Type::ObjCInterface:
3563 if (GetCompleteQualType (ast, qual_type))
3564 {
3565 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
3566 assert (objc_class_type);
3567 if (objc_class_type)
3568 {
3569 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3570
3571 if (class_interface_decl)
3572 {
3573 if (idx < (class_interface_decl->ivar_size()))
3574 {
3575 ObjCInterfaceDecl::ivar_iterator ivar_pos, ivar_end = class_interface_decl->ivar_end();
3576 uint32_t ivar_idx = 0;
3577
3578 for (ivar_pos = class_interface_decl->ivar_begin(); ivar_pos != ivar_end; ++ivar_pos, ++ivar_idx)
3579 {
3580 if (ivar_idx == idx)
3581 {
3582 const ObjCIvarDecl* ivar_decl = *ivar_pos;
3583
3584 QualType ivar_qual_type(ivar_decl->getType());
3585
3586 name.assign(ivar_decl->getNameAsString());
3587
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003588 if (bit_offset_ptr)
Greg Claytonbf2331c2011-09-09 23:04:00 +00003589 {
3590 const ASTRecordLayout &interface_layout = ast->getASTObjCInterfaceLayout(class_interface_decl);
Greg Claytonda7bc7d2011-11-13 06:57:31 +00003591 *bit_offset_ptr = interface_layout.getFieldOffset (ivar_idx);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003592 }
3593
Greg Clayton1811b4f2012-07-31 23:39:10 +00003594 const bool is_bitfield = ivar_pos->isBitField();
3595
3596 if (bitfield_bit_size_ptr)
3597 {
3598 *bitfield_bit_size_ptr = 0;
3599
3600 if (is_bitfield && ast)
3601 {
3602 Expr *bitfield_bit_size_expr = ivar_pos->getBitWidth();
3603 llvm::APSInt bitfield_apsint;
3604 if (bitfield_bit_size_expr && bitfield_bit_size_expr->EvaluateAsInt(bitfield_apsint, *ast))
3605 {
3606 *bitfield_bit_size_ptr = bitfield_apsint.getLimitedValue();
3607 }
3608 }
3609 }
3610 if (is_bitfield_ptr)
3611 *is_bitfield_ptr = is_bitfield;
3612
Greg Claytonbf2331c2011-09-09 23:04:00 +00003613 return ivar_qual_type.getAsOpaquePtr();
3614 }
3615 }
3616 }
3617 }
3618 }
3619 }
3620 break;
3621
3622
3623 case clang::Type::Typedef:
3624 return ClangASTContext::GetFieldAtIndex (ast,
3625 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
3626 idx,
3627 name,
Greg Clayton1811b4f2012-07-31 23:39:10 +00003628 bit_offset_ptr,
3629 bitfield_bit_size_ptr,
3630 is_bitfield_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003631
3632 case clang::Type::Elaborated:
3633 return ClangASTContext::GetFieldAtIndex (ast,
3634 cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
3635 idx,
3636 name,
Greg Clayton1811b4f2012-07-31 23:39:10 +00003637 bit_offset_ptr,
3638 bitfield_bit_size_ptr,
3639 is_bitfield_ptr);
Greg Claytonbf2331c2011-09-09 23:04:00 +00003640
3641 default:
3642 break;
3643 }
3644 return NULL;
3645}
3646
3647
Greg Clayton54979cd2010-12-15 05:08:08 +00003648// If a pointer to a pointee type (the clang_type arg) says that it has no
3649// children, then we either need to trust it, or override it and return a
3650// different result. For example, an "int *" has one child that is an integer,
3651// but a function pointer doesn't have any children. Likewise if a Record type
3652// claims it has no children, then there really is nothing to show.
3653uint32_t
3654ClangASTContext::GetNumPointeeChildren (clang_type_t clang_type)
3655{
3656 if (clang_type == NULL)
3657 return 0;
3658
3659 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
3660 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
3661 switch (type_class)
3662 {
Greg Clayton97a43712011-01-08 22:26:47 +00003663 case clang::Type::Builtin:
3664 switch (cast<clang::BuiltinType>(qual_type)->getKind())
3665 {
Greg Clayton7260f622011-04-18 08:33:37 +00003666 case clang::BuiltinType::UnknownAny:
Greg Clayton97a43712011-01-08 22:26:47 +00003667 case clang::BuiltinType::Void:
3668 case clang::BuiltinType::NullPtr:
3669 return 0;
3670 case clang::BuiltinType::Bool:
3671 case clang::BuiltinType::Char_U:
3672 case clang::BuiltinType::UChar:
Sean Callanan2c777c42011-01-18 23:32:05 +00003673 case clang::BuiltinType::WChar_U:
Greg Clayton97a43712011-01-08 22:26:47 +00003674 case clang::BuiltinType::Char16:
3675 case clang::BuiltinType::Char32:
3676 case clang::BuiltinType::UShort:
3677 case clang::BuiltinType::UInt:
3678 case clang::BuiltinType::ULong:
3679 case clang::BuiltinType::ULongLong:
3680 case clang::BuiltinType::UInt128:
3681 case clang::BuiltinType::Char_S:
3682 case clang::BuiltinType::SChar:
Sean Callanan2c777c42011-01-18 23:32:05 +00003683 case clang::BuiltinType::WChar_S:
Greg Clayton97a43712011-01-08 22:26:47 +00003684 case clang::BuiltinType::Short:
3685 case clang::BuiltinType::Int:
3686 case clang::BuiltinType::Long:
3687 case clang::BuiltinType::LongLong:
3688 case clang::BuiltinType::Int128:
3689 case clang::BuiltinType::Float:
3690 case clang::BuiltinType::Double:
3691 case clang::BuiltinType::LongDouble:
3692 case clang::BuiltinType::Dependent:
3693 case clang::BuiltinType::Overload:
Greg Clayton97a43712011-01-08 22:26:47 +00003694 case clang::BuiltinType::ObjCId:
3695 case clang::BuiltinType::ObjCClass:
3696 case clang::BuiltinType::ObjCSel:
Sean Callanand12cf8bb2011-05-15 22:34:38 +00003697 case clang::BuiltinType::BoundMember:
Greg Claytonf0705c82011-10-22 03:33:13 +00003698 case clang::BuiltinType::Half:
3699 case clang::BuiltinType::ARCUnbridgedCast:
Greg Claytoned3ae702011-11-09 19:04:58 +00003700 case clang::BuiltinType::PseudoObject:
Sean Callanan3d654b32012-09-24 22:25:51 +00003701 case clang::BuiltinType::BuiltinFn:
Greg Clayton97a43712011-01-08 22:26:47 +00003702 return 1;
3703 }
3704 break;
3705
Greg Clayton49462ea2011-01-15 02:52:14 +00003706 case clang::Type::Complex: return 1;
Greg Clayton54979cd2010-12-15 05:08:08 +00003707 case clang::Type::Pointer: return 1;
3708 case clang::Type::BlockPointer: return 0; // If block pointers don't have debug info, then no children for them
3709 case clang::Type::LValueReference: return 1;
3710 case clang::Type::RValueReference: return 1;
3711 case clang::Type::MemberPointer: return 0;
3712 case clang::Type::ConstantArray: return 0;
3713 case clang::Type::IncompleteArray: return 0;
3714 case clang::Type::VariableArray: return 0;
3715 case clang::Type::DependentSizedArray: return 0;
3716 case clang::Type::DependentSizedExtVector: return 0;
3717 case clang::Type::Vector: return 0;
3718 case clang::Type::ExtVector: return 0;
3719 case clang::Type::FunctionProto: return 0; // When we function pointers, they have no children...
3720 case clang::Type::FunctionNoProto: return 0; // When we function pointers, they have no children...
3721 case clang::Type::UnresolvedUsing: return 0;
3722 case clang::Type::Paren: return 0;
3723 case clang::Type::Typedef: return ClangASTContext::GetNumPointeeChildren (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Sean Callanan912855f2011-08-11 23:56:13 +00003724 case clang::Type::Elaborated: return ClangASTContext::GetNumPointeeChildren (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Greg Clayton54979cd2010-12-15 05:08:08 +00003725 case clang::Type::TypeOfExpr: return 0;
3726 case clang::Type::TypeOf: return 0;
3727 case clang::Type::Decltype: return 0;
3728 case clang::Type::Record: return 0;
3729 case clang::Type::Enum: return 1;
Greg Clayton54979cd2010-12-15 05:08:08 +00003730 case clang::Type::TemplateTypeParm: return 1;
3731 case clang::Type::SubstTemplateTypeParm: return 1;
3732 case clang::Type::TemplateSpecialization: return 1;
3733 case clang::Type::InjectedClassName: return 0;
3734 case clang::Type::DependentName: return 1;
3735 case clang::Type::DependentTemplateSpecialization: return 1;
3736 case clang::Type::ObjCObject: return 0;
3737 case clang::Type::ObjCInterface: return 0;
3738 case clang::Type::ObjCObjectPointer: return 1;
3739 default:
3740 break;
3741 }
3742 return 0;
3743}
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003744
Greg Clayton1be10fc2010-09-29 01:12:09 +00003745clang_type_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003746ClangASTContext::GetChildClangTypeAtIndex
3747(
Jim Inghamd555bac2011-06-24 22:03:24 +00003748 ExecutionContext *exe_ctx,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003749 const char *parent_name,
Greg Clayton1be10fc2010-09-29 01:12:09 +00003750 clang_type_t parent_clang_type,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003751 uint32_t idx,
3752 bool transparent_pointers,
3753 bool omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00003754 bool ignore_array_bounds,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003755 std::string& child_name,
3756 uint32_t &child_byte_size,
3757 int32_t &child_byte_offset,
3758 uint32_t &child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003759 uint32_t &child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00003760 bool &child_is_base_class,
3761 bool &child_is_deref_of_parent
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003762)
3763{
3764 if (parent_clang_type)
3765
Jim Inghamd555bac2011-06-24 22:03:24 +00003766 return GetChildClangTypeAtIndex (exe_ctx,
3767 getASTContext(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003768 parent_name,
3769 parent_clang_type,
3770 idx,
3771 transparent_pointers,
3772 omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00003773 ignore_array_bounds,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003774 child_name,
3775 child_byte_size,
3776 child_byte_offset,
3777 child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003778 child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00003779 child_is_base_class,
3780 child_is_deref_of_parent);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003781 return NULL;
3782}
3783
Greg Clayton1be10fc2010-09-29 01:12:09 +00003784clang_type_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003785ClangASTContext::GetChildClangTypeAtIndex
3786(
Jim Inghamd555bac2011-06-24 22:03:24 +00003787 ExecutionContext *exe_ctx,
Greg Clayton6beaaa62011-01-17 03:46:26 +00003788 ASTContext *ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003789 const char *parent_name,
Greg Clayton1be10fc2010-09-29 01:12:09 +00003790 clang_type_t parent_clang_type,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003791 uint32_t idx,
3792 bool transparent_pointers,
3793 bool omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00003794 bool ignore_array_bounds,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003795 std::string& child_name,
3796 uint32_t &child_byte_size,
3797 int32_t &child_byte_offset,
3798 uint32_t &child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003799 uint32_t &child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00003800 bool &child_is_base_class,
3801 bool &child_is_deref_of_parent
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003802)
3803{
3804 if (parent_clang_type == NULL)
3805 return NULL;
3806
Greg Clayton6beaaa62011-01-17 03:46:26 +00003807 if (idx < ClangASTContext::GetNumChildren (ast, parent_clang_type, omit_empty_base_classes))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003808 {
3809 uint32_t bit_offset;
3810 child_bitfield_bit_size = 0;
3811 child_bitfield_bit_offset = 0;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003812 child_is_base_class = false;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003813 QualType parent_qual_type(QualType::getFromOpaquePtr(parent_clang_type));
Greg Clayton737b9322010-09-13 03:32:57 +00003814 const clang::Type::TypeClass parent_type_class = parent_qual_type->getTypeClass();
3815 switch (parent_type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003816 {
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003817 case clang::Type::Builtin:
3818 switch (cast<clang::BuiltinType>(parent_qual_type)->getKind())
3819 {
3820 case clang::BuiltinType::ObjCId:
3821 case clang::BuiltinType::ObjCClass:
Sean Callanana2424172010-10-25 00:29:48 +00003822 child_name = "isa";
Greg Clayton6beaaa62011-01-17 03:46:26 +00003823 child_byte_size = ast->getTypeSize(ast->ObjCBuiltinClassTy) / CHAR_BIT;
3824 return ast->ObjCBuiltinClassTy.getAsOpaquePtr();
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003825
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003826 default:
3827 break;
3828 }
3829 break;
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003830
Greg Claytone1a916a2010-07-21 22:12:05 +00003831 case clang::Type::Record:
Greg Claytonc432c192011-01-20 04:18:48 +00003832 if (GetCompleteQualType (ast, parent_qual_type))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003833 {
3834 const RecordType *record_type = cast<RecordType>(parent_qual_type.getTypePtr());
3835 const RecordDecl *record_decl = record_type->getDecl();
3836 assert(record_decl);
Greg Clayton6beaaa62011-01-17 03:46:26 +00003837 const ASTRecordLayout &record_layout = ast->getASTRecordLayout(record_decl);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003838 uint32_t child_idx = 0;
3839
3840 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
3841 if (cxx_record_decl)
3842 {
3843 // We might have base classes to print out first
3844 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
3845 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
3846 base_class != base_class_end;
3847 ++base_class)
3848 {
3849 const CXXRecordDecl *base_class_decl = NULL;
3850
3851 // Skip empty base classes
3852 if (omit_empty_base_classes)
3853 {
3854 base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
3855 if (RecordHasFields(base_class_decl) == false)
3856 continue;
3857 }
3858
3859 if (idx == child_idx)
3860 {
3861 if (base_class_decl == NULL)
3862 base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
3863
3864
3865 if (base_class->isVirtual())
Greg Clayton6ed95942011-01-22 07:12:45 +00003866 bit_offset = record_layout.getVBaseClassOffset(base_class_decl).getQuantity() * 8;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003867 else
Greg Clayton6ed95942011-01-22 07:12:45 +00003868 bit_offset = record_layout.getBaseClassOffset(base_class_decl).getQuantity() * 8;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003869
3870 // Base classes should be a multiple of 8 bits in size
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003871 child_byte_offset = bit_offset/8;
Greg Claytone3055942011-06-30 02:28:26 +00003872
Greg Clayton84db9102012-03-26 23:03:23 +00003873 child_name = ClangASTType::GetTypeNameForQualType(ast, base_class->getType());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003874
Greg Clayton6beaaa62011-01-17 03:46:26 +00003875 uint64_t clang_type_info_bit_size = ast->getTypeSize(base_class->getType());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003876
Jim Inghamf46b3382011-04-15 23:42:06 +00003877 // Base classes bit sizes should be a multiple of 8 bits in size
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003878 assert (clang_type_info_bit_size % 8 == 0);
3879 child_byte_size = clang_type_info_bit_size / 8;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003880 child_is_base_class = true;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003881 return base_class->getType().getAsOpaquePtr();
3882 }
3883 // We don't increment the child index in the for loop since we might
3884 // be skipping empty base classes
3885 ++child_idx;
3886 }
3887 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003888 // Make sure index is in range...
3889 uint32_t field_idx = 0;
3890 RecordDecl::field_iterator field, field_end;
3891 for (field = record_decl->field_begin(), field_end = record_decl->field_end(); field != field_end; ++field, ++field_idx, ++child_idx)
3892 {
3893 if (idx == child_idx)
3894 {
3895 // Print the member type if requested
3896 // Print the member name and equal sign
3897 child_name.assign(field->getNameAsString().c_str());
3898
3899 // Figure out the type byte size (field_type_info.first) and
3900 // alignment (field_type_info.second) from the AST context.
Greg Clayton6beaaa62011-01-17 03:46:26 +00003901 std::pair<uint64_t, unsigned> field_type_info = ast->getTypeInfo(field->getType());
Greg Claytonc982c762010-07-09 20:39:50 +00003902 assert(field_idx < record_layout.getFieldCount());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003903
3904 child_byte_size = field_type_info.first / 8;
3905
3906 // Figure out the field offset within the current struct/union/class type
3907 bit_offset = record_layout.getFieldOffset (field_idx);
3908 child_byte_offset = bit_offset / 8;
Greg Clayton6beaaa62011-01-17 03:46:26 +00003909 if (ClangASTContext::FieldIsBitfield (ast, *field, child_bitfield_bit_size))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003910 child_bitfield_bit_offset = bit_offset % 8;
3911
3912 return field->getType().getAsOpaquePtr();
3913 }
3914 }
3915 }
3916 break;
3917
Greg Clayton9e409562010-07-28 02:04:09 +00003918 case clang::Type::ObjCObject:
3919 case clang::Type::ObjCInterface:
Greg Claytonc432c192011-01-20 04:18:48 +00003920 if (GetCompleteQualType (ast, parent_qual_type))
Greg Clayton9e409562010-07-28 02:04:09 +00003921 {
Sean Callanan78e37602011-01-27 04:42:51 +00003922 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(parent_qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00003923 assert (objc_class_type);
3924 if (objc_class_type)
3925 {
3926 uint32_t child_idx = 0;
3927 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
3928
3929 if (class_interface_decl)
3930 {
3931
Greg Clayton6beaaa62011-01-17 03:46:26 +00003932 const ASTRecordLayout &interface_layout = ast->getASTObjCInterfaceLayout(class_interface_decl);
Greg Clayton9e409562010-07-28 02:04:09 +00003933 ObjCInterfaceDecl *superclass_interface_decl = class_interface_decl->getSuperClass();
3934 if (superclass_interface_decl)
3935 {
3936 if (omit_empty_base_classes)
3937 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00003938 if (ClangASTContext::GetNumChildren(ast, ast->getObjCInterfaceType(superclass_interface_decl).getAsOpaquePtr(), omit_empty_base_classes) > 0)
Greg Clayton9e409562010-07-28 02:04:09 +00003939 {
3940 if (idx == 0)
3941 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00003942 QualType ivar_qual_type(ast->getObjCInterfaceType(superclass_interface_decl));
Greg Clayton9e409562010-07-28 02:04:09 +00003943
3944
3945 child_name.assign(superclass_interface_decl->getNameAsString().c_str());
3946
Greg Clayton6beaaa62011-01-17 03:46:26 +00003947 std::pair<uint64_t, unsigned> ivar_type_info = ast->getTypeInfo(ivar_qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00003948
3949 child_byte_size = ivar_type_info.first / 8;
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003950 child_byte_offset = 0;
Greg Clayton8f92f0a2010-10-14 22:52:14 +00003951 child_is_base_class = true;
Greg Clayton9e409562010-07-28 02:04:09 +00003952
3953 return ivar_qual_type.getAsOpaquePtr();
3954 }
3955
3956 ++child_idx;
3957 }
3958 }
3959 else
3960 ++child_idx;
3961 }
Greg Claytonb0b9fe62010-08-03 00:35:52 +00003962
3963 const uint32_t superclass_idx = child_idx;
Greg Clayton9e409562010-07-28 02:04:09 +00003964
3965 if (idx < (child_idx + class_interface_decl->ivar_size()))
3966 {
3967 ObjCInterfaceDecl::ivar_iterator ivar_pos, ivar_end = class_interface_decl->ivar_end();
3968
3969 for (ivar_pos = class_interface_decl->ivar_begin(); ivar_pos != ivar_end; ++ivar_pos)
3970 {
3971 if (child_idx == idx)
3972 {
Jim Inghamf80bc3f2011-12-08 02:53:10 +00003973 ObjCIvarDecl* ivar_decl = *ivar_pos;
Greg Clayton9e409562010-07-28 02:04:09 +00003974
3975 QualType ivar_qual_type(ivar_decl->getType());
3976
3977 child_name.assign(ivar_decl->getNameAsString().c_str());
3978
Greg Clayton6beaaa62011-01-17 03:46:26 +00003979 std::pair<uint64_t, unsigned> ivar_type_info = ast->getTypeInfo(ivar_qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00003980
3981 child_byte_size = ivar_type_info.first / 8;
3982
3983 // Figure out the field offset within the current struct/union/class type
Jim Inghamd555bac2011-06-24 22:03:24 +00003984 // For ObjC objects, we can't trust the bit offset we get from the Clang AST, since
3985 // that doesn't account for the space taken up by unbacked properties, or from
3986 // the changing size of base classes that are newer than this class.
3987 // So if we have a process around that we can ask about this object, do so.
3988 child_byte_offset = LLDB_INVALID_IVAR_OFFSET;
Greg Claytonc14ee322011-09-22 04:58:26 +00003989 Process *process = NULL;
3990 if (exe_ctx)
3991 process = exe_ctx->GetProcessPtr();
3992 if (process)
Jim Inghamd555bac2011-06-24 22:03:24 +00003993 {
Greg Claytonc14ee322011-09-22 04:58:26 +00003994 ObjCLanguageRuntime *objc_runtime = process->GetObjCLanguageRuntime();
Jim Inghamd555bac2011-06-24 22:03:24 +00003995 if (objc_runtime != NULL)
3996 {
Enrico Granata6f3533f2011-07-29 19:53:35 +00003997 ClangASTType parent_ast_type (ast, parent_qual_type.getAsOpaquePtr());
Jim Inghamd555bac2011-06-24 22:03:24 +00003998 child_byte_offset = objc_runtime->GetByteOffsetForIvar (parent_ast_type, ivar_decl->getNameAsString().c_str());
3999 }
4000 }
4001
Jim Inghamf80bc3f2011-12-08 02:53:10 +00004002 // Setting this to UINT32_MAX to make sure we don't compute it twice...
4003 bit_offset = UINT32_MAX;
4004
Jim Inghamd555bac2011-06-24 22:03:24 +00004005 if (child_byte_offset == LLDB_INVALID_IVAR_OFFSET)
4006 {
4007 bit_offset = interface_layout.getFieldOffset (child_idx - superclass_idx);
4008 child_byte_offset = bit_offset / 8;
4009 }
Jim Inghamf80bc3f2011-12-08 02:53:10 +00004010
4011 // Note, the ObjC Ivar Byte offset is just that, it doesn't account for the bit offset
4012 // of a bitfield within its containing object. So regardless of where we get the byte
4013 // offset from, we still need to get the bit offset for bitfields from the layout.
4014
4015 if (ClangASTContext::FieldIsBitfield (ast, ivar_decl, child_bitfield_bit_size))
4016 {
4017 if (bit_offset == UINT32_MAX)
4018 bit_offset = interface_layout.getFieldOffset (child_idx - superclass_idx);
4019
4020 child_bitfield_bit_offset = bit_offset % 8;
4021 }
Greg Clayton9e409562010-07-28 02:04:09 +00004022 return ivar_qual_type.getAsOpaquePtr();
4023 }
4024 ++child_idx;
4025 }
4026 }
4027 }
4028 }
4029 }
4030 break;
4031
4032 case clang::Type::ObjCObjectPointer:
4033 {
Sean Callanan78e37602011-01-27 04:42:51 +00004034 const ObjCObjectPointerType *pointer_type = cast<ObjCObjectPointerType>(parent_qual_type.getTypePtr());
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004035 QualType pointee_type = pointer_type->getPointeeType();
4036
4037 if (transparent_pointers && ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4038 {
Greg Claytone221f822011-01-21 01:59:00 +00004039 child_is_deref_of_parent = false;
4040 bool tmp_child_is_deref_of_parent = false;
Jim Inghamd555bac2011-06-24 22:03:24 +00004041 return GetChildClangTypeAtIndex (exe_ctx,
4042 ast,
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004043 parent_name,
4044 pointer_type->getPointeeType().getAsOpaquePtr(),
4045 idx,
4046 transparent_pointers,
4047 omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00004048 ignore_array_bounds,
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004049 child_name,
4050 child_byte_size,
4051 child_byte_offset,
4052 child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00004053 child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00004054 child_is_base_class,
4055 tmp_child_is_deref_of_parent);
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004056 }
4057 else
4058 {
Greg Claytone221f822011-01-21 01:59:00 +00004059 child_is_deref_of_parent = true;
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004060 if (parent_name)
4061 {
4062 child_name.assign(1, '*');
4063 child_name += parent_name;
4064 }
4065
4066 // We have a pointer to an simple type
Sean Callanan5b26f272012-02-04 08:49:35 +00004067 if (idx == 0 && GetCompleteQualType(ast, pointee_type))
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004068 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004069 std::pair<uint64_t, unsigned> clang_type_info = ast->getTypeInfo(pointee_type);
Greg Claytonb0b9fe62010-08-03 00:35:52 +00004070 assert(clang_type_info.first % 8 == 0);
4071 child_byte_size = clang_type_info.first / 8;
4072 child_byte_offset = 0;
4073 return pointee_type.getAsOpaquePtr();
4074 }
4075 }
Greg Clayton9e409562010-07-28 02:04:09 +00004076 }
4077 break;
4078
Greg Claytone1a916a2010-07-21 22:12:05 +00004079 case clang::Type::ConstantArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004080 {
4081 const ConstantArrayType *array = cast<ConstantArrayType>(parent_qual_type.getTypePtr());
4082 const uint64_t element_count = array->getSize().getLimitedValue();
4083
Greg Claytondaf515f2011-07-09 20:12:33 +00004084 if (ignore_array_bounds || idx < element_count)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004085 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004086 if (GetCompleteQualType (ast, array->getElementType()))
4087 {
4088 std::pair<uint64_t, unsigned> field_type_info = ast->getTypeInfo(array->getElementType());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004089
Greg Clayton6beaaa62011-01-17 03:46:26 +00004090 char element_name[64];
4091 ::snprintf (element_name, sizeof (element_name), "[%u]", idx);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004092
Greg Clayton6beaaa62011-01-17 03:46:26 +00004093 child_name.assign(element_name);
4094 assert(field_type_info.first % 8 == 0);
4095 child_byte_size = field_type_info.first / 8;
Greg Claytondaf515f2011-07-09 20:12:33 +00004096 child_byte_offset = (int32_t)idx * (int32_t)child_byte_size;
Greg Clayton6beaaa62011-01-17 03:46:26 +00004097 return array->getElementType().getAsOpaquePtr();
4098 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004099 }
4100 }
4101 break;
4102
Greg Claytone1a916a2010-07-21 22:12:05 +00004103 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004104 {
Sean Callanan78e37602011-01-27 04:42:51 +00004105 const PointerType *pointer_type = cast<PointerType>(parent_qual_type.getTypePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004106 QualType pointee_type = pointer_type->getPointeeType();
Greg Clayton97a43712011-01-08 22:26:47 +00004107
4108 // Don't dereference "void *" pointers
4109 if (pointee_type->isVoidType())
4110 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004111
4112 if (transparent_pointers && ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4113 {
Greg Claytone221f822011-01-21 01:59:00 +00004114 child_is_deref_of_parent = false;
4115 bool tmp_child_is_deref_of_parent = false;
Jim Inghamd555bac2011-06-24 22:03:24 +00004116 return GetChildClangTypeAtIndex (exe_ctx,
4117 ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004118 parent_name,
4119 pointer_type->getPointeeType().getAsOpaquePtr(),
4120 idx,
4121 transparent_pointers,
4122 omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00004123 ignore_array_bounds,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004124 child_name,
4125 child_byte_size,
4126 child_byte_offset,
4127 child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00004128 child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00004129 child_is_base_class,
4130 tmp_child_is_deref_of_parent);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004131 }
4132 else
4133 {
Greg Claytone221f822011-01-21 01:59:00 +00004134 child_is_deref_of_parent = true;
4135
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004136 if (parent_name)
4137 {
4138 child_name.assign(1, '*');
4139 child_name += parent_name;
4140 }
4141
4142 // We have a pointer to an simple type
4143 if (idx == 0)
4144 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004145 std::pair<uint64_t, unsigned> clang_type_info = ast->getTypeInfo(pointee_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004146 assert(clang_type_info.first % 8 == 0);
4147 child_byte_size = clang_type_info.first / 8;
4148 child_byte_offset = 0;
4149 return pointee_type.getAsOpaquePtr();
4150 }
4151 }
4152 }
4153 break;
4154
Greg Clayton73b472d2010-10-27 03:32:59 +00004155 case clang::Type::LValueReference:
4156 case clang::Type::RValueReference:
4157 {
Sean Callanan78e37602011-01-27 04:42:51 +00004158 const ReferenceType *reference_type = cast<ReferenceType>(parent_qual_type.getTypePtr());
Greg Clayton73b472d2010-10-27 03:32:59 +00004159 QualType pointee_type(reference_type->getPointeeType());
4160 clang_type_t pointee_clang_type = pointee_type.getAsOpaquePtr();
4161 if (transparent_pointers && ClangASTContext::IsAggregateType (pointee_clang_type))
4162 {
Greg Claytone221f822011-01-21 01:59:00 +00004163 child_is_deref_of_parent = false;
4164 bool tmp_child_is_deref_of_parent = false;
Jim Inghamd555bac2011-06-24 22:03:24 +00004165 return GetChildClangTypeAtIndex (exe_ctx,
4166 ast,
Greg Clayton73b472d2010-10-27 03:32:59 +00004167 parent_name,
4168 pointee_clang_type,
4169 idx,
4170 transparent_pointers,
4171 omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00004172 ignore_array_bounds,
Greg Clayton73b472d2010-10-27 03:32:59 +00004173 child_name,
4174 child_byte_size,
4175 child_byte_offset,
4176 child_bitfield_bit_size,
4177 child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00004178 child_is_base_class,
4179 tmp_child_is_deref_of_parent);
Greg Clayton73b472d2010-10-27 03:32:59 +00004180 }
4181 else
4182 {
4183 if (parent_name)
4184 {
4185 child_name.assign(1, '&');
4186 child_name += parent_name;
4187 }
4188
4189 // We have a pointer to an simple type
4190 if (idx == 0)
4191 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004192 std::pair<uint64_t, unsigned> clang_type_info = ast->getTypeInfo(pointee_type);
Greg Clayton73b472d2010-10-27 03:32:59 +00004193 assert(clang_type_info.first % 8 == 0);
4194 child_byte_size = clang_type_info.first / 8;
4195 child_byte_offset = 0;
4196 return pointee_type.getAsOpaquePtr();
4197 }
4198 }
4199 }
4200 break;
4201
Greg Claytone1a916a2010-07-21 22:12:05 +00004202 case clang::Type::Typedef:
Jim Inghamd555bac2011-06-24 22:03:24 +00004203 return GetChildClangTypeAtIndex (exe_ctx,
4204 ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004205 parent_name,
Sean Callanan48114472010-12-13 01:26:27 +00004206 cast<TypedefType>(parent_qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004207 idx,
4208 transparent_pointers,
4209 omit_empty_base_classes,
Greg Claytondaf515f2011-07-09 20:12:33 +00004210 ignore_array_bounds,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004211 child_name,
4212 child_byte_size,
4213 child_byte_offset,
4214 child_bitfield_bit_size,
Greg Clayton8f92f0a2010-10-14 22:52:14 +00004215 child_bitfield_bit_offset,
Greg Claytone221f822011-01-21 01:59:00 +00004216 child_is_base_class,
4217 child_is_deref_of_parent);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004218 break;
Sean Callanan912855f2011-08-11 23:56:13 +00004219
4220 case clang::Type::Elaborated:
4221 return GetChildClangTypeAtIndex (exe_ctx,
4222 ast,
4223 parent_name,
4224 cast<ElaboratedType>(parent_qual_type)->getNamedType().getAsOpaquePtr(),
4225 idx,
4226 transparent_pointers,
4227 omit_empty_base_classes,
4228 ignore_array_bounds,
4229 child_name,
4230 child_byte_size,
4231 child_byte_offset,
4232 child_bitfield_bit_size,
4233 child_bitfield_bit_offset,
4234 child_is_base_class,
4235 child_is_deref_of_parent);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004236
4237 default:
4238 break;
4239 }
4240 }
Greg Clayton19503a22010-07-23 15:37:46 +00004241 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004242}
4243
4244static inline bool
4245BaseSpecifierIsEmpty (const CXXBaseSpecifier *b)
4246{
Greg Clayton6beaaa62011-01-17 03:46:26 +00004247 return ClangASTContext::RecordHasFields(b->getType()->getAsCXXRecordDecl()) == false;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004248}
4249
4250static uint32_t
4251GetNumBaseClasses (const CXXRecordDecl *cxx_record_decl, bool omit_empty_base_classes)
4252{
4253 uint32_t num_bases = 0;
4254 if (cxx_record_decl)
4255 {
4256 if (omit_empty_base_classes)
4257 {
4258 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
4259 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
4260 base_class != base_class_end;
4261 ++base_class)
4262 {
4263 // Skip empty base classes
4264 if (omit_empty_base_classes)
4265 {
4266 if (BaseSpecifierIsEmpty (base_class))
4267 continue;
4268 }
4269 ++num_bases;
4270 }
4271 }
4272 else
4273 num_bases = cxx_record_decl->getNumBases();
4274 }
4275 return num_bases;
4276}
4277
4278
4279static uint32_t
4280GetIndexForRecordBase
4281(
4282 const RecordDecl *record_decl,
4283 const CXXBaseSpecifier *base_spec,
4284 bool omit_empty_base_classes
4285)
4286{
4287 uint32_t child_idx = 0;
4288
4289 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
4290
4291// const char *super_name = record_decl->getNameAsCString();
4292// const char *base_name = base_spec->getType()->getAs<RecordType>()->getDecl()->getNameAsCString();
4293// printf ("GetIndexForRecordChild (%s, %s)\n", super_name, base_name);
4294//
4295 if (cxx_record_decl)
4296 {
4297 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
4298 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
4299 base_class != base_class_end;
4300 ++base_class)
4301 {
4302 if (omit_empty_base_classes)
4303 {
4304 if (BaseSpecifierIsEmpty (base_class))
4305 continue;
4306 }
4307
4308// printf ("GetIndexForRecordChild (%s, %s) base[%u] = %s\n", super_name, base_name,
4309// child_idx,
4310// base_class->getType()->getAs<RecordType>()->getDecl()->getNameAsCString());
4311//
4312//
4313 if (base_class == base_spec)
4314 return child_idx;
4315 ++child_idx;
4316 }
4317 }
4318
4319 return UINT32_MAX;
4320}
4321
4322
4323static uint32_t
4324GetIndexForRecordChild
4325(
4326 const RecordDecl *record_decl,
4327 NamedDecl *canonical_decl,
4328 bool omit_empty_base_classes
4329)
4330{
4331 uint32_t child_idx = GetNumBaseClasses (dyn_cast<CXXRecordDecl>(record_decl), omit_empty_base_classes);
4332
4333// const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
4334//
4335//// printf ("GetIndexForRecordChild (%s, %s)\n", record_decl->getNameAsCString(), canonical_decl->getNameAsCString());
4336// if (cxx_record_decl)
4337// {
4338// CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
4339// for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
4340// base_class != base_class_end;
4341// ++base_class)
4342// {
4343// if (omit_empty_base_classes)
4344// {
4345// if (BaseSpecifierIsEmpty (base_class))
4346// continue;
4347// }
4348//
4349//// printf ("GetIndexForRecordChild (%s, %s) base[%u] = %s\n",
4350//// record_decl->getNameAsCString(),
4351//// canonical_decl->getNameAsCString(),
4352//// child_idx,
4353//// base_class->getType()->getAs<RecordType>()->getDecl()->getNameAsCString());
4354//
4355//
4356// CXXRecordDecl *curr_base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
4357// if (curr_base_class_decl == canonical_decl)
4358// {
4359// return child_idx;
4360// }
4361// ++child_idx;
4362// }
4363// }
4364//
4365// const uint32_t num_bases = child_idx;
4366 RecordDecl::field_iterator field, field_end;
4367 for (field = record_decl->field_begin(), field_end = record_decl->field_end();
4368 field != field_end;
4369 ++field, ++child_idx)
4370 {
4371// printf ("GetIndexForRecordChild (%s, %s) field[%u] = %s\n",
4372// record_decl->getNameAsCString(),
4373// canonical_decl->getNameAsCString(),
4374// child_idx - num_bases,
4375// field->getNameAsCString());
4376
4377 if (field->getCanonicalDecl() == canonical_decl)
4378 return child_idx;
4379 }
4380
4381 return UINT32_MAX;
4382}
4383
4384// Look for a child member (doesn't include base classes, but it does include
4385// their members) in the type hierarchy. Returns an index path into "clang_type"
4386// on how to reach the appropriate member.
4387//
4388// class A
4389// {
4390// public:
4391// int m_a;
4392// int m_b;
4393// };
4394//
4395// class B
4396// {
4397// };
4398//
4399// class C :
4400// public B,
4401// public A
4402// {
4403// };
4404//
4405// If we have a clang type that describes "class C", and we wanted to looked
4406// "m_b" in it:
4407//
4408// With omit_empty_base_classes == false we would get an integer array back with:
4409// { 1, 1 }
4410// The first index 1 is the child index for "class A" within class C
4411// The second index 1 is the child index for "m_b" within class A
4412//
4413// With omit_empty_base_classes == true we would get an integer array back with:
4414// { 0, 1 }
4415// The first index 0 is the child index for "class A" within class C (since class B doesn't have any members it doesn't count)
4416// The second index 1 is the child index for "m_b" within class A
4417
4418size_t
4419ClangASTContext::GetIndexOfChildMemberWithName
4420(
Greg Clayton6beaaa62011-01-17 03:46:26 +00004421 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00004422 clang_type_t clang_type,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004423 const char *name,
4424 bool omit_empty_base_classes,
4425 std::vector<uint32_t>& child_indexes
4426)
4427{
4428 if (clang_type && name && name[0])
4429 {
4430 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
Greg Clayton737b9322010-09-13 03:32:57 +00004431 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
4432 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004433 {
Greg Claytone1a916a2010-07-21 22:12:05 +00004434 case clang::Type::Record:
Greg Claytonc432c192011-01-20 04:18:48 +00004435 if (GetCompleteQualType (ast, qual_type))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004436 {
4437 const RecordType *record_type = cast<RecordType>(qual_type.getTypePtr());
4438 const RecordDecl *record_decl = record_type->getDecl();
4439
4440 assert(record_decl);
4441 uint32_t child_idx = 0;
4442
4443 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
4444
4445 // Try and find a field that matches NAME
4446 RecordDecl::field_iterator field, field_end;
4447 StringRef name_sref(name);
4448 for (field = record_decl->field_begin(), field_end = record_decl->field_end();
4449 field != field_end;
4450 ++field, ++child_idx)
4451 {
4452 if (field->getName().equals (name_sref))
4453 {
4454 // We have to add on the number of base classes to this index!
4455 child_indexes.push_back (child_idx + GetNumBaseClasses (cxx_record_decl, omit_empty_base_classes));
4456 return child_indexes.size();
4457 }
4458 }
4459
4460 if (cxx_record_decl)
4461 {
4462 const RecordDecl *parent_record_decl = cxx_record_decl;
4463
4464 //printf ("parent = %s\n", parent_record_decl->getNameAsCString());
4465
4466 //const Decl *root_cdecl = cxx_record_decl->getCanonicalDecl();
4467 // Didn't find things easily, lets let clang do its thang...
Sean Callanancc427fa2011-07-30 02:42:06 +00004468 IdentifierInfo & ident_ref = ast->Idents.get(name_sref);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004469 DeclarationName decl_name(&ident_ref);
4470
4471 CXXBasePaths paths;
4472 if (cxx_record_decl->lookupInBases(CXXRecordDecl::FindOrdinaryMember,
4473 decl_name.getAsOpaquePtr(),
4474 paths))
4475 {
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004476 CXXBasePaths::const_paths_iterator path, path_end = paths.end();
4477 for (path = paths.begin(); path != path_end; ++path)
4478 {
4479 const size_t num_path_elements = path->size();
4480 for (size_t e=0; e<num_path_elements; ++e)
4481 {
4482 CXXBasePathElement elem = (*path)[e];
4483
4484 child_idx = GetIndexForRecordBase (parent_record_decl, elem.Base, omit_empty_base_classes);
4485 if (child_idx == UINT32_MAX)
4486 {
4487 child_indexes.clear();
4488 return 0;
4489 }
4490 else
4491 {
4492 child_indexes.push_back (child_idx);
4493 parent_record_decl = cast<RecordDecl>(elem.Base->getType()->getAs<RecordType>()->getDecl());
4494 }
4495 }
4496 DeclContext::lookup_iterator named_decl_pos;
4497 for (named_decl_pos = path->Decls.first;
4498 named_decl_pos != path->Decls.second && parent_record_decl;
4499 ++named_decl_pos)
4500 {
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004501 child_idx = GetIndexForRecordChild (parent_record_decl, *named_decl_pos, omit_empty_base_classes);
4502 if (child_idx == UINT32_MAX)
4503 {
4504 child_indexes.clear();
4505 return 0;
4506 }
4507 else
4508 {
4509 child_indexes.push_back (child_idx);
4510 }
4511 }
4512 }
4513 return child_indexes.size();
4514 }
4515 }
4516
4517 }
4518 break;
4519
Greg Clayton9e409562010-07-28 02:04:09 +00004520 case clang::Type::ObjCObject:
4521 case clang::Type::ObjCInterface:
Greg Claytonc432c192011-01-20 04:18:48 +00004522 if (GetCompleteQualType (ast, qual_type))
Greg Clayton9e409562010-07-28 02:04:09 +00004523 {
4524 StringRef name_sref(name);
Sean Callanan78e37602011-01-27 04:42:51 +00004525 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00004526 assert (objc_class_type);
4527 if (objc_class_type)
4528 {
4529 uint32_t child_idx = 0;
4530 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
4531
4532 if (class_interface_decl)
4533 {
4534 ObjCInterfaceDecl::ivar_iterator ivar_pos, ivar_end = class_interface_decl->ivar_end();
4535 ObjCInterfaceDecl *superclass_interface_decl = class_interface_decl->getSuperClass();
4536
Greg Clayton6ba78152010-09-18 02:11:07 +00004537 for (ivar_pos = class_interface_decl->ivar_begin(); ivar_pos != ivar_end; ++ivar_pos, ++child_idx)
Greg Clayton9e409562010-07-28 02:04:09 +00004538 {
4539 const ObjCIvarDecl* ivar_decl = *ivar_pos;
4540
4541 if (ivar_decl->getName().equals (name_sref))
4542 {
4543 if ((!omit_empty_base_classes && superclass_interface_decl) ||
4544 ( omit_empty_base_classes && ObjCDeclHasIVars (superclass_interface_decl, true)))
4545 ++child_idx;
4546
4547 child_indexes.push_back (child_idx);
4548 return child_indexes.size();
4549 }
4550 }
4551
4552 if (superclass_interface_decl)
4553 {
4554 // The super class index is always zero for ObjC classes,
4555 // so we push it onto the child indexes in case we find
4556 // an ivar in our superclass...
4557 child_indexes.push_back (0);
4558
Greg Clayton6beaaa62011-01-17 03:46:26 +00004559 if (GetIndexOfChildMemberWithName (ast,
4560 ast->getObjCInterfaceType(superclass_interface_decl).getAsOpaquePtr(),
Greg Clayton9e409562010-07-28 02:04:09 +00004561 name,
4562 omit_empty_base_classes,
4563 child_indexes))
4564 {
4565 // We did find an ivar in a superclass so just
4566 // return the results!
4567 return child_indexes.size();
4568 }
4569
4570 // We didn't find an ivar matching "name" in our
4571 // superclass, pop the superclass zero index that
4572 // we pushed on above.
4573 child_indexes.pop_back();
4574 }
4575 }
4576 }
4577 }
4578 break;
4579
4580 case clang::Type::ObjCObjectPointer:
4581 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004582 return GetIndexOfChildMemberWithName (ast,
Greg Clayton9e409562010-07-28 02:04:09 +00004583 cast<ObjCObjectPointerType>(qual_type.getTypePtr())->getPointeeType().getAsOpaquePtr(),
4584 name,
4585 omit_empty_base_classes,
4586 child_indexes);
4587 }
4588 break;
4589
4590
Greg Claytone1a916a2010-07-21 22:12:05 +00004591 case clang::Type::ConstantArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004592 {
4593// const ConstantArrayType *array = cast<ConstantArrayType>(parent_qual_type.getTypePtr());
4594// const uint64_t element_count = array->getSize().getLimitedValue();
4595//
4596// if (idx < element_count)
4597// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004598// std::pair<uint64_t, unsigned> field_type_info = ast->getTypeInfo(array->getElementType());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004599//
4600// char element_name[32];
4601// ::snprintf (element_name, sizeof (element_name), "%s[%u]", parent_name ? parent_name : "", idx);
4602//
4603// child_name.assign(element_name);
4604// assert(field_type_info.first % 8 == 0);
4605// child_byte_size = field_type_info.first / 8;
4606// child_byte_offset = idx * child_byte_size;
4607// return array->getElementType().getAsOpaquePtr();
4608// }
4609 }
4610 break;
4611
Greg Claytone1a916a2010-07-21 22:12:05 +00004612// case clang::Type::MemberPointerType:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004613// {
4614// MemberPointerType *mem_ptr_type = cast<MemberPointerType>(qual_type.getTypePtr());
4615// QualType pointee_type = mem_ptr_type->getPointeeType();
4616//
4617// if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4618// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004619// return GetIndexOfChildWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004620// mem_ptr_type->getPointeeType().getAsOpaquePtr(),
4621// name);
4622// }
4623// }
4624// break;
4625//
Greg Claytone1a916a2010-07-21 22:12:05 +00004626 case clang::Type::LValueReference:
4627 case clang::Type::RValueReference:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004628 {
Sean Callanan78e37602011-01-27 04:42:51 +00004629 const ReferenceType *reference_type = cast<ReferenceType>(qual_type.getTypePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004630 QualType pointee_type = reference_type->getPointeeType();
4631
4632 if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4633 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004634 return GetIndexOfChildMemberWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004635 reference_type->getPointeeType().getAsOpaquePtr(),
4636 name,
4637 omit_empty_base_classes,
4638 child_indexes);
4639 }
4640 }
4641 break;
4642
Greg Claytone1a916a2010-07-21 22:12:05 +00004643 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004644 {
Sean Callanan78e37602011-01-27 04:42:51 +00004645 const PointerType *pointer_type = cast<PointerType>(qual_type.getTypePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004646 QualType pointee_type = pointer_type->getPointeeType();
4647
4648 if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4649 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004650 return GetIndexOfChildMemberWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004651 pointer_type->getPointeeType().getAsOpaquePtr(),
4652 name,
4653 omit_empty_base_classes,
4654 child_indexes);
4655 }
4656 else
4657 {
4658// if (parent_name)
4659// {
4660// child_name.assign(1, '*');
4661// child_name += parent_name;
4662// }
4663//
4664// // We have a pointer to an simple type
4665// if (idx == 0)
4666// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004667// std::pair<uint64_t, unsigned> clang_type_info = ast->getTypeInfo(pointee_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004668// assert(clang_type_info.first % 8 == 0);
4669// child_byte_size = clang_type_info.first / 8;
4670// child_byte_offset = 0;
4671// return pointee_type.getAsOpaquePtr();
4672// }
4673 }
4674 }
4675 break;
4676
Greg Claytone1a916a2010-07-21 22:12:05 +00004677 case clang::Type::Typedef:
Greg Clayton6beaaa62011-01-17 03:46:26 +00004678 return GetIndexOfChildMemberWithName (ast,
Sean Callanan48114472010-12-13 01:26:27 +00004679 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004680 name,
4681 omit_empty_base_classes,
4682 child_indexes);
4683
4684 default:
4685 break;
4686 }
4687 }
4688 return 0;
4689}
4690
4691
4692// Get the index of the child of "clang_type" whose name matches. This function
4693// doesn't descend into the children, but only looks one level deep and name
4694// matches can include base class names.
4695
4696uint32_t
4697ClangASTContext::GetIndexOfChildWithName
4698(
Greg Clayton6beaaa62011-01-17 03:46:26 +00004699 ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00004700 clang_type_t clang_type,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004701 const char *name,
4702 bool omit_empty_base_classes
4703)
4704{
4705 if (clang_type && name && name[0])
4706 {
4707 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
Greg Clayton9e409562010-07-28 02:04:09 +00004708
Greg Clayton737b9322010-09-13 03:32:57 +00004709 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
Greg Clayton9e409562010-07-28 02:04:09 +00004710
Greg Clayton737b9322010-09-13 03:32:57 +00004711 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004712 {
Greg Claytone1a916a2010-07-21 22:12:05 +00004713 case clang::Type::Record:
Greg Claytonc432c192011-01-20 04:18:48 +00004714 if (GetCompleteQualType (ast, qual_type))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004715 {
4716 const RecordType *record_type = cast<RecordType>(qual_type.getTypePtr());
4717 const RecordDecl *record_decl = record_type->getDecl();
4718
4719 assert(record_decl);
4720 uint32_t child_idx = 0;
4721
4722 const CXXRecordDecl *cxx_record_decl = dyn_cast<CXXRecordDecl>(record_decl);
4723
4724 if (cxx_record_decl)
4725 {
4726 CXXRecordDecl::base_class_const_iterator base_class, base_class_end;
4727 for (base_class = cxx_record_decl->bases_begin(), base_class_end = cxx_record_decl->bases_end();
4728 base_class != base_class_end;
4729 ++base_class)
4730 {
4731 // Skip empty base classes
4732 CXXRecordDecl *base_class_decl = cast<CXXRecordDecl>(base_class->getType()->getAs<RecordType>()->getDecl());
4733 if (omit_empty_base_classes && RecordHasFields(base_class_decl) == false)
4734 continue;
4735
Greg Clayton84db9102012-03-26 23:03:23 +00004736 std::string base_class_type_name (ClangASTType::GetTypeNameForQualType(ast, base_class->getType()));
Greg Claytone3055942011-06-30 02:28:26 +00004737 if (base_class_type_name.compare (name) == 0)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004738 return child_idx;
4739 ++child_idx;
4740 }
4741 }
4742
4743 // Try and find a field that matches NAME
4744 RecordDecl::field_iterator field, field_end;
4745 StringRef name_sref(name);
4746 for (field = record_decl->field_begin(), field_end = record_decl->field_end();
4747 field != field_end;
4748 ++field, ++child_idx)
4749 {
4750 if (field->getName().equals (name_sref))
4751 return child_idx;
4752 }
4753
4754 }
4755 break;
4756
Greg Clayton9e409562010-07-28 02:04:09 +00004757 case clang::Type::ObjCObject:
4758 case clang::Type::ObjCInterface:
Greg Claytonc432c192011-01-20 04:18:48 +00004759 if (GetCompleteQualType (ast, qual_type))
Greg Clayton9e409562010-07-28 02:04:09 +00004760 {
4761 StringRef name_sref(name);
Sean Callanan78e37602011-01-27 04:42:51 +00004762 const ObjCObjectType *objc_class_type = dyn_cast<ObjCObjectType>(qual_type.getTypePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00004763 assert (objc_class_type);
4764 if (objc_class_type)
4765 {
4766 uint32_t child_idx = 0;
4767 ObjCInterfaceDecl *class_interface_decl = objc_class_type->getInterface();
4768
4769 if (class_interface_decl)
4770 {
4771 ObjCInterfaceDecl::ivar_iterator ivar_pos, ivar_end = class_interface_decl->ivar_end();
4772 ObjCInterfaceDecl *superclass_interface_decl = class_interface_decl->getSuperClass();
4773
4774 for (ivar_pos = class_interface_decl->ivar_begin(); ivar_pos != ivar_end; ++ivar_pos)
4775 {
4776 const ObjCIvarDecl* ivar_decl = *ivar_pos;
4777
4778 if (ivar_decl->getName().equals (name_sref))
4779 {
4780 if ((!omit_empty_base_classes && superclass_interface_decl) ||
4781 ( omit_empty_base_classes && ObjCDeclHasIVars (superclass_interface_decl, true)))
4782 ++child_idx;
4783
4784 return child_idx;
4785 }
4786 }
4787
4788 if (superclass_interface_decl)
4789 {
4790 if (superclass_interface_decl->getName().equals (name_sref))
4791 return 0;
4792 }
4793 }
4794 }
4795 }
4796 break;
4797
4798 case clang::Type::ObjCObjectPointer:
4799 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004800 return GetIndexOfChildWithName (ast,
Greg Clayton9e409562010-07-28 02:04:09 +00004801 cast<ObjCObjectPointerType>(qual_type.getTypePtr())->getPointeeType().getAsOpaquePtr(),
4802 name,
4803 omit_empty_base_classes);
4804 }
4805 break;
4806
Greg Claytone1a916a2010-07-21 22:12:05 +00004807 case clang::Type::ConstantArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004808 {
4809// const ConstantArrayType *array = cast<ConstantArrayType>(parent_qual_type.getTypePtr());
4810// const uint64_t element_count = array->getSize().getLimitedValue();
4811//
4812// if (idx < element_count)
4813// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004814// std::pair<uint64_t, unsigned> field_type_info = ast->getTypeInfo(array->getElementType());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004815//
4816// char element_name[32];
4817// ::snprintf (element_name, sizeof (element_name), "%s[%u]", parent_name ? parent_name : "", idx);
4818//
4819// child_name.assign(element_name);
4820// assert(field_type_info.first % 8 == 0);
4821// child_byte_size = field_type_info.first / 8;
4822// child_byte_offset = idx * child_byte_size;
4823// return array->getElementType().getAsOpaquePtr();
4824// }
4825 }
4826 break;
4827
Greg Claytone1a916a2010-07-21 22:12:05 +00004828// case clang::Type::MemberPointerType:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004829// {
4830// MemberPointerType *mem_ptr_type = cast<MemberPointerType>(qual_type.getTypePtr());
4831// QualType pointee_type = mem_ptr_type->getPointeeType();
4832//
4833// if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4834// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004835// return GetIndexOfChildWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004836// mem_ptr_type->getPointeeType().getAsOpaquePtr(),
4837// name);
4838// }
4839// }
4840// break;
4841//
Greg Claytone1a916a2010-07-21 22:12:05 +00004842 case clang::Type::LValueReference:
4843 case clang::Type::RValueReference:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004844 {
Sean Callanan78e37602011-01-27 04:42:51 +00004845 const ReferenceType *reference_type = cast<ReferenceType>(qual_type.getTypePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004846 QualType pointee_type = reference_type->getPointeeType();
4847
4848 if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4849 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004850 return GetIndexOfChildWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004851 reference_type->getPointeeType().getAsOpaquePtr(),
4852 name,
4853 omit_empty_base_classes);
4854 }
4855 }
4856 break;
4857
Greg Claytone1a916a2010-07-21 22:12:05 +00004858 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004859 {
Sean Callanan78e37602011-01-27 04:42:51 +00004860 const PointerType *pointer_type = cast<PointerType>(qual_type.getTypePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004861 QualType pointee_type = pointer_type->getPointeeType();
4862
4863 if (ClangASTContext::IsAggregateType (pointee_type.getAsOpaquePtr()))
4864 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004865 return GetIndexOfChildWithName (ast,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004866 pointer_type->getPointeeType().getAsOpaquePtr(),
4867 name,
4868 omit_empty_base_classes);
4869 }
4870 else
4871 {
4872// if (parent_name)
4873// {
4874// child_name.assign(1, '*');
4875// child_name += parent_name;
4876// }
4877//
4878// // We have a pointer to an simple type
4879// if (idx == 0)
4880// {
Greg Clayton6beaaa62011-01-17 03:46:26 +00004881// std::pair<uint64_t, unsigned> clang_type_info = ast->getTypeInfo(pointee_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004882// assert(clang_type_info.first % 8 == 0);
4883// child_byte_size = clang_type_info.first / 8;
4884// child_byte_offset = 0;
4885// return pointee_type.getAsOpaquePtr();
4886// }
4887 }
4888 }
4889 break;
4890
Greg Claytone1a916a2010-07-21 22:12:05 +00004891 case clang::Type::Typedef:
Greg Clayton6beaaa62011-01-17 03:46:26 +00004892 return GetIndexOfChildWithName (ast,
Sean Callanan48114472010-12-13 01:26:27 +00004893 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004894 name,
4895 omit_empty_base_classes);
4896
4897 default:
4898 break;
4899 }
4900 }
4901 return UINT32_MAX;
4902}
4903
4904#pragma mark TagType
4905
4906bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00004907ClangASTContext::SetTagTypeKind (clang_type_t tag_clang_type, int kind)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004908{
4909 if (tag_clang_type)
4910 {
4911 QualType tag_qual_type(QualType::getFromOpaquePtr(tag_clang_type));
Sean Callanan78e37602011-01-27 04:42:51 +00004912 const clang::Type *clang_type = tag_qual_type.getTypePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004913 if (clang_type)
4914 {
Sean Callanan78e37602011-01-27 04:42:51 +00004915 const TagType *tag_type = dyn_cast<TagType>(clang_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004916 if (tag_type)
4917 {
4918 TagDecl *tag_decl = dyn_cast<TagDecl>(tag_type->getDecl());
4919 if (tag_decl)
4920 {
4921 tag_decl->setTagKind ((TagDecl::TagKind)kind);
4922 return true;
4923 }
4924 }
4925 }
4926 }
4927 return false;
4928}
4929
4930
4931#pragma mark DeclContext Functions
4932
4933DeclContext *
Greg Clayton1be10fc2010-09-29 01:12:09 +00004934ClangASTContext::GetDeclContextForType (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004935{
4936 if (clang_type == NULL)
4937 return NULL;
4938
4939 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
Greg Clayton737b9322010-09-13 03:32:57 +00004940 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
4941 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004942 {
Sean Callanancc427fa2011-07-30 02:42:06 +00004943 case clang::Type::UnaryTransform: break;
Greg Clayton9e409562010-07-28 02:04:09 +00004944 case clang::Type::FunctionNoProto: break;
4945 case clang::Type::FunctionProto: break;
4946 case clang::Type::IncompleteArray: break;
4947 case clang::Type::VariableArray: break;
4948 case clang::Type::ConstantArray: break;
Sean Callananfb0b7582011-03-15 00:17:19 +00004949 case clang::Type::DependentSizedArray: break;
Greg Clayton9e409562010-07-28 02:04:09 +00004950 case clang::Type::ExtVector: break;
Sean Callananfb0b7582011-03-15 00:17:19 +00004951 case clang::Type::DependentSizedExtVector: break;
Greg Clayton9e409562010-07-28 02:04:09 +00004952 case clang::Type::Vector: break;
4953 case clang::Type::Builtin: break;
4954 case clang::Type::BlockPointer: break;
4955 case clang::Type::Pointer: break;
4956 case clang::Type::LValueReference: break;
4957 case clang::Type::RValueReference: break;
4958 case clang::Type::MemberPointer: break;
4959 case clang::Type::Complex: break;
4960 case clang::Type::ObjCObject: break;
4961 case clang::Type::ObjCInterface: return cast<ObjCObjectType>(qual_type.getTypePtr())->getInterface();
4962 case clang::Type::ObjCObjectPointer: return ClangASTContext::GetDeclContextForType (cast<ObjCObjectPointerType>(qual_type.getTypePtr())->getPointeeType().getAsOpaquePtr());
4963 case clang::Type::Record: return cast<RecordType>(qual_type)->getDecl();
4964 case clang::Type::Enum: return cast<EnumType>(qual_type)->getDecl();
Sean Callanan48114472010-12-13 01:26:27 +00004965 case clang::Type::Typedef: return ClangASTContext::GetDeclContextForType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Sean Callanan912855f2011-08-11 23:56:13 +00004966 case clang::Type::Elaborated: return ClangASTContext::GetDeclContextForType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Greg Clayton9e409562010-07-28 02:04:09 +00004967 case clang::Type::TypeOfExpr: break;
4968 case clang::Type::TypeOf: break;
4969 case clang::Type::Decltype: break;
4970 //case clang::Type::QualifiedName: break;
4971 case clang::Type::TemplateSpecialization: break;
Sean Callananfb0b7582011-03-15 00:17:19 +00004972 case clang::Type::DependentTemplateSpecialization: break;
4973 case clang::Type::TemplateTypeParm: break;
4974 case clang::Type::SubstTemplateTypeParm: break;
4975 case clang::Type::SubstTemplateTypeParmPack:break;
4976 case clang::Type::PackExpansion: break;
4977 case clang::Type::UnresolvedUsing: break;
4978 case clang::Type::Paren: break;
Sean Callananfb0b7582011-03-15 00:17:19 +00004979 case clang::Type::Attributed: break;
4980 case clang::Type::Auto: break;
4981 case clang::Type::InjectedClassName: break;
4982 case clang::Type::DependentName: break;
Greg Claytonea3e7d52011-10-08 00:49:15 +00004983 case clang::Type::Atomic: break;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004984 }
4985 // No DeclContext in this type...
4986 return NULL;
4987}
4988
4989#pragma mark Namespace Declarations
4990
4991NamespaceDecl *
Greg Clayton030a2042011-10-14 21:34:45 +00004992ClangASTContext::GetUniqueNamespaceDeclaration (const char *name, DeclContext *decl_ctx)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00004993{
Greg Clayton030a2042011-10-14 21:34:45 +00004994 NamespaceDecl *namespace_decl = NULL;
Greg Clayton9d3d6882011-10-31 23:51:19 +00004995 ASTContext *ast = getASTContext();
4996 TranslationUnitDecl *translation_unit_decl = ast->getTranslationUnitDecl ();
4997 if (decl_ctx == NULL)
4998 decl_ctx = translation_unit_decl;
4999
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005000 if (name)
5001 {
Greg Clayton030a2042011-10-14 21:34:45 +00005002 IdentifierInfo &identifier_info = ast->Idents.get(name);
5003 DeclarationName decl_name (&identifier_info);
5004 clang::DeclContext::lookup_result result = decl_ctx->lookup(decl_name);
5005 for (clang::DeclContext::lookup_iterator pos = result.first, end = result.second; pos != end; ++pos)
5006 {
5007 namespace_decl = dyn_cast<clang::NamespaceDecl>(*pos);
5008 if (namespace_decl)
5009 return namespace_decl;
5010 }
5011
Sean Callanan5b26f272012-02-04 08:49:35 +00005012 namespace_decl = NamespaceDecl::Create(*ast,
5013 decl_ctx,
5014 false,
5015 SourceLocation(),
5016 SourceLocation(),
5017 &identifier_info,
5018 NULL);
Greg Clayton030a2042011-10-14 21:34:45 +00005019
Greg Clayton9d3d6882011-10-31 23:51:19 +00005020 decl_ctx->addDecl (namespace_decl);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005021 }
Greg Clayton9d3d6882011-10-31 23:51:19 +00005022 else
5023 {
5024 if (decl_ctx == translation_unit_decl)
5025 {
5026 namespace_decl = translation_unit_decl->getAnonymousNamespace();
5027 if (namespace_decl)
5028 return namespace_decl;
5029
Sean Callanan5b26f272012-02-04 08:49:35 +00005030 namespace_decl = NamespaceDecl::Create(*ast,
5031 decl_ctx,
5032 false,
5033 SourceLocation(),
5034 SourceLocation(),
5035 NULL,
5036 NULL);
Greg Clayton9d3d6882011-10-31 23:51:19 +00005037 translation_unit_decl->setAnonymousNamespace (namespace_decl);
5038 translation_unit_decl->addDecl (namespace_decl);
5039 assert (namespace_decl == translation_unit_decl->getAnonymousNamespace());
5040 }
5041 else
5042 {
5043 NamespaceDecl *parent_namespace_decl = cast<NamespaceDecl>(decl_ctx);
5044 if (parent_namespace_decl)
5045 {
5046 namespace_decl = parent_namespace_decl->getAnonymousNamespace();
5047 if (namespace_decl)
5048 return namespace_decl;
Sean Callanan5b26f272012-02-04 08:49:35 +00005049 namespace_decl = NamespaceDecl::Create(*ast,
5050 decl_ctx,
5051 false,
5052 SourceLocation(),
5053 SourceLocation(),
5054 NULL,
5055 NULL);
Greg Clayton9d3d6882011-10-31 23:51:19 +00005056 parent_namespace_decl->setAnonymousNamespace (namespace_decl);
5057 parent_namespace_decl->addDecl (namespace_decl);
5058 assert (namespace_decl == parent_namespace_decl->getAnonymousNamespace());
5059 }
5060 else
5061 {
5062 // BAD!!!
5063 }
5064 }
5065
5066
5067 if (namespace_decl)
5068 {
5069 // If we make it here, we are creating the anonymous namespace decl
5070 // for the first time, so we need to do the using directive magic
5071 // like SEMA does
5072 UsingDirectiveDecl* using_directive_decl = UsingDirectiveDecl::Create (*ast,
5073 decl_ctx,
5074 SourceLocation(),
5075 SourceLocation(),
5076 NestedNameSpecifierLoc(),
5077 SourceLocation(),
5078 namespace_decl,
5079 decl_ctx);
5080 using_directive_decl->setImplicit();
5081 decl_ctx->addDecl(using_directive_decl);
5082 }
5083 }
5084#ifdef LLDB_CONFIGURATION_DEBUG
5085 VerifyDecl(namespace_decl);
5086#endif
Greg Clayton030a2042011-10-14 21:34:45 +00005087 return namespace_decl;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005088}
5089
5090
5091#pragma mark Function Types
5092
5093FunctionDecl *
Greg Clayton147e1fa2011-10-14 22:47:18 +00005094ClangASTContext::CreateFunctionDeclaration (DeclContext *decl_ctx, const char *name, clang_type_t function_clang_type, int storage, bool is_inline)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005095{
Greg Clayton147e1fa2011-10-14 22:47:18 +00005096 FunctionDecl *func_decl = NULL;
5097 ASTContext *ast = getASTContext();
5098 if (decl_ctx == NULL)
5099 decl_ctx = ast->getTranslationUnitDecl();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005100
Greg Clayton147e1fa2011-10-14 22:47:18 +00005101 if (name && name[0])
5102 {
5103 func_decl = FunctionDecl::Create (*ast,
5104 decl_ctx,
5105 SourceLocation(),
5106 SourceLocation(),
5107 DeclarationName (&ast->Idents.get(name)),
5108 QualType::getFromOpaquePtr(function_clang_type),
5109 NULL,
5110 (FunctionDecl::StorageClass)storage,
5111 (FunctionDecl::StorageClass)storage,
5112 is_inline);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005113 }
Greg Clayton147e1fa2011-10-14 22:47:18 +00005114 else
5115 {
5116 func_decl = FunctionDecl::Create (*ast,
5117 decl_ctx,
5118 SourceLocation(),
5119 SourceLocation(),
5120 DeclarationName (),
5121 QualType::getFromOpaquePtr(function_clang_type),
5122 NULL,
5123 (FunctionDecl::StorageClass)storage,
5124 (FunctionDecl::StorageClass)storage,
5125 is_inline);
5126 }
5127 if (func_decl)
5128 decl_ctx->addDecl (func_decl);
Sean Callanan5e9e1992011-10-26 01:06:27 +00005129
5130#ifdef LLDB_CONFIGURATION_DEBUG
5131 VerifyDecl(func_decl);
5132#endif
5133
Greg Clayton147e1fa2011-10-14 22:47:18 +00005134 return func_decl;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005135}
5136
Greg Clayton1be10fc2010-09-29 01:12:09 +00005137clang_type_t
Greg Clayton6beaaa62011-01-17 03:46:26 +00005138ClangASTContext::CreateFunctionType (ASTContext *ast,
Greg Clayton1be10fc2010-09-29 01:12:09 +00005139 clang_type_t result_type,
5140 clang_type_t *args,
Sean Callananc81256a2010-09-16 20:40:25 +00005141 unsigned num_args,
5142 bool is_variadic,
5143 unsigned type_quals)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005144{
Greg Clayton6beaaa62011-01-17 03:46:26 +00005145 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005146 std::vector<QualType> qual_type_args;
5147 for (unsigned i=0; i<num_args; ++i)
5148 qual_type_args.push_back (QualType::getFromOpaquePtr(args[i]));
5149
5150 // TODO: Detect calling convention in DWARF?
Sean Callanan2c777c42011-01-18 23:32:05 +00005151 FunctionProtoType::ExtProtoInfo proto_info;
5152 proto_info.Variadic = is_variadic;
Sean Callananfb0b7582011-03-15 00:17:19 +00005153 proto_info.ExceptionSpecType = EST_None;
Sean Callanan2c777c42011-01-18 23:32:05 +00005154 proto_info.TypeQuals = type_quals;
Sean Callananfb0b7582011-03-15 00:17:19 +00005155 proto_info.RefQualifier = RQ_None;
Sean Callanan2c777c42011-01-18 23:32:05 +00005156 proto_info.NumExceptions = 0;
5157 proto_info.Exceptions = NULL;
5158
Greg Clayton147e1fa2011-10-14 22:47:18 +00005159 return ast->getFunctionType (QualType::getFromOpaquePtr(result_type),
5160 qual_type_args.empty() ? NULL : &qual_type_args.front(),
5161 qual_type_args.size(),
5162 proto_info).getAsOpaquePtr(); // NoReturn);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005163}
5164
5165ParmVarDecl *
Greg Clayton1be10fc2010-09-29 01:12:09 +00005166ClangASTContext::CreateParameterDeclaration (const char *name, clang_type_t param_type, int storage)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005167{
Greg Clayton6beaaa62011-01-17 03:46:26 +00005168 ASTContext *ast = getASTContext();
5169 assert (ast != NULL);
5170 return ParmVarDecl::Create(*ast,
5171 ast->getTranslationUnitDecl(),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005172 SourceLocation(),
Sean Callananfb0b7582011-03-15 00:17:19 +00005173 SourceLocation(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00005174 name && name[0] ? &ast->Idents.get(name) : NULL,
Sean Callananc81256a2010-09-16 20:40:25 +00005175 QualType::getFromOpaquePtr(param_type),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005176 NULL,
5177 (VarDecl::StorageClass)storage,
5178 (VarDecl::StorageClass)storage,
5179 0);
5180}
5181
5182void
5183ClangASTContext::SetFunctionParameters (FunctionDecl *function_decl, ParmVarDecl **params, unsigned num_params)
5184{
5185 if (function_decl)
Sean Callanan880e6802011-10-07 23:18:13 +00005186 function_decl->setParams (ArrayRef<ParmVarDecl*>(params, num_params));
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005187}
5188
5189
5190#pragma mark Array Types
5191
Greg Clayton1be10fc2010-09-29 01:12:09 +00005192clang_type_t
5193ClangASTContext::CreateArrayType (clang_type_t element_type, size_t element_count, uint32_t bit_stride)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005194{
5195 if (element_type)
5196 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00005197 ASTContext *ast = getASTContext();
5198 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005199 llvm::APInt ap_element_count (64, element_count);
Greg Clayton6beaaa62011-01-17 03:46:26 +00005200 return ast->getConstantArrayType(QualType::getFromOpaquePtr(element_type),
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005201 ap_element_count,
5202 ArrayType::Normal,
5203 0).getAsOpaquePtr(); // ElemQuals
5204 }
5205 return NULL;
5206}
5207
5208
5209#pragma mark TagDecl
5210
5211bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005212ClangASTContext::StartTagDeclarationDefinition (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005213{
5214 if (clang_type)
5215 {
5216 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
Sean Callanan78e37602011-01-27 04:42:51 +00005217 const clang::Type *t = qual_type.getTypePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005218 if (t)
5219 {
Sean Callanan78e37602011-01-27 04:42:51 +00005220 const TagType *tag_type = dyn_cast<TagType>(t);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005221 if (tag_type)
5222 {
5223 TagDecl *tag_decl = tag_type->getDecl();
5224 if (tag_decl)
5225 {
5226 tag_decl->startDefinition();
5227 return true;
5228 }
5229 }
Sean Callanan5b26f272012-02-04 08:49:35 +00005230
5231 const ObjCObjectType *object_type = dyn_cast<ObjCObjectType>(t);
5232 if (object_type)
5233 {
5234 ObjCInterfaceDecl *interface_decl = object_type->getInterface();
5235 if (interface_decl)
5236 {
5237 interface_decl->startDefinition();
5238 return true;
5239 }
5240 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005241 }
5242 }
5243 return false;
5244}
5245
5246bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005247ClangASTContext::CompleteTagDeclarationDefinition (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005248{
5249 if (clang_type)
5250 {
5251 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
Greg Clayton14372242010-09-29 03:44:17 +00005252
5253 CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
5254
5255 if (cxx_record_decl)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005256 {
Greg Clayton14372242010-09-29 03:44:17 +00005257 cxx_record_decl->completeDefinition();
5258
5259 return true;
5260 }
5261
5262 const EnumType *enum_type = dyn_cast<EnumType>(qual_type.getTypePtr());
5263
5264 if (enum_type)
5265 {
5266 EnumDecl *enum_decl = enum_type->getDecl();
5267
5268 if (enum_decl)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005269 {
Greg Clayton14372242010-09-29 03:44:17 +00005270 /// TODO This really needs to be fixed.
5271
5272 unsigned NumPositiveBits = 1;
5273 unsigned NumNegativeBits = 0;
5274
Greg Clayton6beaaa62011-01-17 03:46:26 +00005275 ASTContext *ast = getASTContext();
Greg Claytone02b8502010-10-12 04:29:14 +00005276
5277 QualType promotion_qual_type;
5278 // If the enum integer type is less than an integer in bit width,
5279 // then we must promote it to an integer size.
Greg Clayton6beaaa62011-01-17 03:46:26 +00005280 if (ast->getTypeSize(enum_decl->getIntegerType()) < ast->getTypeSize(ast->IntTy))
Greg Claytone02b8502010-10-12 04:29:14 +00005281 {
5282 if (enum_decl->getIntegerType()->isSignedIntegerType())
Greg Clayton6beaaa62011-01-17 03:46:26 +00005283 promotion_qual_type = ast->IntTy;
Greg Claytone02b8502010-10-12 04:29:14 +00005284 else
Greg Clayton6beaaa62011-01-17 03:46:26 +00005285 promotion_qual_type = ast->UnsignedIntTy;
Greg Claytone02b8502010-10-12 04:29:14 +00005286 }
5287 else
5288 promotion_qual_type = enum_decl->getIntegerType();
5289
5290 enum_decl->completeDefinition(enum_decl->getIntegerType(), promotion_qual_type, NumPositiveBits, NumNegativeBits);
Greg Clayton14372242010-09-29 03:44:17 +00005291 return true;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005292 }
5293 }
5294 }
5295 return false;
5296}
5297
5298
5299#pragma mark Enumeration Types
5300
Greg Clayton1be10fc2010-09-29 01:12:09 +00005301clang_type_t
Greg Claytonca512b32011-01-14 04:54:56 +00005302ClangASTContext::CreateEnumerationType
5303(
5304 const char *name,
5305 DeclContext *decl_ctx,
5306 const Declaration &decl,
5307 clang_type_t integer_qual_type
5308)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005309{
5310 // TODO: Do something intelligent with the Declaration object passed in
5311 // like maybe filling in the SourceLocation with it...
Greg Clayton6beaaa62011-01-17 03:46:26 +00005312 ASTContext *ast = getASTContext();
5313 assert (ast != NULL);
Greg Claytone02b8502010-10-12 04:29:14 +00005314
5315 // TODO: ask about these...
5316// const bool IsScoped = false;
5317// const bool IsFixed = false;
5318
Greg Clayton6beaaa62011-01-17 03:46:26 +00005319 EnumDecl *enum_decl = EnumDecl::Create (*ast,
Greg Claytonca512b32011-01-14 04:54:56 +00005320 decl_ctx,
Greg Claytone02b8502010-10-12 04:29:14 +00005321 SourceLocation(),
Greg Claytone02b8502010-10-12 04:29:14 +00005322 SourceLocation(),
Sean Callananfb0b7582011-03-15 00:17:19 +00005323 name && name[0] ? &ast->Idents.get(name) : NULL,
Sean Callanan48114472010-12-13 01:26:27 +00005324 NULL,
5325 false, // IsScoped
5326 false, // IsScopedUsingClassTag
5327 false); // IsFixed
Sean Callanan2652ad22011-01-18 01:03:44 +00005328
5329
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005330 if (enum_decl)
Greg Clayton83ff3892010-09-12 23:17:56 +00005331 {
5332 // TODO: check if we should be setting the promotion type too?
5333 enum_decl->setIntegerType(QualType::getFromOpaquePtr (integer_qual_type));
Sean Callanan2652ad22011-01-18 01:03:44 +00005334
5335 enum_decl->setAccess(AS_public); // TODO respect what's in the debug info
5336
Greg Clayton6beaaa62011-01-17 03:46:26 +00005337 return ast->getTagDeclType(enum_decl).getAsOpaquePtr();
Greg Clayton83ff3892010-09-12 23:17:56 +00005338 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005339 return NULL;
5340}
5341
Greg Clayton1be10fc2010-09-29 01:12:09 +00005342clang_type_t
5343ClangASTContext::GetEnumerationIntegerType (clang_type_t enum_clang_type)
5344{
5345 QualType enum_qual_type (QualType::getFromOpaquePtr(enum_clang_type));
5346
Sean Callanan78e37602011-01-27 04:42:51 +00005347 const clang::Type *clang_type = enum_qual_type.getTypePtr();
Greg Clayton1be10fc2010-09-29 01:12:09 +00005348 if (clang_type)
5349 {
5350 const EnumType *enum_type = dyn_cast<EnumType>(clang_type);
5351 if (enum_type)
5352 {
5353 EnumDecl *enum_decl = enum_type->getDecl();
5354 if (enum_decl)
5355 return enum_decl->getIntegerType().getAsOpaquePtr();
5356 }
5357 }
5358 return NULL;
5359}
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005360bool
5361ClangASTContext::AddEnumerationValueToEnumerationType
5362(
Greg Clayton1be10fc2010-09-29 01:12:09 +00005363 clang_type_t enum_clang_type,
5364 clang_type_t enumerator_clang_type,
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005365 const Declaration &decl,
5366 const char *name,
5367 int64_t enum_value,
5368 uint32_t enum_value_bit_size
5369)
5370{
5371 if (enum_clang_type && enumerator_clang_type && name)
5372 {
5373 // TODO: Do something intelligent with the Declaration object passed in
5374 // like maybe filling in the SourceLocation with it...
Greg Clayton6beaaa62011-01-17 03:46:26 +00005375 ASTContext *ast = getASTContext();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005376 IdentifierTable *identifier_table = getIdentifierTable();
5377
Greg Clayton6beaaa62011-01-17 03:46:26 +00005378 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005379 assert (identifier_table != NULL);
5380 QualType enum_qual_type (QualType::getFromOpaquePtr(enum_clang_type));
5381
Sean Callanan78e37602011-01-27 04:42:51 +00005382 const clang::Type *clang_type = enum_qual_type.getTypePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005383 if (clang_type)
5384 {
5385 const EnumType *enum_type = dyn_cast<EnumType>(clang_type);
5386
5387 if (enum_type)
5388 {
5389 llvm::APSInt enum_llvm_apsint(enum_value_bit_size, false);
5390 enum_llvm_apsint = enum_value;
5391 EnumConstantDecl *enumerator_decl =
Greg Clayton6beaaa62011-01-17 03:46:26 +00005392 EnumConstantDecl::Create (*ast,
5393 enum_type->getDecl(),
5394 SourceLocation(),
5395 name ? &identifier_table->get(name) : NULL, // Identifier
5396 QualType::getFromOpaquePtr(enumerator_clang_type),
5397 NULL,
5398 enum_llvm_apsint);
5399
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005400 if (enumerator_decl)
5401 {
5402 enum_type->getDecl()->addDecl(enumerator_decl);
Sean Callanan5e9e1992011-10-26 01:06:27 +00005403
5404#ifdef LLDB_CONFIGURATION_DEBUG
5405 VerifyDecl(enumerator_decl);
5406#endif
5407
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005408 return true;
5409 }
5410 }
5411 }
5412 }
5413 return false;
5414}
5415
5416#pragma mark Pointers & References
5417
Greg Clayton1be10fc2010-09-29 01:12:09 +00005418clang_type_t
5419ClangASTContext::CreatePointerType (clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005420{
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00005421 return CreatePointerType (getASTContext(), clang_type);
5422}
5423
5424clang_type_t
5425ClangASTContext::CreatePointerType (clang::ASTContext *ast, clang_type_t clang_type)
5426{
5427 if (ast && clang_type)
Greg Clayton5fb47cd2010-07-29 20:06:32 +00005428 {
5429 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5430
Greg Clayton737b9322010-09-13 03:32:57 +00005431 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
5432 switch (type_class)
Greg Clayton5fb47cd2010-07-29 20:06:32 +00005433 {
5434 case clang::Type::ObjCObject:
5435 case clang::Type::ObjCInterface:
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00005436 return ast->getObjCObjectPointerType(qual_type).getAsOpaquePtr();
Greg Clayton5fb47cd2010-07-29 20:06:32 +00005437
Greg Clayton5fb47cd2010-07-29 20:06:32 +00005438 default:
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00005439 return ast->getPointerType(qual_type).getAsOpaquePtr();
Greg Clayton5fb47cd2010-07-29 20:06:32 +00005440 }
5441 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005442 return NULL;
5443}
5444
Greg Clayton1be10fc2010-09-29 01:12:09 +00005445clang_type_t
Sean Callanan92adcac2011-01-13 08:53:35 +00005446ClangASTContext::CreateLValueReferenceType (clang::ASTContext *ast,
5447 clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005448{
5449 if (clang_type)
Sean Callanan92adcac2011-01-13 08:53:35 +00005450 return ast->getLValueReferenceType (QualType::getFromOpaquePtr(clang_type)).getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005451 return NULL;
5452}
5453
Greg Clayton1be10fc2010-09-29 01:12:09 +00005454clang_type_t
Sean Callanan92adcac2011-01-13 08:53:35 +00005455ClangASTContext::CreateRValueReferenceType (clang::ASTContext *ast,
5456 clang_type_t clang_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005457{
5458 if (clang_type)
Sean Callanan92adcac2011-01-13 08:53:35 +00005459 return ast->getRValueReferenceType (QualType::getFromOpaquePtr(clang_type)).getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005460 return NULL;
5461}
5462
Greg Clayton1be10fc2010-09-29 01:12:09 +00005463clang_type_t
5464ClangASTContext::CreateMemberPointerType (clang_type_t clang_pointee_type, clang_type_t clang_class_type)
Greg Clayton9b81a312010-06-12 01:20:30 +00005465{
5466 if (clang_pointee_type && clang_pointee_type)
5467 return getASTContext()->getMemberPointerType(QualType::getFromOpaquePtr(clang_pointee_type),
5468 QualType::getFromOpaquePtr(clang_class_type).getTypePtr()).getAsOpaquePtr();
5469 return NULL;
5470}
5471
Greg Clayton1a65ae12011-01-25 23:55:37 +00005472uint32_t
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005473ClangASTContext::GetPointerBitSize ()
5474{
Greg Clayton6beaaa62011-01-17 03:46:26 +00005475 ASTContext *ast = getASTContext();
5476 return ast->getTypeSize(ast->VoidPtrTy);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005477}
5478
5479bool
Greg Clayton219cf312012-03-30 00:51:13 +00005480ClangASTContext::IsPossibleDynamicType (clang::ASTContext *ast,
5481 clang_type_t clang_type,
5482 clang_type_t *dynamic_pointee_type,
5483 bool check_cplusplus,
5484 bool check_objc)
Greg Claytondea8cb42011-06-29 22:09:02 +00005485{
5486 QualType pointee_qual_type;
5487 if (clang_type)
5488 {
5489 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5490 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
5491 bool success = false;
5492 switch (type_class)
5493 {
5494 case clang::Type::Builtin:
Greg Clayton219cf312012-03-30 00:51:13 +00005495 if (check_objc && cast<clang::BuiltinType>(qual_type)->getKind() == clang::BuiltinType::ObjCId)
Greg Claytondea8cb42011-06-29 22:09:02 +00005496 {
5497 if (dynamic_pointee_type)
5498 *dynamic_pointee_type = clang_type;
5499 return true;
5500 }
5501 break;
5502
5503 case clang::Type::ObjCObjectPointer:
Greg Clayton219cf312012-03-30 00:51:13 +00005504 if (check_objc)
5505 {
5506 if (dynamic_pointee_type)
5507 *dynamic_pointee_type = cast<ObjCObjectPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5508 return true;
5509 }
5510 break;
Greg Claytondea8cb42011-06-29 22:09:02 +00005511
5512 case clang::Type::Pointer:
5513 pointee_qual_type = cast<PointerType>(qual_type)->getPointeeType();
5514 success = true;
5515 break;
5516
5517 case clang::Type::LValueReference:
5518 case clang::Type::RValueReference:
5519 pointee_qual_type = cast<ReferenceType>(qual_type)->getPointeeType();
5520 success = true;
5521 break;
5522
5523 case clang::Type::Typedef:
Greg Clayton70364252012-08-31 18:56:24 +00005524 return ClangASTContext::IsPossibleDynamicType (ast,
5525 cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
5526 dynamic_pointee_type,
5527 check_cplusplus,
5528 check_objc);
Sean Callanan912855f2011-08-11 23:56:13 +00005529
5530 case clang::Type::Elaborated:
Greg Clayton70364252012-08-31 18:56:24 +00005531 return ClangASTContext::IsPossibleDynamicType (ast,
5532 cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
5533 dynamic_pointee_type,
5534 check_cplusplus,
5535 check_objc);
Sean Callanan912855f2011-08-11 23:56:13 +00005536
Greg Claytondea8cb42011-06-29 22:09:02 +00005537 default:
5538 break;
5539 }
5540
5541 if (success)
5542 {
5543 // Check to make sure what we are pointing too is a possible dynamic C++ type
5544 // We currently accept any "void *" (in case we have a class that has been
5545 // watered down to an opaque pointer) and virtual C++ classes.
5546 const clang::Type::TypeClass pointee_type_class = pointee_qual_type->getTypeClass();
5547 switch (pointee_type_class)
5548 {
5549 case clang::Type::Builtin:
5550 switch (cast<clang::BuiltinType>(pointee_qual_type)->getKind())
5551 {
5552 case clang::BuiltinType::UnknownAny:
5553 case clang::BuiltinType::Void:
5554 if (dynamic_pointee_type)
5555 *dynamic_pointee_type = pointee_qual_type.getAsOpaquePtr();
5556 return true;
5557
5558 case clang::BuiltinType::NullPtr:
5559 case clang::BuiltinType::Bool:
5560 case clang::BuiltinType::Char_U:
5561 case clang::BuiltinType::UChar:
5562 case clang::BuiltinType::WChar_U:
5563 case clang::BuiltinType::Char16:
5564 case clang::BuiltinType::Char32:
5565 case clang::BuiltinType::UShort:
5566 case clang::BuiltinType::UInt:
5567 case clang::BuiltinType::ULong:
5568 case clang::BuiltinType::ULongLong:
5569 case clang::BuiltinType::UInt128:
5570 case clang::BuiltinType::Char_S:
5571 case clang::BuiltinType::SChar:
5572 case clang::BuiltinType::WChar_S:
5573 case clang::BuiltinType::Short:
5574 case clang::BuiltinType::Int:
5575 case clang::BuiltinType::Long:
5576 case clang::BuiltinType::LongLong:
5577 case clang::BuiltinType::Int128:
5578 case clang::BuiltinType::Float:
5579 case clang::BuiltinType::Double:
5580 case clang::BuiltinType::LongDouble:
5581 case clang::BuiltinType::Dependent:
5582 case clang::BuiltinType::Overload:
5583 case clang::BuiltinType::ObjCId:
5584 case clang::BuiltinType::ObjCClass:
5585 case clang::BuiltinType::ObjCSel:
5586 case clang::BuiltinType::BoundMember:
Greg Claytonf0705c82011-10-22 03:33:13 +00005587 case clang::BuiltinType::Half:
5588 case clang::BuiltinType::ARCUnbridgedCast:
Greg Claytoned3ae702011-11-09 19:04:58 +00005589 case clang::BuiltinType::PseudoObject:
Sean Callanan3d654b32012-09-24 22:25:51 +00005590 case clang::BuiltinType::BuiltinFn:
Greg Claytondea8cb42011-06-29 22:09:02 +00005591 break;
5592 }
5593 break;
5594
5595 case clang::Type::Record:
Greg Clayton219cf312012-03-30 00:51:13 +00005596 if (check_cplusplus)
Greg Claytondea8cb42011-06-29 22:09:02 +00005597 {
5598 CXXRecordDecl *cxx_record_decl = pointee_qual_type->getAsCXXRecordDecl();
5599 if (cxx_record_decl)
5600 {
Greg Clayton70364252012-08-31 18:56:24 +00005601 bool is_complete = cxx_record_decl->isCompleteDefinition();
5602 if (!is_complete)
Sean Callanan6e4100ea2012-09-08 00:49:45 +00005603 is_complete = ClangASTContext::GetCompleteType (ast, pointee_qual_type.getAsOpaquePtr());
Greg Clayton70364252012-08-31 18:56:24 +00005604
5605 if (is_complete)
Greg Claytondea8cb42011-06-29 22:09:02 +00005606 {
5607 success = cxx_record_decl->isDynamicClass();
5608 }
5609 else
5610 {
Greg Clayton70364252012-08-31 18:56:24 +00005611 success = false;
Greg Claytondea8cb42011-06-29 22:09:02 +00005612 }
Greg Clayton70364252012-08-31 18:56:24 +00005613
Greg Claytondea8cb42011-06-29 22:09:02 +00005614 if (success)
5615 {
5616 if (dynamic_pointee_type)
5617 *dynamic_pointee_type = pointee_qual_type.getAsOpaquePtr();
5618 return true;
5619 }
5620 }
5621 }
5622 break;
5623
5624 case clang::Type::ObjCObject:
5625 case clang::Type::ObjCInterface:
Greg Clayton219cf312012-03-30 00:51:13 +00005626 if (check_objc)
5627 {
5628 if (dynamic_pointee_type)
5629 *dynamic_pointee_type = pointee_qual_type.getAsOpaquePtr();
5630 return true;
5631 }
5632 break;
Greg Claytondea8cb42011-06-29 22:09:02 +00005633
5634 default:
5635 break;
5636 }
5637 }
5638 }
5639 if (dynamic_pointee_type)
5640 *dynamic_pointee_type = NULL;
5641 return false;
5642}
5643
5644
5645bool
Greg Clayton007d5be2011-05-30 00:49:24 +00005646ClangASTContext::IsPossibleCPlusPlusDynamicType (clang::ASTContext *ast, clang_type_t clang_type, clang_type_t *dynamic_pointee_type)
5647{
Greg Clayton219cf312012-03-30 00:51:13 +00005648 return IsPossibleDynamicType (ast,
5649 clang_type,
5650 dynamic_pointee_type,
5651 true, // Check for dynamic C++ types
5652 false); // Check for dynamic ObjC types
Greg Clayton007d5be2011-05-30 00:49:24 +00005653}
5654
Sean Callanan98298012011-10-27 19:41:13 +00005655bool
5656ClangASTContext::IsReferenceType (clang_type_t clang_type, clang_type_t *target_type)
5657{
5658 if (clang_type == NULL)
5659 return false;
5660
5661 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5662 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
5663
5664 switch (type_class)
5665 {
5666 case clang::Type::LValueReference:
5667 if (target_type)
5668 *target_type = cast<LValueReferenceType>(qual_type)->desugar().getAsOpaquePtr();
5669 return true;
5670 case clang::Type::RValueReference:
5671 if (target_type)
5672 *target_type = cast<LValueReferenceType>(qual_type)->desugar().getAsOpaquePtr();
5673 return true;
5674 case clang::Type::Typedef:
5675 return ClangASTContext::IsReferenceType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
5676 case clang::Type::Elaborated:
5677 return ClangASTContext::IsReferenceType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
5678 default:
5679 break;
5680 }
5681
5682 return false;
5683}
Greg Clayton007d5be2011-05-30 00:49:24 +00005684
5685bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005686ClangASTContext::IsPointerOrReferenceType (clang_type_t clang_type, clang_type_t*target_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005687{
5688 if (clang_type == NULL)
5689 return false;
5690
5691 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
Greg Clayton737b9322010-09-13 03:32:57 +00005692 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
5693 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005694 {
Sean Callanana2424172010-10-25 00:29:48 +00005695 case clang::Type::Builtin:
5696 switch (cast<clang::BuiltinType>(qual_type)->getKind())
5697 {
5698 default:
5699 break;
5700 case clang::BuiltinType::ObjCId:
5701 case clang::BuiltinType::ObjCClass:
Sean Callanana2424172010-10-25 00:29:48 +00005702 return true;
5703 }
5704 return false;
Greg Claytone1a916a2010-07-21 22:12:05 +00005705 case clang::Type::ObjCObjectPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005706 if (target_type)
5707 *target_type = cast<ObjCObjectPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5708 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005709 case clang::Type::BlockPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005710 if (target_type)
5711 *target_type = cast<BlockPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5712 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005713 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005714 if (target_type)
5715 *target_type = cast<PointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5716 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005717 case clang::Type::MemberPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005718 if (target_type)
5719 *target_type = cast<MemberPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5720 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005721 case clang::Type::LValueReference:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005722 if (target_type)
5723 *target_type = cast<LValueReferenceType>(qual_type)->desugar().getAsOpaquePtr();
5724 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005725 case clang::Type::RValueReference:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005726 if (target_type)
5727 *target_type = cast<LValueReferenceType>(qual_type)->desugar().getAsOpaquePtr();
5728 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005729 case clang::Type::Typedef:
Sean Callanan48114472010-12-13 01:26:27 +00005730 return ClangASTContext::IsPointerOrReferenceType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Sean Callanan912855f2011-08-11 23:56:13 +00005731 case clang::Type::Elaborated:
5732 return ClangASTContext::IsPointerOrReferenceType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005733 default:
5734 break;
5735 }
5736 return false;
5737}
5738
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005739bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005740ClangASTContext::IsIntegerType (clang_type_t clang_type, bool &is_signed)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005741{
5742 if (!clang_type)
5743 return false;
5744
5745 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5746 const BuiltinType *builtin_type = dyn_cast<BuiltinType>(qual_type->getCanonicalTypeInternal());
5747
5748 if (builtin_type)
5749 {
5750 if (builtin_type->isInteger())
Jim Inghamef651602011-12-22 19:12:40 +00005751 {
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005752 is_signed = builtin_type->isSignedInteger();
Jim Inghamef651602011-12-22 19:12:40 +00005753 return true;
5754 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005755 }
5756
5757 return false;
5758}
5759
5760bool
Greg Claytonaffb03b2011-07-08 18:27:39 +00005761ClangASTContext::IsPointerType (clang_type_t clang_type, clang_type_t *target_type)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005762{
Greg Claytonaffb03b2011-07-08 18:27:39 +00005763 if (target_type)
5764 *target_type = NULL;
5765
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005766 if (clang_type)
5767 {
5768 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
Greg Clayton737b9322010-09-13 03:32:57 +00005769 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
5770 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005771 {
Sean Callanana2424172010-10-25 00:29:48 +00005772 case clang::Type::Builtin:
5773 switch (cast<clang::BuiltinType>(qual_type)->getKind())
5774 {
5775 default:
5776 break;
5777 case clang::BuiltinType::ObjCId:
5778 case clang::BuiltinType::ObjCClass:
Sean Callanana2424172010-10-25 00:29:48 +00005779 return true;
5780 }
5781 return false;
Greg Claytone1a916a2010-07-21 22:12:05 +00005782 case clang::Type::ObjCObjectPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005783 if (target_type)
5784 *target_type = cast<ObjCObjectPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5785 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005786 case clang::Type::BlockPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005787 if (target_type)
5788 *target_type = cast<BlockPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5789 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005790 case clang::Type::Pointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005791 if (target_type)
5792 *target_type = cast<PointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5793 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005794 case clang::Type::MemberPointer:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005795 if (target_type)
5796 *target_type = cast<MemberPointerType>(qual_type)->getPointeeType().getAsOpaquePtr();
5797 return true;
Greg Claytone1a916a2010-07-21 22:12:05 +00005798 case clang::Type::Typedef:
Greg Claytonaffb03b2011-07-08 18:27:39 +00005799 return ClangASTContext::IsPointerType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(), target_type);
Sean Callanan912855f2011-08-11 23:56:13 +00005800 case clang::Type::Elaborated:
5801 return ClangASTContext::IsPointerType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(), target_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005802 default:
5803 break;
5804 }
5805 }
5806 return false;
5807}
5808
5809bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005810ClangASTContext::IsFloatingPointType (clang_type_t clang_type, uint32_t &count, bool &is_complex)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005811{
5812 if (clang_type)
5813 {
5814 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5815
5816 if (const BuiltinType *BT = dyn_cast<BuiltinType>(qual_type->getCanonicalTypeInternal()))
5817 {
5818 clang::BuiltinType::Kind kind = BT->getKind();
5819 if (kind >= BuiltinType::Float && kind <= BuiltinType::LongDouble)
5820 {
5821 count = 1;
5822 is_complex = false;
5823 return true;
5824 }
5825 }
5826 else if (const ComplexType *CT = dyn_cast<ComplexType>(qual_type->getCanonicalTypeInternal()))
5827 {
5828 if (IsFloatingPointType(CT->getElementType().getAsOpaquePtr(), count, is_complex))
5829 {
5830 count = 2;
5831 is_complex = true;
5832 return true;
5833 }
5834 }
5835 else if (const VectorType *VT = dyn_cast<VectorType>(qual_type->getCanonicalTypeInternal()))
5836 {
5837 if (IsFloatingPointType(VT->getElementType().getAsOpaquePtr(), count, is_complex))
5838 {
5839 count = VT->getNumElements();
5840 is_complex = false;
5841 return true;
5842 }
5843 }
5844 }
5845 return false;
5846}
5847
Enrico Granata9fc19442011-07-06 02:13:41 +00005848bool
5849ClangASTContext::IsScalarType (lldb::clang_type_t clang_type)
5850{
5851 bool is_signed;
5852 if (ClangASTContext::IsIntegerType(clang_type, is_signed))
5853 return true;
5854
5855 uint32_t count;
5856 bool is_complex;
5857 return ClangASTContext::IsFloatingPointType(clang_type, count, is_complex) && !is_complex;
5858}
5859
5860bool
5861ClangASTContext::IsPointerToScalarType (lldb::clang_type_t clang_type)
5862{
5863 if (!IsPointerType(clang_type))
5864 return false;
5865
5866 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5867 lldb::clang_type_t pointee_type = qual_type.getTypePtr()->getPointeeType().getAsOpaquePtr();
5868 return IsScalarType(pointee_type);
5869}
5870
5871bool
5872ClangASTContext::IsArrayOfScalarType (lldb::clang_type_t clang_type)
5873{
Sean Callanan0caa21c2012-01-19 23:54:24 +00005874 clang_type = GetAsArrayType(clang_type);
5875
5876 if (clang_type == 0)
Enrico Granata9fc19442011-07-06 02:13:41 +00005877 return false;
5878
5879 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5880 lldb::clang_type_t item_type = cast<ArrayType>(qual_type.getTypePtr())->getElementType().getAsOpaquePtr();
5881 return IsScalarType(item_type);
5882}
5883
Greg Clayton8f92f0a2010-10-14 22:52:14 +00005884
5885bool
5886ClangASTContext::GetCXXClassName (clang_type_t clang_type, std::string &class_name)
5887{
5888 if (clang_type)
5889 {
5890 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5891
5892 CXXRecordDecl *cxx_record_decl = qual_type->getAsCXXRecordDecl();
5893 if (cxx_record_decl)
5894 {
5895 class_name.assign (cxx_record_decl->getIdentifier()->getNameStart());
5896 return true;
5897 }
5898 }
5899 class_name.clear();
5900 return false;
5901}
5902
5903
Greg Clayton0fffff52010-09-24 05:15:53 +00005904bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005905ClangASTContext::IsCXXClassType (clang_type_t clang_type)
Greg Clayton0fffff52010-09-24 05:15:53 +00005906{
5907 if (clang_type)
5908 {
5909 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5910 if (qual_type->getAsCXXRecordDecl() != NULL)
5911 return true;
5912 }
5913 return false;
5914}
5915
Greg Clayton20568dd2011-10-13 23:13:20 +00005916bool
5917ClangASTContext::IsBeingDefined (lldb::clang_type_t clang_type)
5918{
5919 if (clang_type)
5920 {
5921 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5922 const clang::TagType *tag_type = dyn_cast<clang::TagType>(qual_type);
5923 if (tag_type)
5924 return tag_type->isBeingDefined();
5925 }
5926 return false;
5927}
5928
Greg Clayton0fffff52010-09-24 05:15:53 +00005929bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005930ClangASTContext::IsObjCClassType (clang_type_t clang_type)
Greg Clayton0fffff52010-09-24 05:15:53 +00005931{
5932 if (clang_type)
5933 {
5934 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5935 if (qual_type->isObjCObjectOrInterfaceType())
5936 return true;
5937 }
5938 return false;
5939}
5940
Sean Callanan72772842012-02-22 23:57:45 +00005941bool
5942ClangASTContext::IsObjCObjectPointerType (lldb::clang_type_t clang_type, clang_type_t *class_type)
5943{
5944 if (clang_type)
5945 {
5946 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
5947 if (qual_type->isObjCObjectPointerType())
5948 {
5949 if (class_type)
5950 {
5951 *class_type = NULL;
5952
5953 if (!qual_type->isObjCClassType() &&
5954 !qual_type->isObjCIdType())
5955 {
5956 const ObjCObjectPointerType *obj_pointer_type = dyn_cast<ObjCObjectPointerType>(qual_type);
Sean Callanand7dabe22012-03-10 01:59:11 +00005957 if (!obj_pointer_type)
5958 *class_type = NULL;
Sean Callanan1fc91ad2012-03-10 02:00:32 +00005959 else
5960 *class_type = QualType(obj_pointer_type->getInterfaceType(), 0).getAsOpaquePtr();
Sean Callanan72772842012-02-22 23:57:45 +00005961 }
5962 }
5963 return true;
5964 }
5965 }
5966 return false;
5967}
5968
5969bool
5970ClangASTContext::GetObjCClassName (lldb::clang_type_t clang_type,
5971 std::string &class_name)
5972{
5973 if (!clang_type)
5974 return false;
5975
5976 const ObjCObjectType *object_type = dyn_cast<ObjCObjectType>(QualType::getFromOpaquePtr(clang_type));
5977 if (!object_type)
5978 return false;
5979
5980 const ObjCInterfaceDecl *interface = object_type->getInterface();
5981 if (!interface)
5982 return false;
5983
5984 class_name = interface->getNameAsString();
5985 return true;
5986}
Greg Clayton0fffff52010-09-24 05:15:53 +00005987
Greg Clayton73b472d2010-10-27 03:32:59 +00005988bool
5989ClangASTContext::IsCharType (clang_type_t clang_type)
5990{
5991 if (clang_type)
5992 return QualType::getFromOpaquePtr(clang_type)->isCharType();
5993 return false;
5994}
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005995
5996bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00005997ClangASTContext::IsCStringType (clang_type_t clang_type, uint32_t &length)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00005998{
Greg Clayton73b472d2010-10-27 03:32:59 +00005999 clang_type_t pointee_or_element_clang_type = NULL;
6000 Flags type_flags (ClangASTContext::GetTypeInfo (clang_type, NULL, &pointee_or_element_clang_type));
6001
6002 if (pointee_or_element_clang_type == NULL)
6003 return false;
6004
6005 if (type_flags.AnySet (eTypeIsArray | eTypeIsPointer))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006006 {
Greg Clayton73b472d2010-10-27 03:32:59 +00006007 QualType pointee_or_element_qual_type (QualType::getFromOpaquePtr (pointee_or_element_clang_type));
6008
6009 if (pointee_or_element_qual_type.getUnqualifiedType()->isCharType())
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006010 {
Greg Clayton73b472d2010-10-27 03:32:59 +00006011 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
6012 if (type_flags.Test (eTypeIsArray))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006013 {
Greg Clayton73b472d2010-10-27 03:32:59 +00006014 // We know the size of the array and it could be a C string
6015 // since it is an array of characters
6016 length = cast<ConstantArrayType>(qual_type.getTypePtr())->getSize().getLimitedValue();
6017 return true;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006018 }
Greg Clayton73b472d2010-10-27 03:32:59 +00006019 else
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006020 {
Greg Clayton73b472d2010-10-27 03:32:59 +00006021 length = 0;
6022 return true;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006023 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006024
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006025 }
6026 }
6027 return false;
6028}
6029
6030bool
Greg Clayton1be10fc2010-09-29 01:12:09 +00006031ClangASTContext::IsFunctionPointerType (clang_type_t clang_type)
Greg Clayton737b9322010-09-13 03:32:57 +00006032{
6033 if (clang_type)
6034 {
6035 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
6036
6037 if (qual_type->isFunctionPointerType())
6038 return true;
6039
6040 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
6041 switch (type_class)
6042 {
Sean Callananfb0b7582011-03-15 00:17:19 +00006043 default:
6044 break;
Greg Clayton737b9322010-09-13 03:32:57 +00006045 case clang::Type::Typedef:
Sean Callanan48114472010-12-13 01:26:27 +00006046 return ClangASTContext::IsFunctionPointerType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Sean Callanan912855f2011-08-11 23:56:13 +00006047 case clang::Type::Elaborated:
6048 return ClangASTContext::IsFunctionPointerType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Greg Clayton737b9322010-09-13 03:32:57 +00006049
6050 case clang::Type::LValueReference:
6051 case clang::Type::RValueReference:
6052 {
Sean Callanan78e37602011-01-27 04:42:51 +00006053 const ReferenceType *reference_type = cast<ReferenceType>(qual_type.getTypePtr());
Greg Clayton737b9322010-09-13 03:32:57 +00006054 if (reference_type)
6055 return ClangASTContext::IsFunctionPointerType (reference_type->getPointeeType().getAsOpaquePtr());
6056 }
6057 break;
6058 }
6059 }
6060 return false;
6061}
6062
Greg Clayton73b472d2010-10-27 03:32:59 +00006063size_t
6064ClangASTContext::GetArraySize (clang_type_t clang_type)
6065{
6066 if (clang_type)
6067 {
Greg Claytonef37d68a2011-07-09 17:12:27 +00006068 QualType qual_type(QualType::getFromOpaquePtr(clang_type));
6069 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
6070 switch (type_class)
6071 {
6072 case clang::Type::ConstantArray:
6073 {
6074 const ConstantArrayType *array = cast<ConstantArrayType>(QualType::getFromOpaquePtr(clang_type).getTypePtr());
6075 if (array)
6076 return array->getSize().getLimitedValue();
6077 }
6078 break;
6079
6080 case clang::Type::Typedef:
6081 return ClangASTContext::GetArraySize(cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr());
Sean Callanan912855f2011-08-11 23:56:13 +00006082
6083 case clang::Type::Elaborated:
6084 return ClangASTContext::GetArraySize(cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr());
Enrico Granataf9fa6ee2011-07-12 00:18:11 +00006085
6086 default:
6087 break;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006088 }
Greg Clayton73b472d2010-10-27 03:32:59 +00006089 }
6090 return 0;
6091}
Greg Clayton737b9322010-09-13 03:32:57 +00006092
Sean Callanan0caa21c2012-01-19 23:54:24 +00006093clang_type_t
6094ClangASTContext::GetAsArrayType (clang_type_t clang_type, clang_type_t*member_type, uint64_t *size)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006095{
6096 if (!clang_type)
Sean Callanan0caa21c2012-01-19 23:54:24 +00006097 return 0;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006098
6099 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
6100
Greg Clayton737b9322010-09-13 03:32:57 +00006101 const clang::Type::TypeClass type_class = qual_type->getTypeClass();
6102 switch (type_class)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006103 {
Sean Callananfb0b7582011-03-15 00:17:19 +00006104 default:
6105 break;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006106
Greg Claytone1a916a2010-07-21 22:12:05 +00006107 case clang::Type::ConstantArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006108 if (member_type)
6109 *member_type = cast<ConstantArrayType>(qual_type)->getElementType().getAsOpaquePtr();
6110 if (size)
Greg Claytonac4827f2011-04-01 18:14:08 +00006111 *size = cast<ConstantArrayType>(qual_type)->getSize().getLimitedValue(ULLONG_MAX);
Sean Callanan0caa21c2012-01-19 23:54:24 +00006112 return clang_type;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006113
Greg Claytone1a916a2010-07-21 22:12:05 +00006114 case clang::Type::IncompleteArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006115 if (member_type)
6116 *member_type = cast<IncompleteArrayType>(qual_type)->getElementType().getAsOpaquePtr();
6117 if (size)
6118 *size = 0;
Sean Callanan0caa21c2012-01-19 23:54:24 +00006119 return clang_type;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006120
Greg Claytone1a916a2010-07-21 22:12:05 +00006121 case clang::Type::VariableArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006122 if (member_type)
6123 *member_type = cast<VariableArrayType>(qual_type)->getElementType().getAsOpaquePtr();
6124 if (size)
6125 *size = 0;
Sean Callanan0caa21c2012-01-19 23:54:24 +00006126 return clang_type;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006127
Greg Claytone1a916a2010-07-21 22:12:05 +00006128 case clang::Type::DependentSizedArray:
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006129 if (member_type)
6130 *member_type = cast<DependentSizedArrayType>(qual_type)->getElementType().getAsOpaquePtr();
6131 if (size)
6132 *size = 0;
Sean Callanan0caa21c2012-01-19 23:54:24 +00006133 return clang_type;
Greg Claytonef37d68a2011-07-09 17:12:27 +00006134
6135 case clang::Type::Typedef:
Sean Callanan0caa21c2012-01-19 23:54:24 +00006136 return ClangASTContext::GetAsArrayType (cast<TypedefType>(qual_type)->getDecl()->getUnderlyingType().getAsOpaquePtr(),
6137 member_type,
6138 size);
Sean Callanan912855f2011-08-11 23:56:13 +00006139
6140 case clang::Type::Elaborated:
Sean Callanan0caa21c2012-01-19 23:54:24 +00006141 return ClangASTContext::GetAsArrayType (cast<ElaboratedType>(qual_type)->getNamedType().getAsOpaquePtr(),
6142 member_type,
6143 size);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006144 }
Sean Callanan0caa21c2012-01-19 23:54:24 +00006145 return 0;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006146}
6147
6148
6149#pragma mark Typedefs
6150
Greg Clayton1be10fc2010-09-29 01:12:09 +00006151clang_type_t
6152ClangASTContext::CreateTypedefType (const char *name, clang_type_t clang_type, DeclContext *decl_ctx)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006153{
6154 if (clang_type)
6155 {
6156 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
Greg Clayton6beaaa62011-01-17 03:46:26 +00006157 ASTContext *ast = getASTContext();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006158 IdentifierTable *identifier_table = getIdentifierTable();
Greg Clayton6beaaa62011-01-17 03:46:26 +00006159 assert (ast != NULL);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006160 assert (identifier_table != NULL);
6161 if (decl_ctx == NULL)
Greg Clayton6beaaa62011-01-17 03:46:26 +00006162 decl_ctx = ast->getTranslationUnitDecl();
6163 TypedefDecl *decl = TypedefDecl::Create (*ast,
6164 decl_ctx,
6165 SourceLocation(),
Sean Callananfb0b7582011-03-15 00:17:19 +00006166 SourceLocation(),
Greg Clayton6beaaa62011-01-17 03:46:26 +00006167 name ? &identifier_table->get(name) : NULL, // Identifier
6168 ast->CreateTypeSourceInfo(qual_type));
Sean Callanan2652ad22011-01-18 01:03:44 +00006169
Greg Clayton147e1fa2011-10-14 22:47:18 +00006170 //decl_ctx->addDecl (decl);
6171
Sean Callanan2652ad22011-01-18 01:03:44 +00006172 decl->setAccess(AS_public); // TODO respect proper access specifier
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006173
6174 // Get a uniqued QualType for the typedef decl type
Greg Clayton6beaaa62011-01-17 03:46:26 +00006175 return ast->getTypedefType (decl).getAsOpaquePtr();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006176 }
6177 return NULL;
6178}
6179
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006180// Disable this for now since I can't seem to get a nicely formatted float
6181// out of the APFloat class without just getting the float, double or quad
6182// and then using a formatted print on it which defeats the purpose. We ideally
6183// would like to get perfect string values for any kind of float semantics
6184// so we can support remote targets. The code below also requires a patch to
6185// llvm::APInt.
6186//bool
Greg Clayton6beaaa62011-01-17 03:46:26 +00006187//ClangASTContext::ConvertFloatValueToString (ASTContext *ast, clang_type_t clang_type, const uint8_t* bytes, size_t byte_size, int apint_byte_order, std::string &float_str)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006188//{
6189// uint32_t count = 0;
6190// bool is_complex = false;
6191// if (ClangASTContext::IsFloatingPointType (clang_type, count, is_complex))
6192// {
6193// unsigned num_bytes_per_float = byte_size / count;
6194// unsigned num_bits_per_float = num_bytes_per_float * 8;
6195//
6196// float_str.clear();
6197// uint32_t i;
6198// for (i=0; i<count; i++)
6199// {
6200// APInt ap_int(num_bits_per_float, bytes + i * num_bytes_per_float, (APInt::ByteOrder)apint_byte_order);
6201// bool is_ieee = false;
6202// APFloat ap_float(ap_int, is_ieee);
6203// char s[1024];
6204// unsigned int hex_digits = 0;
6205// bool upper_case = false;
6206//
6207// if (ap_float.convertToHexString(s, hex_digits, upper_case, APFloat::rmNearestTiesToEven) > 0)
6208// {
6209// if (i > 0)
6210// float_str.append(", ");
6211// float_str.append(s);
6212// if (i == 1 && is_complex)
6213// float_str.append(1, 'i');
6214// }
6215// }
6216// return !float_str.empty();
6217// }
6218// return false;
6219//}
6220
6221size_t
Greg Clayton6beaaa62011-01-17 03:46:26 +00006222ClangASTContext::ConvertStringToFloatValue (ASTContext *ast, clang_type_t clang_type, const char *s, uint8_t *dst, size_t dst_size)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006223{
6224 if (clang_type)
6225 {
6226 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
6227 uint32_t count = 0;
6228 bool is_complex = false;
6229 if (ClangASTContext::IsFloatingPointType (clang_type, count, is_complex))
6230 {
6231 // TODO: handle complex and vector types
6232 if (count != 1)
6233 return false;
6234
6235 StringRef s_sref(s);
Greg Clayton6beaaa62011-01-17 03:46:26 +00006236 APFloat ap_float(ast->getFloatTypeSemantics(qual_type), s_sref);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006237
Greg Clayton6beaaa62011-01-17 03:46:26 +00006238 const uint64_t bit_size = ast->getTypeSize (qual_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00006239 const uint64_t byte_size = bit_size / 8;
6240 if (dst_size >= byte_size)
6241 {
6242 if (bit_size == sizeof(float)*8)
6243 {
6244 float float32 = ap_float.convertToFloat();
6245 ::memcpy (dst, &float32, byte_size);
6246 return byte_size;
6247 }
6248 else if (bit_size >= 64)
6249 {
6250 llvm::APInt ap_int(ap_float.bitcastToAPInt());
6251 ::memcpy (dst, ap_int.getRawData(), byte_size);
6252 return byte_size;
6253 }
6254 }
6255 }
6256 }
6257 return 0;
6258}
Sean Callanan6fe64b52010-09-17 02:24:29 +00006259
6260unsigned
Greg Clayton1be10fc2010-09-29 01:12:09 +00006261ClangASTContext::GetTypeQualifiers(clang_type_t clang_type)
Sean Callanan6fe64b52010-09-17 02:24:29 +00006262{
6263 assert (clang_type);
6264
6265 QualType qual_type (QualType::getFromOpaquePtr(clang_type));
6266
6267 return qual_type.getQualifiers().getCVRQualifiers();
6268}
Greg Clayton6beaaa62011-01-17 03:46:26 +00006269
6270bool
6271ClangASTContext::GetCompleteType (clang::ASTContext *ast, lldb::clang_type_t clang_type)
6272{
6273 if (clang_type == NULL)
6274 return false;
6275
Greg Claytonc432c192011-01-20 04:18:48 +00006276 return GetCompleteQualType (ast, clang::QualType::getFromOpaquePtr(clang_type));
Greg Clayton6beaaa62011-01-17 03:46:26 +00006277}
6278
6279
6280bool
6281ClangASTContext::GetCompleteType (clang_type_t clang_type)
6282{
6283 return ClangASTContext::GetCompleteType (getASTContext(), clang_type);
6284}
6285
Greg Claytona2721472011-06-25 00:44:06 +00006286bool
Enrico Granata86027e92012-03-24 01:11:14 +00006287ClangASTContext::IsCompleteType (clang::ASTContext *ast, lldb::clang_type_t clang_type)
6288{
6289 if (clang_type == NULL)
6290 return false;
6291
6292 return GetCompleteQualType (ast, clang::QualType::getFromOpaquePtr(clang_type), false); // just check but don't let it actually complete
6293}
6294
6295
6296bool
6297ClangASTContext::IsCompleteType (clang_type_t clang_type)
6298{
6299 return ClangASTContext::IsCompleteType (getASTContext(), clang_type);
6300}
6301
6302bool
Greg Claytona2721472011-06-25 00:44:06 +00006303ClangASTContext::GetCompleteDecl (clang::ASTContext *ast,
6304 clang::Decl *decl)
6305{
6306 if (!decl)
6307 return false;
6308
6309 ExternalASTSource *ast_source = ast->getExternalSource();
6310
6311 if (!ast_source)
6312 return false;
6313
6314 if (clang::TagDecl *tag_decl = llvm::dyn_cast<clang::TagDecl>(decl))
6315 {
Greg Clayton219cf312012-03-30 00:51:13 +00006316 if (tag_decl->isCompleteDefinition())
Greg Claytona2721472011-06-25 00:44:06 +00006317 return true;
6318
6319 if (!tag_decl->hasExternalLexicalStorage())
6320 return false;
6321
6322 ast_source->CompleteType(tag_decl);
6323
6324 return !tag_decl->getTypeForDecl()->isIncompleteType();
6325 }
6326 else if (clang::ObjCInterfaceDecl *objc_interface_decl = llvm::dyn_cast<clang::ObjCInterfaceDecl>(decl))
6327 {
Sean Callanan5b26f272012-02-04 08:49:35 +00006328 if (objc_interface_decl->getDefinition())
Greg Claytona2721472011-06-25 00:44:06 +00006329 return true;
6330
6331 if (!objc_interface_decl->hasExternalLexicalStorage())
6332 return false;
6333
6334 ast_source->CompleteType(objc_interface_decl);
6335
Sean Callanan5b26f272012-02-04 08:49:35 +00006336 return !objc_interface_decl->getTypeForDecl()->isIncompleteType();
Greg Claytona2721472011-06-25 00:44:06 +00006337 }
6338 else
6339 {
6340 return false;
6341 }
6342}
6343
Sean Callanan60217122012-04-13 00:10:03 +00006344void
6345ClangASTContext::SetMetadata (clang::ASTContext *ast,
6346 uintptr_t object,
6347 uint64_t metadata)
6348{
6349 ClangExternalASTSourceCommon *external_source =
6350 static_cast<ClangExternalASTSourceCommon*>(ast->getExternalSource());
6351
6352 if (external_source)
6353 external_source->SetMetadata(object, metadata);
6354}
6355
6356uint64_t
6357ClangASTContext::GetMetadata (clang::ASTContext *ast,
6358 uintptr_t object)
6359{
6360 ClangExternalASTSourceCommon *external_source =
6361 static_cast<ClangExternalASTSourceCommon*>(ast->getExternalSource());
6362
6363 if (external_source && external_source->HasMetadata(object))
6364 return external_source->GetMetadata(object);
6365 else
6366 return 0;
6367}
6368
Greg Clayton2c5f0e92011-08-04 21:02:57 +00006369clang::DeclContext *
6370ClangASTContext::GetAsDeclContext (clang::CXXMethodDecl *cxx_method_decl)
6371{
Sean Callanana87bee82011-08-19 06:19:25 +00006372 return llvm::dyn_cast<clang::DeclContext>(cxx_method_decl);
Greg Clayton2c5f0e92011-08-04 21:02:57 +00006373}
6374
6375clang::DeclContext *
6376ClangASTContext::GetAsDeclContext (clang::ObjCMethodDecl *objc_method_decl)
6377{
Sean Callanana87bee82011-08-19 06:19:25 +00006378 return llvm::dyn_cast<clang::DeclContext>(objc_method_decl);
Greg Clayton2c5f0e92011-08-04 21:02:57 +00006379}
6380
Greg Clayton685c88c2012-07-14 00:53:55 +00006381
6382bool
6383ClangASTContext::GetClassMethodInfoForDeclContext (clang::DeclContext *decl_ctx,
6384 lldb::LanguageType &language,
6385 bool &is_instance_method,
6386 ConstString &language_object_name)
6387{
6388 language_object_name.Clear();
6389 language = eLanguageTypeUnknown;
6390 is_instance_method = false;
6391
6392 if (decl_ctx)
6393 {
6394 if (clang::CXXMethodDecl *method_decl = llvm::dyn_cast<clang::CXXMethodDecl>(decl_ctx))
6395 {
6396 if (method_decl->isStatic())
6397 {
6398 is_instance_method = false;
6399 }
6400 else
6401 {
6402 language_object_name.SetCString("this");
6403 is_instance_method = true;
6404 }
6405 language = eLanguageTypeC_plus_plus;
6406 return true;
6407 }
6408 else if (clang::ObjCMethodDecl *method_decl = llvm::dyn_cast<clang::ObjCMethodDecl>(decl_ctx))
6409 {
6410 // Both static and instance methods have a "self" object in objective C
6411 language_object_name.SetCString("self");
6412 if (method_decl->isInstanceMethod())
6413 {
6414 is_instance_method = true;
6415 }
6416 else
6417 {
6418 is_instance_method = false;
6419 }
6420 language = eLanguageTypeObjC;
6421 return true;
6422 }
6423 }
6424 return false;
6425}
6426