1 //===-- lldb-enumerations.h -------------------------------------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 #ifndef LLDB_lldb_enumerations_h_
11 #define LLDB_lldb_enumerations_h_
12 
13 namespace lldb {
14 
15     //----------------------------------------------------------------------
16     // Process and Thread States
17     //----------------------------------------------------------------------
18     typedef enum StateType
19     {
20         eStateInvalid = 0,
21         eStateUnloaded,     ///< Process is object is valid, but not currently loaded
22         eStateConnected,    ///< Process is connected to remote debug services, but not launched or attached to anything yet
23         eStateAttaching,    ///< Process is currently trying to attach
24         eStateLaunching,    ///< Process is in the process of launching
25         eStateStopped,      ///< Process or thread is stopped and can be examined.
26         eStateRunning,      ///< Process or thread is running and can't be examined.
27         eStateStepping,     ///< Process or thread is in the process of stepping and can not be examined.
28         eStateCrashed,      ///< Process or thread has crashed and can be examined.
29         eStateDetached,     ///< Process has been detached and can't be examined.
30         eStateExited,       ///< Process has exited and can't be examined.
31         eStateSuspended     ///< Process or thread is in a suspended state as far
32                             ///< as the debugger is concerned while other processes
33                             ///< or threads get the chance to run.
34     } StateType;
35 
36     //----------------------------------------------------------------------
37     // Launch Flags
38     //----------------------------------------------------------------------
39     typedef enum LaunchFlags
40     {
41         eLaunchFlagNone         = 0u,
42         eLaunchFlagExec         = (1u << 0),  ///< Exec when launching and turn the calling process into a new process
43         eLaunchFlagDebug        = (1u << 1),  ///< Stop as soon as the process launches to allow the process to be debugged
44         eLaunchFlagStopAtEntry  = (1u << 2),  ///< Stop at the program entry point instead of auto-continuing when launching or attaching at entry point
45         eLaunchFlagDisableASLR  = (1u << 3),  ///< Disable Address Space Layout Randomization
46         eLaunchFlagDisableSTDIO = (1u << 4),  ///< Disable stdio for inferior process (e.g. for a GUI app)
47         eLaunchFlagLaunchInTTY  = (1u << 5),  ///< Launch the process in a new TTY if supported by the host
48         eLaunchFlagLaunchInShell= (1u << 6),   ///< Launch the process inside a shell to get shell expansion
49         eLaunchFlagLaunchInSeparateProcessGroup = (1u << 7) ///< Launch the process in a separate process group
50     } LaunchFlags;
51 
52     //----------------------------------------------------------------------
53     // Thread Run Modes
54     //----------------------------------------------------------------------
55     typedef enum RunMode {
56         eOnlyThisThread,
57         eAllThreads,
58         eOnlyDuringStepping
59     } RunMode;
60 
61     //----------------------------------------------------------------------
62     // Byte ordering definitions
63     //----------------------------------------------------------------------
64     typedef enum ByteOrder
65     {
66         eByteOrderInvalid   = 0,
67         eByteOrderBig       = 1,
68         eByteOrderPDP       = 2,
69         eByteOrderLittle    = 4
70     } ByteOrder;
71 
72     //----------------------------------------------------------------------
73     // Register encoding definitions
74     //----------------------------------------------------------------------
75     typedef enum Encoding
76     {
77         eEncodingInvalid = 0,
78         eEncodingUint,               // unsigned integer
79         eEncodingSint,               // signed integer
80         eEncodingIEEE754,            // float
81         eEncodingVector              // vector registers
82     } Encoding;
83 
84     //----------------------------------------------------------------------
85     // Display format definitions
86     //----------------------------------------------------------------------
87     typedef enum Format
88     {
89         eFormatDefault = 0,
90         eFormatInvalid = 0,
91         eFormatBoolean,
92         eFormatBinary,
93         eFormatBytes,
94         eFormatBytesWithASCII,
95         eFormatChar,
96         eFormatCharPrintable,   // Only printable characters, space if not printable
97         eFormatComplex,         // Floating point complex type
98         eFormatComplexFloat = eFormatComplex,
99         eFormatCString,         // NULL terminated C strings
100         eFormatDecimal,
101         eFormatEnum,
102         eFormatHex,
103         eFormatHexUppercase,
104         eFormatFloat,
105         eFormatOctal,
106         eFormatOSType,          // OS character codes encoded into an integer 'PICT' 'text' etc...
107         eFormatUnicode16,
108         eFormatUnicode32,
109         eFormatUnsigned,
110         eFormatPointer,
111         eFormatVectorOfChar,
112         eFormatVectorOfSInt8,
113         eFormatVectorOfUInt8,
114         eFormatVectorOfSInt16,
115         eFormatVectorOfUInt16,
116         eFormatVectorOfSInt32,
117         eFormatVectorOfUInt32,
118         eFormatVectorOfSInt64,
119         eFormatVectorOfUInt64,
120         eFormatVectorOfFloat32,
121         eFormatVectorOfFloat64,
122         eFormatVectorOfUInt128,
123         eFormatComplexInteger,      // Integer complex type
124         eFormatCharArray,           // Print characters with no single quotes, used for character arrays that can contain non printable characters
125         eFormatAddressInfo,         // Describe what an address points to (func + offset with file/line, symbol + offset, data, etc)
126         eFormatHexFloat,            // ISO C99 hex float string
127         eFormatInstruction,         // Disassemble an opcode
128         eFormatVoid,                // Do not print this
129         kNumFormats
130     } Format;
131 
132     //----------------------------------------------------------------------
133     // Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls
134     //----------------------------------------------------------------------
135     typedef enum DescriptionLevel
136     {
137         eDescriptionLevelBrief = 0,
138         eDescriptionLevelFull,
139         eDescriptionLevelVerbose,
140         eDescriptionLevelInitial,
141         kNumDescriptionLevels
142     } DescriptionLevel;
143 
144     //----------------------------------------------------------------------
145     // Script interpreter types
146     //----------------------------------------------------------------------
147     typedef enum ScriptLanguage
148     {
149         eScriptLanguageNone,
150         eScriptLanguagePython,
151         eScriptLanguageDefault = eScriptLanguagePython
152     } ScriptLanguage;
153 
154     //----------------------------------------------------------------------
155     // Register numbering types
156     //----------------------------------------------------------------------
157     typedef enum RegisterKind
158     {
159         eRegisterKindGCC = 0,    // the register numbers seen in eh_frame
160         eRegisterKindDWARF,      // the register numbers seen DWARF
161         eRegisterKindGeneric,    // insn ptr reg, stack ptr reg, etc not specific to any particular target
162         eRegisterKindGDB,        // the register numbers gdb uses (matches stabs numbers?)
163         eRegisterKindLLDB,       // lldb's internal register numbers
164         kNumRegisterKinds
165     } RegisterKind;
166 
167     //----------------------------------------------------------------------
168     // Thread stop reasons
169     //----------------------------------------------------------------------
170     typedef enum StopReason
171     {
172         eStopReasonInvalid = 0,
173         eStopReasonNone,
174         eStopReasonTrace,
175         eStopReasonBreakpoint,
176         eStopReasonWatchpoint,
177         eStopReasonSignal,
178         eStopReasonException,
179         eStopReasonExec,        // Program was re-exec'ed
180         eStopReasonPlanComplete,
181         eStopReasonThreadExiting
182     } StopReason;
183 
184     //----------------------------------------------------------------------
185     // Command Return Status Types
186     //----------------------------------------------------------------------
187     typedef enum ReturnStatus
188     {
189         eReturnStatusInvalid,
190         eReturnStatusSuccessFinishNoResult,
191         eReturnStatusSuccessFinishResult,
192         eReturnStatusSuccessContinuingNoResult,
193         eReturnStatusSuccessContinuingResult,
194         eReturnStatusStarted,
195         eReturnStatusFailed,
196         eReturnStatusQuit
197     } ReturnStatus;
198 
199 
200     //----------------------------------------------------------------------
201     // Connection Status Types
202     //----------------------------------------------------------------------
203     typedef enum ConnectionStatus
204     {
205         eConnectionStatusSuccess,         // Success
206         eConnectionStatusEndOfFile,       // End-of-file encountered
207         eConnectionStatusError,           // Check GetError() for details
208         eConnectionStatusTimedOut,        // Request timed out
209         eConnectionStatusNoConnection,    // No connection
210         eConnectionStatusLostConnection   // Lost connection while connected to a valid connection
211     } ConnectionStatus;
212 
213     typedef enum ErrorType
214     {
215         eErrorTypeInvalid,
216         eErrorTypeGeneric,      ///< Generic errors that can be any value.
217         eErrorTypeMachKernel,   ///< Mach kernel error codes.
218         eErrorTypePOSIX         ///< POSIX error codes.
219     } ErrorType;
220 
221 
222     typedef enum ValueType
223     {
224         eValueTypeInvalid           = 0,
225         eValueTypeVariableGlobal    = 1,    // globals variable
226         eValueTypeVariableStatic    = 2,    // static variable
227         eValueTypeVariableArgument  = 3,    // function argument variables
228         eValueTypeVariableLocal     = 4,    // function local variables
229         eValueTypeRegister          = 5,    // stack frame register value
230         eValueTypeRegisterSet       = 6,    // A collection of stack frame register values
231         eValueTypeConstResult       = 7     // constant result variables
232     } ValueType;
233 
234     //----------------------------------------------------------------------
235     // Token size/granularities for Input Readers
236     //----------------------------------------------------------------------
237 
238     typedef enum InputReaderGranularity
239     {
240         eInputReaderGranularityInvalid = 0,
241         eInputReaderGranularityByte,
242         eInputReaderGranularityWord,
243         eInputReaderGranularityLine,
244         eInputReaderGranularityAll
245     } InputReaderGranularity;
246 
247     //------------------------------------------------------------------
248     /// These mask bits allow a common interface for queries that can
249     /// limit the amount of information that gets parsed to only the
250     /// information that is requested. These bits also can indicate what
251     /// actually did get resolved during query function calls.
252     ///
253     /// Each definition corresponds to a one of the member variables
254     /// in this class, and requests that that item be resolved, or
255     /// indicates that the member did get resolved.
256     //------------------------------------------------------------------
257     typedef enum SymbolContextItem
258     {
259         eSymbolContextTarget     = (1u << 0), ///< Set when \a target is requested from a query, or was located in query results
260         eSymbolContextModule     = (1u << 1), ///< Set when \a module is requested from a query, or was located in query results
261         eSymbolContextCompUnit   = (1u << 2), ///< Set when \a comp_unit is requested from a query, or was located in query results
262         eSymbolContextFunction   = (1u << 3), ///< Set when \a function is requested from a query, or was located in query results
263         eSymbolContextBlock      = (1u << 4), ///< Set when the deepest \a block is requested from a query, or was located in query results
264         eSymbolContextLineEntry  = (1u << 5), ///< Set when \a line_entry is requested from a query, or was located in query results
265         eSymbolContextSymbol     = (1u << 6), ///< Set when \a symbol is requested from a query, or was located in query results
266         eSymbolContextEverything = ((eSymbolContextSymbol << 1) - 1u)  ///< Indicates to try and lookup everything up during a query.
267     } SymbolContextItem;
268 
269     typedef enum Permissions
270     {
271         ePermissionsWritable    = (1u << 0),
272         ePermissionsReadable    = (1u << 1),
273         ePermissionsExecutable  = (1u << 2)
274     } Permissions;
275 
276     typedef enum InputReaderAction
277     {
278         eInputReaderActivate,   // reader is newly pushed onto the reader stack
279         eInputReaderAsynchronousOutputWritten, // an async output event occurred; the reader may want to do something
280         eInputReaderReactivate, // reader is on top of the stack again after another reader was popped off
281         eInputReaderDeactivate, // another reader was pushed on the stack
282         eInputReaderGotToken,   // reader got one of its tokens (granularity)
283         eInputReaderInterrupt,  // reader received an interrupt signal (probably from a control-c)
284         eInputReaderEndOfFile,  // reader received an EOF char (probably from a control-d)
285         eInputReaderDone        // reader was just popped off the stack and is done
286     } InputReaderAction;
287 
288     typedef enum BreakpointEventType
289     {
290         eBreakpointEventTypeInvalidType         = (1u << 0),
291         eBreakpointEventTypeAdded               = (1u << 1),
292         eBreakpointEventTypeRemoved             = (1u << 2),
293         eBreakpointEventTypeLocationsAdded      = (1u << 3),  // Locations added doesn't get sent when the breakpoint is created
294         eBreakpointEventTypeLocationsRemoved    = (1u << 4),
295         eBreakpointEventTypeLocationsResolved   = (1u << 5),
296         eBreakpointEventTypeEnabled             = (1u << 6),
297         eBreakpointEventTypeDisabled            = (1u << 7),
298         eBreakpointEventTypeCommandChanged      = (1u << 8),
299         eBreakpointEventTypeConditionChanged    = (1u << 9),
300         eBreakpointEventTypeIgnoreChanged       = (1u << 10),
301         eBreakpointEventTypeThreadChanged       = (1u << 11)
302     } BreakpointEventType;
303 
304     typedef enum WatchpointEventType
305     {
306         eWatchpointEventTypeInvalidType         = (1u << 0),
307         eWatchpointEventTypeAdded               = (1u << 1),
308         eWatchpointEventTypeRemoved             = (1u << 2),
309         eWatchpointEventTypeEnabled             = (1u << 6),
310         eWatchpointEventTypeDisabled            = (1u << 7),
311         eWatchpointEventTypeCommandChanged      = (1u << 8),
312         eWatchpointEventTypeConditionChanged    = (1u << 9),
313         eWatchpointEventTypeIgnoreChanged       = (1u << 10),
314         eWatchpointEventTypeThreadChanged       = (1u << 11),
315         eWatchpointEventTypeTypeChanged         = (1u << 12)
316     } WatchpointEventType;
317 
318 
319     //----------------------------------------------------------------------
320     /// Programming language type.
321     ///
322     /// These enumerations use the same language enumerations as the DWARF
323     /// specification for ease of use and consistency.
324     /// The enum -> string code is in LanguageRuntime.cpp, don't change this
325     /// table without updating that code as well.
326     //----------------------------------------------------------------------
327     typedef enum LanguageType
328     {
329         eLanguageTypeUnknown         = 0x0000,   ///< Unknown or invalid language value.
330         eLanguageTypeC89             = 0x0001,   ///< ISO C:1989.
331         eLanguageTypeC               = 0x0002,   ///< Non-standardized C, such as K&R.
332         eLanguageTypeAda83           = 0x0003,   ///< ISO Ada:1983.
333         eLanguageTypeC_plus_plus     = 0x0004,   ///< ISO C++:1998.
334         eLanguageTypeCobol74         = 0x0005,   ///< ISO Cobol:1974.
335         eLanguageTypeCobol85         = 0x0006,   ///< ISO Cobol:1985.
336         eLanguageTypeFortran77       = 0x0007,   ///< ISO Fortran 77.
337         eLanguageTypeFortran90       = 0x0008,   ///< ISO Fortran 90.
338         eLanguageTypePascal83        = 0x0009,   ///< ISO Pascal:1983.
339         eLanguageTypeModula2         = 0x000a,   ///< ISO Modula-2:1996.
340         eLanguageTypeJava            = 0x000b,   ///< Java.
341         eLanguageTypeC99             = 0x000c,   ///< ISO C:1999.
342         eLanguageTypeAda95           = 0x000d,   ///< ISO Ada:1995.
343         eLanguageTypeFortran95       = 0x000e,   ///< ISO Fortran 95.
344         eLanguageTypePLI             = 0x000f,   ///< ANSI PL/I:1976.
345         eLanguageTypeObjC            = 0x0010,   ///< Objective-C.
346         eLanguageTypeObjC_plus_plus  = 0x0011,   ///< Objective-C++.
347         eLanguageTypeUPC             = 0x0012,   ///< Unified Parallel C.
348         eLanguageTypeD               = 0x0013,   ///< D.
349         eLanguageTypePython          = 0x0014,   ///< Python.
350         eNumLanguageTypes
351     } LanguageType;
352 
353     typedef enum DynamicValueType
354     {
355         eNoDynamicValues = 0,
356         eDynamicCanRunTarget    = 1,
357         eDynamicDontRunTarget   = 2
358     } DynamicValueType;
359 
360     typedef enum AccessType
361     {
362         eAccessNone,
363         eAccessPublic,
364         eAccessPrivate,
365         eAccessProtected,
366         eAccessPackage
367     } AccessType;
368 
369     typedef enum CommandArgumentType
370     {
371         eArgTypeAddress = 0,
372         eArgTypeAddressOrExpression,
373         eArgTypeAliasName,
374         eArgTypeAliasOptions,
375         eArgTypeArchitecture,
376         eArgTypeBoolean,
377         eArgTypeBreakpointID,
378         eArgTypeBreakpointIDRange,
379         eArgTypeByteSize,
380         eArgTypeClassName,
381         eArgTypeCommandName,
382         eArgTypeCount,
383         eArgTypeDirectoryName,
384         eArgTypeDisassemblyFlavor,
385         eArgTypeEndAddress,
386         eArgTypeExpression,
387         eArgTypeExpressionPath,
388         eArgTypeExprFormat,
389         eArgTypeFilename,
390         eArgTypeFormat,
391         eArgTypeFrameIndex,
392         eArgTypeFullName,
393         eArgTypeFunctionName,
394         eArgTypeFunctionOrSymbol,
395         eArgTypeGDBFormat,
396         eArgTypeIndex,
397         eArgTypeLanguage,
398         eArgTypeLineNum,
399         eArgTypeLogCategory,
400         eArgTypeLogChannel,
401         eArgTypeMethod,
402         eArgTypeName,
403         eArgTypeNewPathPrefix,
404         eArgTypeNumLines,
405         eArgTypeNumberPerLine,
406         eArgTypeOffset,
407         eArgTypeOldPathPrefix,
408         eArgTypeOneLiner,
409         eArgTypePid,
410         eArgTypePlugin,
411         eArgTypeProcessName,
412         eArgTypePythonClass,
413         eArgTypePythonFunction,
414         eArgTypePythonScript,
415         eArgTypeQueueName,
416         eArgTypeRegisterName,
417         eArgTypeRegularExpression,
418         eArgTypeRunArgs,
419         eArgTypeRunMode,
420         eArgTypeScriptedCommandSynchronicity,
421         eArgTypeScriptLang,
422         eArgTypeSearchWord,
423         eArgTypeSelector,
424         eArgTypeSettingIndex,
425         eArgTypeSettingKey,
426         eArgTypeSettingPrefix,
427         eArgTypeSettingVariableName,
428         eArgTypeShlibName,
429         eArgTypeSourceFile,
430         eArgTypeSortOrder,
431         eArgTypeStartAddress,
432         eArgTypeSummaryString,
433         eArgTypeSymbol,
434         eArgTypeThreadID,
435         eArgTypeThreadIndex,
436         eArgTypeThreadName,
437         eArgTypeUnsignedInteger,
438         eArgTypeUnixSignal,
439         eArgTypeVarName,
440         eArgTypeValue,
441         eArgTypeWidth,
442         eArgTypeNone,
443         eArgTypePlatform,
444         eArgTypeWatchpointID,
445         eArgTypeWatchpointIDRange,
446         eArgTypeWatchType,
447         eArgTypeLastArg  // Always keep this entry as the last entry in this enumeration!!
448     } CommandArgumentType;
449 
450     //----------------------------------------------------------------------
451     // Symbol types
452     //----------------------------------------------------------------------
453     typedef enum SymbolType
454     {
455         eSymbolTypeAny = 0,
456         eSymbolTypeInvalid = 0,
457         eSymbolTypeAbsolute,
458         eSymbolTypeCode,
459         eSymbolTypeResolver,
460         eSymbolTypeData,
461         eSymbolTypeTrampoline,
462         eSymbolTypeRuntime,
463         eSymbolTypeException,
464         eSymbolTypeSourceFile,
465         eSymbolTypeHeaderFile,
466         eSymbolTypeObjectFile,
467         eSymbolTypeCommonBlock,
468         eSymbolTypeBlock,
469         eSymbolTypeLocal,
470         eSymbolTypeParam,
471         eSymbolTypeVariable,
472         eSymbolTypeVariableType,
473         eSymbolTypeLineEntry,
474         eSymbolTypeLineHeader,
475         eSymbolTypeScopeBegin,
476         eSymbolTypeScopeEnd,
477         eSymbolTypeAdditional, // When symbols take more than one entry, the extra entries get this type
478         eSymbolTypeCompiler,
479         eSymbolTypeInstrumentation,
480         eSymbolTypeUndefined,
481         eSymbolTypeObjCClass,
482         eSymbolTypeObjCMetaClass,
483         eSymbolTypeObjCIVar
484     } SymbolType;
485 
486     typedef enum SectionType
487     {
488         eSectionTypeInvalid,
489         eSectionTypeCode,
490         eSectionTypeContainer,              // The section contains child sections
491         eSectionTypeData,
492         eSectionTypeDataCString,            // Inlined C string data
493         eSectionTypeDataCStringPointers,    // Pointers to C string data
494         eSectionTypeDataSymbolAddress,      // Address of a symbol in the symbol table
495         eSectionTypeData4,
496         eSectionTypeData8,
497         eSectionTypeData16,
498         eSectionTypeDataPointers,
499         eSectionTypeDebug,
500         eSectionTypeZeroFill,
501         eSectionTypeDataObjCMessageRefs,    // Pointer to function pointer + selector
502         eSectionTypeDataObjCCFStrings,      // Objective C const CFString/NSString objects
503         eSectionTypeDWARFDebugAbbrev,
504         eSectionTypeDWARFDebugAranges,
505         eSectionTypeDWARFDebugFrame,
506         eSectionTypeDWARFDebugInfo,
507         eSectionTypeDWARFDebugLine,
508         eSectionTypeDWARFDebugLoc,
509         eSectionTypeDWARFDebugMacInfo,
510         eSectionTypeDWARFDebugPubNames,
511         eSectionTypeDWARFDebugPubTypes,
512         eSectionTypeDWARFDebugRanges,
513         eSectionTypeDWARFDebugStr,
514         eSectionTypeDWARFAppleNames,
515         eSectionTypeDWARFAppleTypes,
516         eSectionTypeDWARFAppleNamespaces,
517         eSectionTypeDWARFAppleObjC,
518         eSectionTypeELFSymbolTable,       // Elf SHT_SYMTAB section
519         eSectionTypeELFDynamicSymbols,    // Elf SHT_DYNSYM section
520         eSectionTypeELFRelocationEntries, // Elf SHT_REL or SHT_REL section
521         eSectionTypeELFDynamicLinkInfo,   // Elf SHT_DYNAMIC section
522         eSectionTypeEHFrame,
523         eSectionTypeOther
524 
525     } SectionType;
526 
527     typedef enum EmulateInstructionOptions
528     {
529         eEmulateInstructionOptionNone               = (0u),
530         eEmulateInstructionOptionAutoAdvancePC      = (1u << 0),
531         eEmulateInstructionOptionIgnoreConditions   = (1u << 1)
532     } EmulateInstructionOptions;
533 
534     typedef enum FunctionNameType
535     {
536         eFunctionNameTypeNone       = 0u,
537         eFunctionNameTypeAuto       = (1u << 1),    // Automatically figure out which FunctionNameType
538                                                     // bits to set based on the function name.
539         eFunctionNameTypeFull       = (1u << 2),    // The function name.
540                                                     // For C this is the same as just the name of the function
541                                                     // For C++ this is the mangled or demangled version of the mangled name.
542                                                     // For ObjC this is the full function signature with the + or
543                                                     // - and the square brackets and the class and selector
544         eFunctionNameTypeBase       = (1u << 3),    // The function name only, no namespaces or arguments and no class
545                                                     // methods or selectors will be searched.
546         eFunctionNameTypeMethod     = (1u << 4),    // Find function by method name (C++) with no namespace or arguments
547         eFunctionNameTypeSelector   = (1u << 5),    // Find function by selector name (ObjC) names
548         eFunctionNameTypeAny        = eFunctionNameTypeAuto // DEPRECATED: use eFunctionNameTypeAuto
549     } FunctionNameType;
550 
551 
552     //----------------------------------------------------------------------
553     // Basic types enumeration for the public API SBType::GetBasicType()
554     //----------------------------------------------------------------------
555     typedef enum BasicType
556     {
557 		eBasicTypeInvalid = 0,
558         eBasicTypeVoid = 1,
559         eBasicTypeChar,
560         eBasicTypeSignedChar,
561         eBasicTypeUnsignedChar,
562         eBasicTypeWChar,
563         eBasicTypeSignedWChar,
564         eBasicTypeUnsignedWChar,
565         eBasicTypeChar16,
566         eBasicTypeChar32,
567         eBasicTypeShort,
568         eBasicTypeUnsignedShort,
569         eBasicTypeInt,
570         eBasicTypeUnsignedInt,
571         eBasicTypeLong,
572         eBasicTypeUnsignedLong,
573         eBasicTypeLongLong,
574         eBasicTypeUnsignedLongLong,
575         eBasicTypeInt128,
576         eBasicTypeUnsignedInt128,
577         eBasicTypeBool,
578         eBasicTypeHalf,
579         eBasicTypeFloat,
580         eBasicTypeDouble,
581         eBasicTypeLongDouble,
582         eBasicTypeFloatComplex,
583         eBasicTypeDoubleComplex,
584         eBasicTypeLongDoubleComplex,
585         eBasicTypeObjCID,
586         eBasicTypeObjCClass,
587         eBasicTypeObjCSel,
588         eBasicTypeNullPtr,
589         eBasicTypeOther
590     } BasicType;
591 
592     typedef enum TypeClass
593     {
594         eTypeClassInvalid           = (0u),
595         eTypeClassArray             = (1u << 0),
596         eTypeClassBlockPointer      = (1u << 1),
597         eTypeClassBuiltin           = (1u << 2),
598         eTypeClassClass             = (1u << 3),
599         eTypeClassComplexFloat      = (1u << 4),
600         eTypeClassComplexInteger    = (1u << 5),
601         eTypeClassEnumeration       = (1u << 6),
602         eTypeClassFunction          = (1u << 7),
603         eTypeClassMemberPointer     = (1u << 8),
604         eTypeClassObjCObject        = (1u << 9),
605         eTypeClassObjCInterface     = (1u << 10),
606         eTypeClassObjCObjectPointer = (1u << 11),
607         eTypeClassPointer           = (1u << 12),
608         eTypeClassReference         = (1u << 13),
609         eTypeClassStruct            = (1u << 14),
610         eTypeClassTypedef           = (1u << 15),
611         eTypeClassUnion             = (1u << 16),
612         eTypeClassVector            = (1u << 17),
613         // Define the last type class as the MSBit of a 32 bit value
614         eTypeClassOther             = (1u << 31),
615         // Define a mask that can be used for any type when finding types
616         eTypeClassAny               = (0xffffffffu)
617     } TypeClass;
618 
619     typedef enum TemplateArgumentKind
620     {
621         eTemplateArgumentKindNull = 0,
622         eTemplateArgumentKindType,
623         eTemplateArgumentKindDeclaration,
624         eTemplateArgumentKindIntegral,
625         eTemplateArgumentKindTemplate,
626         eTemplateArgumentKindTemplateExpansion,
627         eTemplateArgumentKindExpression,
628         eTemplateArgumentKindPack
629 
630     } TemplateArgumentKind;
631 
632     //----------------------------------------------------------------------
633     // Options that can be set for a formatter to alter its behavior
634     // Not all of these are applicable to all formatter types
635     //----------------------------------------------------------------------
636     typedef enum TypeOptions
637     {
638         eTypeOptionNone            = (0u),
639         eTypeOptionCascade         = (1u << 0),
640         eTypeOptionSkipPointers    = (1u << 1),
641         eTypeOptionSkipReferences  = (1u << 2),
642         eTypeOptionHideChildren    = (1u << 3),
643         eTypeOptionHideValue       = (1u << 4),
644         eTypeOptionShowOneLiner    = (1u << 5),
645         eTypeOptionHideNames       = (1u << 6)
646     } TypeOptions;
647 
648    //----------------------------------------------------------------------
649    // This is the return value for frame comparisons.  When frame A pushes
650    // frame B onto the stack, frame A is OLDER than frame B.
651    //----------------------------------------------------------------------
652    typedef enum FrameComparison
653    {
654        eFrameCompareInvalid,
655        eFrameCompareUnknown,
656        eFrameCompareEqual,
657        eFrameCompareYounger,
658        eFrameCompareOlder
659    } FrameComparison;
660 
661     //----------------------------------------------------------------------
662     // Address Class
663     //
664     // A way of classifying an address used for disassembling and setting
665     // breakpoints. Many object files can track exactly what parts of their
666     // object files are code, data and other information. This is of course
667     // above and beyond just looking at the section types. For example, code
668     // might contain PC relative data and the object file might be able to
669     // tell us that an address in code is data.
670     //----------------------------------------------------------------------
671     typedef enum AddressClass
672     {
673         eAddressClassInvalid,
674         eAddressClassUnknown,
675         eAddressClassCode,
676         eAddressClassCodeAlternateISA,
677         eAddressClassData,
678         eAddressClassDebug,
679         eAddressClassRuntime
680     } AddressClass;
681 
682 } // namespace lldb
683 
684 
685 #endif  // LLDB_lldb_enumerations_h_
686