2011-06-24 01:59:56 +08:00
|
|
|
//===-- FormatManager.cpp -------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/Core/FormatManager.h"
|
|
|
|
|
|
|
|
// C Includes
|
|
|
|
// C++ Includes
|
|
|
|
// Other libraries and framework includes
|
|
|
|
// Project includes
|
|
|
|
|
2011-07-15 10:26:42 +08:00
|
|
|
#include "lldb/Core/Debugger.h"
|
|
|
|
|
2011-06-24 01:59:56 +08:00
|
|
|
using namespace lldb;
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
2011-06-24 05:22:24 +08:00
|
|
|
|
|
|
|
struct FormatInfo
|
|
|
|
{
|
|
|
|
Format format;
|
|
|
|
const char format_char; // One or more format characters that can be used for this format.
|
|
|
|
const char *format_name; // Long format name that can be used to specify the current format
|
|
|
|
};
|
|
|
|
|
|
|
|
static FormatInfo
|
|
|
|
g_format_infos[] =
|
|
|
|
{
|
|
|
|
{ eFormatDefault , '\0' , "default" },
|
|
|
|
{ eFormatBoolean , 'B' , "boolean" },
|
|
|
|
{ eFormatBinary , 'b' , "binary" },
|
|
|
|
{ eFormatBytes , 'y' , "bytes" },
|
|
|
|
{ eFormatBytesWithASCII , 'Y' , "bytes with ASCII" },
|
|
|
|
{ eFormatChar , 'c' , "character" },
|
|
|
|
{ eFormatCharPrintable , 'C' , "printable character" },
|
|
|
|
{ eFormatComplexFloat , 'F' , "complex float" },
|
|
|
|
{ eFormatCString , 's' , "c-string" },
|
Added support for the new ".apple_objc" accelerator tables. These tables are
in the same hashed format as the ".apple_names", but they map objective C
class names to all of the methods and class functions. We need to do this
because in the DWARF the methods for Objective C are never contained in the
class definition, they are scattered about at the translation unit level and
they don't even have attributes that say the are contained within the class
itself.
Added 3 new formats which can be used to display data:
eFormatAddressInfo
eFormatHexFloat
eFormatInstruction
eFormatAddressInfo describes an address such as function+offset and file+line,
or symbol + offset, or constant data (c string, 2, 4, 8, or 16 byte constants).
The format character for this is "A", the long format is "address".
eFormatHexFloat will print out the hex float format that compilers tend to use.
The format character for this is "X", the long format is "hex float".
eFormatInstruction will print out disassembly with bytes and it will use the
current target's architecture. The format character for this is "i" (which
used to be being used for the integer format, but the integer format also has
"d", so we gave the "i" format to disassembly), the long format is
"instruction".
Mate the lldb::FormatterChoiceCriterion enumeration private as it should have
been from the start. It is very specialized and doesn't belong in the public
API.
llvm-svn: 143114
2011-10-28 01:55:14 +08:00
|
|
|
{ eFormatDecimal , 'd' , "decimal" },
|
2011-06-24 05:22:24 +08:00
|
|
|
{ eFormatEnum , 'E' , "enumeration" },
|
|
|
|
{ eFormatHex , 'x' , "hex" },
|
2012-08-10 03:33:34 +08:00
|
|
|
{ eFormatHexUppercase , 'X' , "uppercase hex" },
|
2011-06-24 05:22:24 +08:00
|
|
|
{ eFormatFloat , 'f' , "float" },
|
|
|
|
{ eFormatOctal , 'o' , "octal" },
|
|
|
|
{ eFormatOSType , 'O' , "OSType" },
|
|
|
|
{ eFormatUnicode16 , 'U' , "unicode16" },
|
|
|
|
{ eFormatUnicode32 , '\0' , "unicode32" },
|
|
|
|
{ eFormatUnsigned , 'u' , "unsigned decimal" },
|
|
|
|
{ eFormatPointer , 'p' , "pointer" },
|
|
|
|
{ eFormatVectorOfChar , '\0' , "char[]" },
|
|
|
|
{ eFormatVectorOfSInt8 , '\0' , "int8_t[]" },
|
|
|
|
{ eFormatVectorOfUInt8 , '\0' , "uint8_t[]" },
|
|
|
|
{ eFormatVectorOfSInt16 , '\0' , "int16_t[]" },
|
|
|
|
{ eFormatVectorOfUInt16 , '\0' , "uint16_t[]" },
|
2011-07-06 23:56:06 +08:00
|
|
|
{ eFormatVectorOfSInt32 , '\0' , "int32_t[]" },
|
|
|
|
{ eFormatVectorOfUInt32 , '\0' , "uint32_t[]" },
|
|
|
|
{ eFormatVectorOfSInt64 , '\0' , "int64_t[]" },
|
|
|
|
{ eFormatVectorOfUInt64 , '\0' , "uint64_t[]" },
|
2011-06-24 05:22:24 +08:00
|
|
|
{ eFormatVectorOfFloat32, '\0' , "float32[]" },
|
|
|
|
{ eFormatVectorOfFloat64, '\0' , "float64[]" },
|
|
|
|
{ eFormatVectorOfUInt128, '\0' , "uint128_t[]" },
|
|
|
|
{ eFormatComplexInteger , 'I' , "complex integer" },
|
Added support for the new ".apple_objc" accelerator tables. These tables are
in the same hashed format as the ".apple_names", but they map objective C
class names to all of the methods and class functions. We need to do this
because in the DWARF the methods for Objective C are never contained in the
class definition, they are scattered about at the translation unit level and
they don't even have attributes that say the are contained within the class
itself.
Added 3 new formats which can be used to display data:
eFormatAddressInfo
eFormatHexFloat
eFormatInstruction
eFormatAddressInfo describes an address such as function+offset and file+line,
or symbol + offset, or constant data (c string, 2, 4, 8, or 16 byte constants).
The format character for this is "A", the long format is "address".
eFormatHexFloat will print out the hex float format that compilers tend to use.
The format character for this is "X", the long format is "hex float".
eFormatInstruction will print out disassembly with bytes and it will use the
current target's architecture. The format character for this is "i" (which
used to be being used for the integer format, but the integer format also has
"d", so we gave the "i" format to disassembly), the long format is
"instruction".
Mate the lldb::FormatterChoiceCriterion enumeration private as it should have
been from the start. It is very specialized and doesn't belong in the public
API.
llvm-svn: 143114
2011-10-28 01:55:14 +08:00
|
|
|
{ eFormatCharArray , 'a' , "character array" },
|
|
|
|
{ eFormatAddressInfo , 'A' , "address" },
|
2012-08-10 03:33:34 +08:00
|
|
|
{ eFormatHexFloat , '\0' , "hex float" },
|
2012-08-09 01:35:10 +08:00
|
|
|
{ eFormatInstruction , 'i' , "instruction" },
|
|
|
|
{ eFormatVoid , 'v' , "void" }
|
2011-06-24 05:22:24 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static uint32_t
|
|
|
|
g_num_format_infos = sizeof(g_format_infos)/sizeof(FormatInfo);
|
|
|
|
|
|
|
|
static bool
|
|
|
|
GetFormatFromFormatChar (char format_char, Format &format)
|
|
|
|
{
|
|
|
|
for (uint32_t i=0; i<g_num_format_infos; ++i)
|
|
|
|
{
|
|
|
|
if (g_format_infos[i].format_char == format_char)
|
|
|
|
{
|
|
|
|
format = g_format_infos[i].format;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
format = eFormatInvalid;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool
|
|
|
|
GetFormatFromFormatName (const char *format_name, bool partial_match_ok, Format &format)
|
|
|
|
{
|
|
|
|
uint32_t i;
|
|
|
|
for (i=0; i<g_num_format_infos; ++i)
|
|
|
|
{
|
|
|
|
if (strcasecmp (g_format_infos[i].format_name, format_name) == 0)
|
|
|
|
{
|
|
|
|
format = g_format_infos[i].format;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (partial_match_ok)
|
|
|
|
{
|
|
|
|
for (i=0; i<g_num_format_infos; ++i)
|
|
|
|
{
|
|
|
|
if (strcasestr (g_format_infos[i].format_name, format_name) == g_format_infos[i].format_name)
|
|
|
|
{
|
|
|
|
format = g_format_infos[i].format;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
format = eFormatInvalid;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
FormatManager::GetFormatFromCString (const char *format_cstr,
|
|
|
|
bool partial_match_ok,
|
|
|
|
lldb::Format &format)
|
|
|
|
{
|
|
|
|
bool success = false;
|
|
|
|
if (format_cstr && format_cstr[0])
|
|
|
|
{
|
|
|
|
if (format_cstr[1] == '\0')
|
|
|
|
{
|
|
|
|
success = GetFormatFromFormatChar (format_cstr[0], format);
|
|
|
|
if (success)
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
success = GetFormatFromFormatName (format_cstr, partial_match_ok, format);
|
|
|
|
}
|
|
|
|
if (!success)
|
|
|
|
format = eFormatInvalid;
|
|
|
|
return success;
|
|
|
|
}
|
|
|
|
|
|
|
|
char
|
|
|
|
FormatManager::GetFormatAsFormatChar (lldb::Format format)
|
|
|
|
{
|
|
|
|
for (uint32_t i=0; i<g_num_format_infos; ++i)
|
|
|
|
{
|
|
|
|
if (g_format_infos[i].format == format)
|
|
|
|
return g_format_infos[i].format_char;
|
|
|
|
}
|
|
|
|
return '\0';
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const char *
|
|
|
|
FormatManager::GetFormatAsCString (Format format)
|
|
|
|
{
|
|
|
|
if (format >= eFormatDefault && format < kNumFormats)
|
|
|
|
return g_format_infos[format].format_name;
|
|
|
|
return NULL;
|
|
|
|
}
|
2011-07-02 08:25:22 +08:00
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::TypeCategoryImpl(IFormatChangeListener* clist,
|
|
|
|
ConstString name) :
|
2011-08-19 00:38:26 +08:00
|
|
|
m_summary_nav(new SummaryNavigator("summary",clist)),
|
|
|
|
m_regex_summary_nav(new RegexSummaryNavigator("regex-summary",clist)),
|
|
|
|
m_filter_nav(new FilterNavigator("filter",clist)),
|
|
|
|
m_regex_filter_nav(new RegexFilterNavigator("regex-filter",clist)),
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-08-19 00:38:26 +08:00
|
|
|
m_synth_nav(new SynthNavigator("synth",clist)),
|
|
|
|
m_regex_synth_nav(new RegexSynthNavigator("regex-synth",clist)),
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-19 00:38:26 +08:00
|
|
|
m_enabled(false),
|
|
|
|
m_change_listener(clist),
|
|
|
|
m_mutex(Mutex::eMutexTypeRecursive),
|
|
|
|
m_name(name)
|
|
|
|
{}
|
|
|
|
|
2011-08-23 08:32:52 +08:00
|
|
|
bool
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::Get (ValueObject& valobj,
|
|
|
|
lldb::TypeSummaryImplSP& entry,
|
2011-08-23 08:32:52 +08:00
|
|
|
lldb::DynamicValueType use_dynamic,
|
|
|
|
uint32_t* reason)
|
|
|
|
{
|
|
|
|
if (!IsEnabled())
|
|
|
|
return false;
|
|
|
|
if (GetSummaryNavigator()->Get(valobj, entry, use_dynamic, reason))
|
|
|
|
return true;
|
|
|
|
bool regex = GetRegexSummaryNavigator()->Get(valobj, entry, use_dynamic, reason);
|
|
|
|
if (regex && reason)
|
Added support for the new ".apple_objc" accelerator tables. These tables are
in the same hashed format as the ".apple_names", but they map objective C
class names to all of the methods and class functions. We need to do this
because in the DWARF the methods for Objective C are never contained in the
class definition, they are scattered about at the translation unit level and
they don't even have attributes that say the are contained within the class
itself.
Added 3 new formats which can be used to display data:
eFormatAddressInfo
eFormatHexFloat
eFormatInstruction
eFormatAddressInfo describes an address such as function+offset and file+line,
or symbol + offset, or constant data (c string, 2, 4, 8, or 16 byte constants).
The format character for this is "A", the long format is "address".
eFormatHexFloat will print out the hex float format that compilers tend to use.
The format character for this is "X", the long format is "hex float".
eFormatInstruction will print out disassembly with bytes and it will use the
current target's architecture. The format character for this is "i" (which
used to be being used for the integer format, but the integer format also has
"d", so we gave the "i" format to disassembly), the long format is
"instruction".
Mate the lldb::FormatterChoiceCriterion enumeration private as it should have
been from the start. It is very specialized and doesn't belong in the public
API.
llvm-svn: 143114
2011-10-28 01:55:14 +08:00
|
|
|
*reason |= lldb_private::eFormatterChoiceCriterionRegularExpressionSummary;
|
2011-08-23 08:32:52 +08:00
|
|
|
return regex;
|
|
|
|
}
|
|
|
|
|
2011-08-19 00:38:26 +08:00
|
|
|
bool
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::Get(ValueObject& valobj,
|
2011-11-04 11:34:56 +08:00
|
|
|
lldb::SyntheticChildrenSP& entry_sp,
|
2011-08-19 00:38:26 +08:00
|
|
|
lldb::DynamicValueType use_dynamic,
|
|
|
|
uint32_t* reason)
|
|
|
|
{
|
|
|
|
if (!IsEnabled())
|
|
|
|
return false;
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeFilterImpl::SharedPointer filter_sp;
|
2011-11-04 11:34:56 +08:00
|
|
|
uint32_t reason_filter = 0;
|
|
|
|
bool regex_filter = false;
|
2011-08-19 00:38:26 +08:00
|
|
|
// first find both Filter and Synth, and then check which is most recent
|
|
|
|
|
2011-11-04 11:34:56 +08:00
|
|
|
if (!GetFilterNavigator()->Get(valobj, filter_sp, use_dynamic, &reason_filter))
|
|
|
|
regex_filter = GetRegexFilterNavigator()->Get (valobj, filter_sp, use_dynamic, &reason_filter);
|
|
|
|
|
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
|
|
|
bool regex_synth = false;
|
|
|
|
uint32_t reason_synth = 0;
|
|
|
|
bool pick_synth = false;
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeSyntheticImpl::SharedPointer synth;
|
2011-08-19 00:38:26 +08:00
|
|
|
if (!GetSyntheticNavigator()->Get(valobj, synth, use_dynamic, &reason_synth))
|
2011-11-04 11:34:56 +08:00
|
|
|
regex_synth = GetRegexSyntheticNavigator()->Get (valobj, synth, use_dynamic, &reason_synth);
|
|
|
|
if (!filter_sp.get() && !synth.get())
|
2011-08-19 00:38:26 +08:00
|
|
|
return false;
|
2011-11-04 11:34:56 +08:00
|
|
|
else if (!filter_sp.get() && synth.get())
|
2011-08-19 00:38:26 +08:00
|
|
|
pick_synth = true;
|
|
|
|
|
2011-11-04 11:34:56 +08:00
|
|
|
else if (filter_sp.get() && !synth.get())
|
2011-08-19 00:38:26 +08:00
|
|
|
pick_synth = false;
|
|
|
|
|
2011-11-04 11:34:56 +08:00
|
|
|
else /*if (filter_sp.get() && synth.get())*/
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
2012-02-15 10:34:21 +08:00
|
|
|
if (filter_sp->GetRevision() > synth->GetRevision())
|
2011-08-19 00:38:26 +08:00
|
|
|
pick_synth = false;
|
|
|
|
else
|
|
|
|
pick_synth = true;
|
|
|
|
}
|
|
|
|
if (pick_synth)
|
|
|
|
{
|
|
|
|
if (regex_synth && reason)
|
Added support for the new ".apple_objc" accelerator tables. These tables are
in the same hashed format as the ".apple_names", but they map objective C
class names to all of the methods and class functions. We need to do this
because in the DWARF the methods for Objective C are never contained in the
class definition, they are scattered about at the translation unit level and
they don't even have attributes that say the are contained within the class
itself.
Added 3 new formats which can be used to display data:
eFormatAddressInfo
eFormatHexFloat
eFormatInstruction
eFormatAddressInfo describes an address such as function+offset and file+line,
or symbol + offset, or constant data (c string, 2, 4, 8, or 16 byte constants).
The format character for this is "A", the long format is "address".
eFormatHexFloat will print out the hex float format that compilers tend to use.
The format character for this is "X", the long format is "hex float".
eFormatInstruction will print out disassembly with bytes and it will use the
current target's architecture. The format character for this is "i" (which
used to be being used for the integer format, but the integer format also has
"d", so we gave the "i" format to disassembly), the long format is
"instruction".
Mate the lldb::FormatterChoiceCriterion enumeration private as it should have
been from the start. It is very specialized and doesn't belong in the public
API.
llvm-svn: 143114
2011-10-28 01:55:14 +08:00
|
|
|
*reason |= lldb_private::eFormatterChoiceCriterionRegularExpressionFilter;
|
2011-11-04 11:34:56 +08:00
|
|
|
entry_sp = synth;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (regex_filter && reason)
|
Added support for the new ".apple_objc" accelerator tables. These tables are
in the same hashed format as the ".apple_names", but they map objective C
class names to all of the methods and class functions. We need to do this
because in the DWARF the methods for Objective C are never contained in the
class definition, they are scattered about at the translation unit level and
they don't even have attributes that say the are contained within the class
itself.
Added 3 new formats which can be used to display data:
eFormatAddressInfo
eFormatHexFloat
eFormatInstruction
eFormatAddressInfo describes an address such as function+offset and file+line,
or symbol + offset, or constant data (c string, 2, 4, 8, or 16 byte constants).
The format character for this is "A", the long format is "address".
eFormatHexFloat will print out the hex float format that compilers tend to use.
The format character for this is "X", the long format is "hex float".
eFormatInstruction will print out disassembly with bytes and it will use the
current target's architecture. The format character for this is "i" (which
used to be being used for the integer format, but the integer format also has
"d", so we gave the "i" format to disassembly), the long format is
"instruction".
Mate the lldb::FormatterChoiceCriterion enumeration private as it should have
been from the start. It is very specialized and doesn't belong in the public
API.
llvm-svn: 143114
2011-10-28 01:55:14 +08:00
|
|
|
*reason |= lldb_private::eFormatterChoiceCriterionRegularExpressionFilter;
|
2011-11-04 11:34:56 +08:00
|
|
|
entry_sp = filter_sp;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
2011-11-04 11:34:56 +08:00
|
|
|
|
|
|
|
#else
|
|
|
|
if (filter_sp)
|
|
|
|
{
|
|
|
|
entry_sp = filter_sp;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
2011-08-19 00:38:26 +08:00
|
|
|
}
|
|
|
|
|
2011-08-23 06:03:47 +08:00
|
|
|
void
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::Clear (FormatCategoryItems items)
|
2011-08-23 06:03:47 +08:00
|
|
|
{
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSummary) == eFormatCategoryItemSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_summary_nav->Clear();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSummary) == eFormatCategoryItemRegexSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_regex_summary_nav->Clear();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemFilter) == eFormatCategoryItemFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_filter_nav->Clear();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexFilter) == eFormatCategoryItemRegexFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_regex_filter_nav->Clear();
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSynth) == eFormatCategoryItemSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_synth_nav->Clear();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSynth) == eFormatCategoryItemRegexSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
m_regex_synth_nav->Clear();
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-23 06:03:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::Delete (ConstString name,
|
2011-08-23 06:03:47 +08:00
|
|
|
FormatCategoryItems items)
|
|
|
|
{
|
|
|
|
bool success = false;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSummary) == eFormatCategoryItemSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_summary_nav->Delete(name) || success;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSummary) == eFormatCategoryItemRegexSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_regex_summary_nav->Delete(name) || success;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemFilter) == eFormatCategoryItemFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_filter_nav->Delete(name) || success;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexFilter) == eFormatCategoryItemRegexFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_regex_filter_nav->Delete(name) || success;
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSynth) == eFormatCategoryItemSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_synth_nav->Delete(name) || success;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSynth) == eFormatCategoryItemRegexSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
success = m_regex_synth_nav->Delete(name) || success;
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-23 06:03:47 +08:00
|
|
|
return success;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::GetCount (FormatCategoryItems items)
|
2011-08-23 06:03:47 +08:00
|
|
|
{
|
|
|
|
uint32_t count = 0;
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSummary) == eFormatCategoryItemSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_summary_nav->GetCount();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSummary) == eFormatCategoryItemRegexSummary )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_regex_summary_nav->GetCount();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemFilter) == eFormatCategoryItemFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_filter_nav->GetCount();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexFilter) == eFormatCategoryItemRegexFilter )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_regex_filter_nav->GetCount();
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSynth) == eFormatCategoryItemSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_synth_nav->GetCount();
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSynth) == eFormatCategoryItemRegexSynth )
|
2011-08-23 06:03:47 +08:00
|
|
|
count += m_regex_synth_nav->GetCount();
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-23 06:03:47 +08:00
|
|
|
return count;
|
|
|
|
}
|
|
|
|
|
2011-08-19 00:38:26 +08:00
|
|
|
bool
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::AnyMatches(ConstString type_name,
|
2011-08-19 00:38:26 +08:00
|
|
|
FormatCategoryItems items,
|
|
|
|
bool only_enabled,
|
|
|
|
const char** matching_category,
|
|
|
|
FormatCategoryItems* matching_type)
|
|
|
|
{
|
|
|
|
if (!IsEnabled() && only_enabled)
|
|
|
|
return false;
|
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeSummaryImplSP summary;
|
|
|
|
TypeFilterImpl::SharedPointer filter;
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeSyntheticImpl::SharedPointer synth;
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-19 00:38:26 +08:00
|
|
|
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSummary) == eFormatCategoryItemSummary )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_summary_nav->Get(type_name, summary))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemSummary;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSummary) == eFormatCategoryItemRegexSummary )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_regex_summary_nav->Get(type_name, summary))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemRegexSummary;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemFilter) == eFormatCategoryItemFilter )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_filter_nav->Get(type_name, filter))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemFilter;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexFilter) == eFormatCategoryItemRegexFilter )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_regex_filter_nav->Get(type_name, filter))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemRegexFilter;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemSynth) == eFormatCategoryItemSynth )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_synth_nav->Get(type_name, synth))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemSynth;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-08-23 07:45:15 +08:00
|
|
|
if ( (items & eFormatCategoryItemRegexSynth) == eFormatCategoryItemRegexSynth )
|
2011-08-19 00:38:26 +08:00
|
|
|
{
|
|
|
|
if (m_regex_synth_nav->Get(type_name, synth))
|
|
|
|
{
|
|
|
|
if (matching_category)
|
2012-02-15 10:34:21 +08:00
|
|
|
*matching_category = m_name.GetCString();
|
2011-08-19 00:38:26 +08:00
|
|
|
if (matching_type)
|
2011-08-23 07:45:15 +08:00
|
|
|
*matching_type = eFormatCategoryItemRegexSynth;
|
2011-08-19 00:38:26 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2011-11-04 11:34:56 +08:00
|
|
|
#endif
|
2011-08-19 00:38:26 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-08-23 08:32:52 +08:00
|
|
|
bool
|
|
|
|
CategoryMap::AnyMatches (ConstString type_name,
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::FormatCategoryItems items,
|
|
|
|
bool only_enabled,
|
|
|
|
const char** matching_category,
|
|
|
|
TypeCategoryImpl::FormatCategoryItems* matching_type)
|
2011-08-23 08:32:52 +08:00
|
|
|
{
|
|
|
|
Mutex::Locker(m_map_mutex);
|
|
|
|
|
|
|
|
MapIterator pos, end = m_map.end();
|
|
|
|
for (pos = m_map.begin(); pos != end; pos++)
|
|
|
|
{
|
|
|
|
if (pos->second->AnyMatches(type_name,
|
|
|
|
items,
|
|
|
|
only_enabled,
|
|
|
|
matching_category,
|
|
|
|
matching_type))
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeSummaryImplSP
|
2011-09-07 06:59:55 +08:00
|
|
|
CategoryMap::GetSummaryFormat (ValueObject& valobj,
|
|
|
|
lldb::DynamicValueType use_dynamic)
|
2011-08-23 08:32:52 +08:00
|
|
|
{
|
|
|
|
Mutex::Locker(m_map_mutex);
|
|
|
|
|
|
|
|
uint32_t reason_why;
|
|
|
|
ActiveCategoriesIterator begin, end = m_active_categories.end();
|
|
|
|
|
|
|
|
for (begin = m_active_categories.begin(); begin != end; begin++)
|
|
|
|
{
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeCategoryImplSP category = *begin;
|
|
|
|
lldb::TypeSummaryImplSP current_format;
|
2011-08-23 08:32:52 +08:00
|
|
|
if (!category->Get(valobj, current_format, use_dynamic, &reason_why))
|
|
|
|
continue;
|
2011-09-07 06:59:55 +08:00
|
|
|
return current_format;
|
2011-08-23 08:32:52 +08:00
|
|
|
}
|
2012-02-15 10:34:21 +08:00
|
|
|
return lldb::TypeSummaryImplSP();
|
2011-08-23 08:32:52 +08:00
|
|
|
}
|
|
|
|
|
2012-05-09 05:49:57 +08:00
|
|
|
lldb::TypeSummaryImplSP
|
|
|
|
FormatManager::GetSummaryForType (lldb::TypeNameSpecifierImplSP type_sp)
|
|
|
|
{
|
|
|
|
if (!type_sp)
|
|
|
|
return lldb::TypeSummaryImplSP();
|
|
|
|
lldb::TypeSummaryImplSP summary_chosen_sp;
|
|
|
|
uint32_t num_categories = m_categories_map.GetCount();
|
|
|
|
lldb::TypeCategoryImplSP category_sp;
|
|
|
|
uint32_t prio_category = UINT32_MAX;
|
|
|
|
for (uint32_t category_id = 0;
|
|
|
|
category_id < num_categories;
|
|
|
|
category_id++)
|
|
|
|
{
|
|
|
|
category_sp = GetCategoryAtIndex(category_id);
|
|
|
|
if (category_sp->IsEnabled() == false)
|
|
|
|
continue;
|
|
|
|
lldb::TypeSummaryImplSP summary_current_sp = category_sp->GetSummaryForType(type_sp);
|
|
|
|
if (summary_current_sp && (summary_chosen_sp.get() == NULL || (prio_category > category_sp->GetEnabledPosition())))
|
|
|
|
{
|
|
|
|
prio_category = category_sp->GetEnabledPosition();
|
|
|
|
summary_chosen_sp = summary_current_sp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return summary_chosen_sp;
|
|
|
|
}
|
|
|
|
|
|
|
|
lldb::TypeFilterImplSP
|
|
|
|
FormatManager::GetFilterForType (lldb::TypeNameSpecifierImplSP type_sp)
|
|
|
|
{
|
|
|
|
if (!type_sp)
|
|
|
|
return lldb::TypeFilterImplSP();
|
|
|
|
lldb::TypeFilterImplSP filter_chosen_sp;
|
|
|
|
uint32_t num_categories = m_categories_map.GetCount();
|
|
|
|
lldb::TypeCategoryImplSP category_sp;
|
|
|
|
uint32_t prio_category = UINT32_MAX;
|
|
|
|
for (uint32_t category_id = 0;
|
|
|
|
category_id < num_categories;
|
|
|
|
category_id++)
|
|
|
|
{
|
|
|
|
category_sp = GetCategoryAtIndex(category_id);
|
|
|
|
if (category_sp->IsEnabled() == false)
|
|
|
|
continue;
|
|
|
|
lldb::TypeFilterImplSP filter_current_sp((TypeFilterImpl*)category_sp->GetFilterForType(type_sp).get());
|
|
|
|
if (filter_current_sp && (filter_chosen_sp.get() == NULL || (prio_category > category_sp->GetEnabledPosition())))
|
|
|
|
{
|
|
|
|
prio_category = category_sp->GetEnabledPosition();
|
|
|
|
filter_chosen_sp = filter_current_sp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return filter_chosen_sp;
|
|
|
|
}
|
|
|
|
|
2012-05-16 08:38:08 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-05-09 05:49:57 +08:00
|
|
|
lldb::TypeSyntheticImplSP
|
|
|
|
FormatManager::GetSyntheticForType (lldb::TypeNameSpecifierImplSP type_sp)
|
|
|
|
{
|
|
|
|
if (!type_sp)
|
|
|
|
return lldb::TypeSyntheticImplSP();
|
|
|
|
lldb::TypeSyntheticImplSP synth_chosen_sp;
|
|
|
|
uint32_t num_categories = m_categories_map.GetCount();
|
|
|
|
lldb::TypeCategoryImplSP category_sp;
|
|
|
|
uint32_t prio_category = UINT32_MAX;
|
|
|
|
for (uint32_t category_id = 0;
|
|
|
|
category_id < num_categories;
|
|
|
|
category_id++)
|
|
|
|
{
|
|
|
|
category_sp = GetCategoryAtIndex(category_id);
|
|
|
|
if (category_sp->IsEnabled() == false)
|
|
|
|
continue;
|
|
|
|
lldb::TypeSyntheticImplSP synth_current_sp((TypeSyntheticImpl*)category_sp->GetSyntheticForType(type_sp).get());
|
|
|
|
if (synth_current_sp && (synth_chosen_sp.get() == NULL || (prio_category > category_sp->GetEnabledPosition())))
|
|
|
|
{
|
|
|
|
prio_category = category_sp->GetEnabledPosition();
|
|
|
|
synth_chosen_sp = synth_current_sp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return synth_chosen_sp;
|
|
|
|
}
|
2012-05-16 08:38:08 +08:00
|
|
|
#endif
|
2012-05-09 05:49:57 +08:00
|
|
|
|
2012-05-16 08:38:08 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-05-09 05:49:57 +08:00
|
|
|
lldb::SyntheticChildrenSP
|
|
|
|
FormatManager::GetSyntheticChildrenForType (lldb::TypeNameSpecifierImplSP type_sp)
|
|
|
|
{
|
|
|
|
if (!type_sp)
|
|
|
|
return lldb::SyntheticChildrenSP();
|
|
|
|
lldb::TypeFilterImplSP filter_sp = GetFilterForType(type_sp);
|
|
|
|
lldb::TypeSyntheticImplSP synth_sp = GetSyntheticForType(type_sp);
|
|
|
|
if (filter_sp->GetRevision() > synth_sp->GetRevision())
|
|
|
|
return lldb::SyntheticChildrenSP(filter_sp.get());
|
|
|
|
else
|
|
|
|
return lldb::SyntheticChildrenSP(synth_sp.get());
|
|
|
|
}
|
2012-05-16 08:38:08 +08:00
|
|
|
#endif
|
2012-05-09 05:49:57 +08:00
|
|
|
|
2012-05-16 08:38:08 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2011-09-07 06:59:55 +08:00
|
|
|
lldb::SyntheticChildrenSP
|
|
|
|
CategoryMap::GetSyntheticChildren (ValueObject& valobj,
|
|
|
|
lldb::DynamicValueType use_dynamic)
|
2011-08-23 08:32:52 +08:00
|
|
|
{
|
|
|
|
Mutex::Locker(m_map_mutex);
|
|
|
|
|
|
|
|
uint32_t reason_why;
|
|
|
|
|
|
|
|
ActiveCategoriesIterator begin, end = m_active_categories.end();
|
|
|
|
|
|
|
|
for (begin = m_active_categories.begin(); begin != end; begin++)
|
|
|
|
{
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeCategoryImplSP category = *begin;
|
2011-08-23 08:32:52 +08:00
|
|
|
lldb::SyntheticChildrenSP current_format;
|
|
|
|
if (!category->Get(valobj, current_format, use_dynamic, &reason_why))
|
|
|
|
continue;
|
2011-09-07 06:59:55 +08:00
|
|
|
return current_format;
|
2011-08-23 08:32:52 +08:00
|
|
|
}
|
2011-09-07 06:59:55 +08:00
|
|
|
return lldb::SyntheticChildrenSP();
|
2011-08-23 08:32:52 +08:00
|
|
|
}
|
2012-05-16 08:38:08 +08:00
|
|
|
#endif
|
2011-08-23 08:32:52 +08:00
|
|
|
|
2011-08-19 00:38:26 +08:00
|
|
|
void
|
|
|
|
CategoryMap::LoopThrough(CallbackType callback, void* param)
|
|
|
|
{
|
|
|
|
if (callback)
|
|
|
|
{
|
|
|
|
Mutex::Locker(m_map_mutex);
|
|
|
|
|
|
|
|
// loop through enabled categories in respective order
|
|
|
|
{
|
|
|
|
ActiveCategoriesIterator begin, end = m_active_categories.end();
|
|
|
|
for (begin = m_active_categories.begin(); begin != end; begin++)
|
|
|
|
{
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeCategoryImplSP category = *begin;
|
|
|
|
ConstString type = ConstString(category->GetName());
|
2011-08-23 02:36:52 +08:00
|
|
|
if (!callback(param, category))
|
2011-08-19 00:38:26 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// loop through disabled categories in just any order
|
|
|
|
{
|
|
|
|
MapIterator pos, end = m_map.end();
|
|
|
|
for (pos = m_map.begin(); pos != end; pos++)
|
|
|
|
{
|
|
|
|
if (pos->second->IsEnabled())
|
|
|
|
continue;
|
|
|
|
KeyType type = pos->first;
|
2011-08-23 02:36:52 +08:00
|
|
|
if (!callback(param, pos->second))
|
2011-08-19 00:38:26 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImplSP
|
|
|
|
CategoryMap::GetAtIndex (uint32_t index)
|
|
|
|
{
|
|
|
|
Mutex::Locker(m_map_mutex);
|
|
|
|
|
|
|
|
if (index < m_map.size())
|
|
|
|
{
|
|
|
|
MapIterator pos, end = m_map.end();
|
|
|
|
for (pos = m_map.begin(); pos != end; pos++)
|
|
|
|
{
|
|
|
|
if (index == 0)
|
|
|
|
return pos->second;
|
|
|
|
index--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return TypeCategoryImplSP();
|
|
|
|
}
|
|
|
|
|
|
|
|
lldb::TypeCategoryImplSP
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
FormatManager::GetCategory (const ConstString& category_name,
|
2011-08-23 08:32:52 +08:00
|
|
|
bool can_create)
|
|
|
|
{
|
|
|
|
if (!category_name)
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
return GetCategory(m_default_category_name);
|
2012-02-15 10:34:21 +08:00
|
|
|
lldb::TypeCategoryImplSP category;
|
2011-08-23 08:32:52 +08:00
|
|
|
if (m_categories_map.Get(category_name, category))
|
|
|
|
return category;
|
|
|
|
|
|
|
|
if (!can_create)
|
2012-02-15 10:34:21 +08:00
|
|
|
return lldb::TypeCategoryImplSP();
|
2011-08-23 08:32:52 +08:00
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
m_categories_map.Add(category_name,lldb::TypeCategoryImplSP(new TypeCategoryImpl(this, category_name)));
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
return GetCategory(category_name);
|
2011-08-23 08:32:52 +08:00
|
|
|
}
|
|
|
|
|
2011-07-13 06:56:10 +08:00
|
|
|
lldb::Format
|
|
|
|
FormatManager::GetSingleItemFormat(lldb::Format vector_format)
|
|
|
|
{
|
|
|
|
switch(vector_format)
|
|
|
|
{
|
|
|
|
case eFormatVectorOfChar:
|
|
|
|
return eFormatCharArray;
|
|
|
|
|
|
|
|
case eFormatVectorOfSInt8:
|
|
|
|
case eFormatVectorOfSInt16:
|
|
|
|
case eFormatVectorOfSInt32:
|
|
|
|
case eFormatVectorOfSInt64:
|
|
|
|
return eFormatDecimal;
|
|
|
|
|
|
|
|
case eFormatVectorOfUInt8:
|
|
|
|
case eFormatVectorOfUInt16:
|
|
|
|
case eFormatVectorOfUInt32:
|
|
|
|
case eFormatVectorOfUInt64:
|
|
|
|
case eFormatVectorOfUInt128:
|
|
|
|
return eFormatHex;
|
|
|
|
|
|
|
|
case eFormatVectorOfFloat32:
|
|
|
|
case eFormatVectorOfFloat64:
|
|
|
|
return eFormatFloat;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return lldb::eFormatInvalid;
|
|
|
|
}
|
2011-08-10 10:10:13 +08:00
|
|
|
}
|
2011-08-18 06:13:59 +08:00
|
|
|
|
2011-08-19 09:14:49 +08:00
|
|
|
ConstString
|
|
|
|
FormatManager::GetValidTypeName (const ConstString& type)
|
|
|
|
{
|
|
|
|
return ::GetValidTypeName_Impl(type);
|
|
|
|
}
|
|
|
|
|
2011-08-18 06:13:59 +08:00
|
|
|
FormatManager::FormatManager() :
|
|
|
|
m_value_nav("format",this),
|
|
|
|
m_named_summaries_map(this),
|
|
|
|
m_last_revision(0),
|
|
|
|
m_categories_map(this),
|
2011-08-23 02:36:52 +08:00
|
|
|
m_default_category_name(ConstString("default")),
|
|
|
|
m_system_category_name(ConstString("system")),
|
2012-02-01 01:01:51 +08:00
|
|
|
m_gnu_cpp_category_name(ConstString("gnu-libstdc++")),
|
2012-03-13 03:47:17 +08:00
|
|
|
m_libcxx_category_name(ConstString("libcxx")),
|
2012-02-17 11:18:30 +08:00
|
|
|
m_objc_category_name(ConstString("objc")),
|
|
|
|
m_corefoundation_category_name(ConstString("CoreFoundation")),
|
|
|
|
m_coregraphics_category_name(ConstString("CoreGraphics")),
|
|
|
|
m_coreservices_category_name(ConstString("CoreServices")),
|
2012-02-24 07:10:03 +08:00
|
|
|
m_vectortypes_category_name(ConstString("VectorTypes")),
|
|
|
|
m_appkit_category_name(ConstString("AppKit"))
|
2011-08-18 06:13:59 +08:00
|
|
|
{
|
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
LoadSystemFormatters();
|
|
|
|
LoadSTLFormatters();
|
2012-03-13 03:47:17 +08:00
|
|
|
LoadLibcxxFormatters();
|
2012-02-21 13:33:55 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-02-17 11:18:30 +08:00
|
|
|
LoadObjCFormatters();
|
2012-02-21 13:33:55 +08:00
|
|
|
#endif
|
2011-08-18 06:13:59 +08:00
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
EnableCategory(m_objc_category_name,CategoryMap::Last);
|
2012-04-26 09:40:38 +08:00
|
|
|
EnableCategory(m_corefoundation_category_name,CategoryMap::Last);
|
|
|
|
EnableCategory(m_appkit_category_name,CategoryMap::Last);
|
|
|
|
EnableCategory(m_coreservices_category_name,CategoryMap::Last);
|
|
|
|
EnableCategory(m_coregraphics_category_name,CategoryMap::Last);
|
2012-02-17 11:18:30 +08:00
|
|
|
EnableCategory(m_gnu_cpp_category_name,CategoryMap::Last);
|
2012-03-13 03:47:17 +08:00
|
|
|
EnableCategory(m_libcxx_category_name,CategoryMap::Last);
|
2012-04-26 09:40:38 +08:00
|
|
|
EnableCategory(m_vectortypes_category_name,CategoryMap::Last);
|
2012-02-17 11:18:30 +08:00
|
|
|
EnableCategory(m_system_category_name,CategoryMap::Last);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
FormatManager::LoadSTLFormatters()
|
|
|
|
{
|
2012-03-02 08:55:53 +08:00
|
|
|
TypeSummaryImpl::Flags stl_summary_flags;
|
|
|
|
stl_summary_flags.SetCascades(true)
|
|
|
|
.SetSkipPointers(false)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(true)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false);
|
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP std_string_summary_sp(new StringSummaryFormat(stl_summary_flags,
|
2012-02-15 10:34:21 +08:00
|
|
|
"${var._M_dataplus._M_p}"));
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
|
2012-02-15 10:34:21 +08:00
|
|
|
TypeCategoryImpl::SharedPointer gnu_category_sp = GetCategory(m_gnu_cpp_category_name);
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
|
|
|
|
gnu_category_sp->GetSummaryNavigator()->Add(ConstString("std::string"),
|
|
|
|
std_string_summary_sp);
|
|
|
|
gnu_category_sp->GetSummaryNavigator()->Add(ConstString("std::basic_string<char>"),
|
|
|
|
std_string_summary_sp);
|
|
|
|
gnu_category_sp->GetSummaryNavigator()->Add(ConstString("std::basic_string<char,std::char_traits<char>,std::allocator<char> >"),
|
|
|
|
std_string_summary_sp);
|
2012-03-27 07:03:23 +08:00
|
|
|
gnu_category_sp->GetSummaryNavigator()->Add(ConstString("std::basic_string<char, std::char_traits<char>, std::allocator<char> >"),
|
Added a new --omit-names (-O, uppercase letter o) option to "type summary add".
When used in conjunction with --inline-children, this option will cause the names of the values to be omitted from the output. This can be beneficial in cases such as vFloat, where it will compact the representation from
([0]=1,[1]=2,[2]=3,[3]=4) to (1, 2, 3, 4).
Added a test case to check that the new option works correctly.
Also took some time to revisit SummaryFormat and related classes and tweak them for added readability and maintainability.
Finally, added a new class name to which the std::string summary should be applied.
llvm-svn: 149644
2012-02-03 07:34:52 +08:00
|
|
|
std_string_summary_sp);
|
2012-02-17 11:18:30 +08:00
|
|
|
|
Redesign of the interaction between Python and frozen objects:
- introduced two new classes ValueObjectConstResultChild and ValueObjectConstResultImpl: the first one is a ValueObjectChild obtained from
a ValueObjectConstResult, the second is a common implementation backend for VOCR and VOCRCh of method calls meant to read through pointers stored
in frozen objects ; now such reads transparently move from host to target as required
- as a consequence of the above, removed code that made target-memory copies of expression results in several places throughout LLDB, and also
removed code that enabled to recognize an expression result VO as such
- introduced a new GetPointeeData() method in ValueObject that lets you read a given amount of objects of type T from a VO
representing a T* or T[], and doing dereferences transparently
in private layer it returns a DataExtractor ; in public layer it returns an instance of a newly created lldb::SBData
- as GetPointeeData() does the right thing for both frozen and non-frozen ValueObject's, reimplemented ReadPointedString() to use it
en lieu of doing the raw read itself
- introduced a new GetData() method in ValueObject that lets you get a copy of the data that backs the ValueObject (for pointers,
this returns the address without any previous dereferencing steps ; for arrays it actually reads the whole chunk of memory)
in public layer this returns an SBData, just like GetPointeeData()
- introduced a new CreateValueFromData() method in SBValue that lets you create a new SBValue from a chunk of data wrapped in an SBData
the limitation to remember for this kind of SBValue is that they have no address: extracting the address-of for these objects (with any
of GetAddress(), GetLoadAddress() and AddressOf()) will return invalid values
- added several tests to check that "p"-ing objects (STL classes, char* and char[]) will do the right thing
Solved a bug where global pointers to global variables were not dereferenced correctly for display
New target setting "max-string-summary-length" gives the maximum number of characters to show in a string when summarizing it, instead of the hardcoded 128
Solved a bug where the summary for char[] and char* would not be shown if the ValueObject's were dumped via the "p" command
Removed m_pointers_point_to_load_addrs from ValueObject. Introduced a new m_address_type_of_children, which each ValueObject can set to tell the address type
of any pointers and/or references it creates. In the current codebase, this is load address most of the time (the only notable exception being file
addresses that generate file address children UNLESS we have a live process)
Updated help text for summary-string
Fixed an issue in STL formatters where std::stlcontainer::iterator would match the container's synthetic children providers
Edited the syntax and help for some commands to have proper argument types
llvm-svn: 139160
2011-09-07 03:20:51 +08:00
|
|
|
|
2011-11-04 11:34:56 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-02-15 10:34:21 +08:00
|
|
|
|
|
|
|
SyntheticChildren::Flags stl_synth_flags;
|
|
|
|
stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(false);
|
|
|
|
|
2012-03-27 10:35:13 +08:00
|
|
|
gnu_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::vector<.+>(( )?&)?$")),
|
2012-02-17 11:18:30 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.gnu_libstdcpp.StdVectorSynthProvider")));
|
2012-03-27 10:35:13 +08:00
|
|
|
gnu_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::map<.+> >(( )?&)?$")),
|
2012-02-17 11:18:30 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.gnu_libstdcpp.StdMapSynthProvider")));
|
2012-03-27 10:35:13 +08:00
|
|
|
gnu_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::list<.+>(( )?&)?$")),
|
2012-02-17 11:18:30 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.gnu_libstdcpp.StdListSynthProvider")));
|
2012-03-02 08:55:53 +08:00
|
|
|
|
2012-03-02 09:14:02 +08:00
|
|
|
stl_summary_flags.SetDontShowChildren(false);
|
2012-03-27 10:35:13 +08:00
|
|
|
gnu_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::vector<.+>(( )?&)?$")),
|
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags,
|
|
|
|
"size=${svar%#}")));
|
|
|
|
gnu_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::map<.+> >(( )?&)?$")),
|
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags,
|
|
|
|
"size=${svar%#}")));
|
|
|
|
gnu_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::list<.+>(( )?&)?$")),
|
2012-03-02 08:55:53 +08:00
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags,
|
|
|
|
"size=${svar%#}")));
|
2012-02-17 11:18:30 +08:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-03-13 03:47:17 +08:00
|
|
|
void
|
|
|
|
FormatManager::LoadLibcxxFormatters()
|
|
|
|
{
|
|
|
|
TypeSummaryImpl::Flags stl_summary_flags;
|
|
|
|
stl_summary_flags.SetCascades(true)
|
|
|
|
.SetSkipPointers(false)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(true)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false);
|
|
|
|
|
2012-03-13 09:19:42 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-08-08 10:06:30 +08:00
|
|
|
std::string code(" lldb.formatters.cpp.libcxx.stdstring_SummaryProvider(valobj,internal_dict)");
|
2012-04-26 01:53:41 +08:00
|
|
|
lldb::TypeSummaryImplSP std_string_summary_sp(new ScriptSummaryFormat(stl_summary_flags, "lldb.formatters.cpp.libcxx.stdstring_SummaryProvider",code.c_str()));
|
2012-03-13 03:47:17 +08:00
|
|
|
|
|
|
|
TypeCategoryImpl::SharedPointer libcxx_category_sp = GetCategory(m_libcxx_category_name);
|
|
|
|
|
|
|
|
libcxx_category_sp->GetSummaryNavigator()->Add(ConstString("std::__1::string"),
|
|
|
|
std_string_summary_sp);
|
2012-03-27 07:03:23 +08:00
|
|
|
libcxx_category_sp->GetSummaryNavigator()->Add(ConstString("std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >"),
|
2012-03-13 03:47:17 +08:00
|
|
|
std_string_summary_sp);
|
2012-03-13 09:19:42 +08:00
|
|
|
|
2012-03-13 03:47:17 +08:00
|
|
|
SyntheticChildren::Flags stl_synth_flags;
|
|
|
|
stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(false);
|
|
|
|
|
2012-03-27 10:35:13 +08:00
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::vector<.+>(( )?&)?$")),
|
2012-03-13 03:47:17 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.libcxx.stdvector_SynthProvider")));
|
2012-03-27 10:35:13 +08:00
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::list<.+>(( )?&)?$")),
|
2012-03-13 03:47:17 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.libcxx.stdlist_SynthProvider")));
|
2012-03-27 10:35:13 +08:00
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::map<.+> >(( )?&)?$")),
|
2012-03-13 03:47:17 +08:00
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.cpp.libcxx.stdmap_SynthProvider")));
|
2012-08-28 01:42:50 +08:00
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^(std::__1::)deque<.+>(( )?&)?$")),
|
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
|
|
|
"lldb.formatters.cpp.libcxx.stddeque_SynthProvider")));
|
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^(std::__1::)shared_ptr<.+>(( )?&)?$")),
|
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
|
|
|
"lldb.formatters.cpp.libcxx.stdsharedptr_SynthProvider")));
|
|
|
|
libcxx_category_sp->GetRegexSyntheticNavigator()->Add(RegularExpressionSP(new RegularExpression("^(std::__1::)weak_ptr<.+>(( )?&)?$")),
|
|
|
|
SyntheticChildrenSP(new TypeSyntheticImpl(stl_synth_flags,
|
|
|
|
"lldb.formatters.cpp.libcxx.stdsharedptr_SynthProvider")));
|
|
|
|
|
|
|
|
stl_summary_flags.SetDontShowChildren(false);stl_summary_flags.SetSkipPointers(true);
|
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::vector<.+>(( )?&)?$")),
|
2012-03-20 06:58:49 +08:00
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "size=${svar%#}")));
|
2012-03-27 10:35:13 +08:00
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::list<.+>(( )?&)?$")),
|
2012-03-20 06:58:49 +08:00
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "size=${svar%#}")));
|
2012-03-27 10:35:13 +08:00
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::map<.+> >(( )?&)?$")),
|
2012-03-20 06:58:49 +08:00
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "size=${svar%#}")));
|
2012-08-28 01:42:50 +08:00
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::deque<.+>(( )?&)?$")),
|
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "size=${svar%#}")));
|
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::shared_ptr<.+>(( )?&)?$")),
|
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "{${var.__ptr_%S}} (strong=${var.count} weak=${var.weak_count})")));
|
|
|
|
libcxx_category_sp->GetRegexSummaryNavigator()->Add(RegularExpressionSP(new RegularExpression("^std::__1::weak_ptr<.+>(( )?&)?$")),
|
|
|
|
TypeSummaryImplSP(new StringSummaryFormat(stl_summary_flags, "{${var.__ptr_%S}} (strong=${var.count} weak=${var.weak_count})")));
|
|
|
|
|
2012-03-13 03:47:17 +08:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
void
|
|
|
|
FormatManager::LoadSystemFormatters()
|
|
|
|
{
|
|
|
|
lldb::TypeSummaryImplSP string_format(new StringSummaryFormat(TypeSummaryImpl::Flags().SetCascades(false)
|
|
|
|
.SetSkipPointers(true)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(false)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false),
|
|
|
|
"${var%s}"));
|
|
|
|
|
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP string_array_format(new StringSummaryFormat(TypeSummaryImpl::Flags().SetCascades(false)
|
|
|
|
.SetSkipPointers(true)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(false)
|
|
|
|
.SetDontShowValue(true)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false),
|
|
|
|
"${var%s}"));
|
|
|
|
|
|
|
|
lldb::RegularExpressionSP any_size_char_arr(new RegularExpression("char \\[[0-9]+\\]"));
|
|
|
|
|
|
|
|
TypeCategoryImpl::SharedPointer sys_category_sp = GetCategory(m_system_category_name);
|
|
|
|
|
|
|
|
sys_category_sp->GetSummaryNavigator()->Add(ConstString("char *"), string_format);
|
|
|
|
sys_category_sp->GetSummaryNavigator()->Add(ConstString("const char *"), string_format);
|
|
|
|
sys_category_sp->GetRegexSummaryNavigator()->Add(any_size_char_arr, string_array_format);
|
2012-07-14 02:54:40 +08:00
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP ostype_summary(new StringSummaryFormat(TypeSummaryImpl::Flags().SetCascades(false)
|
|
|
|
.SetSkipPointers(true)
|
|
|
|
.SetSkipReferences(true)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(false)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false),
|
|
|
|
"${var%O}"));
|
|
|
|
|
|
|
|
sys_category_sp->GetSummaryNavigator()->Add(ConstString("OSType"), ostype_summary);
|
2012-02-17 11:18:30 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
AddSummary(TypeCategoryImpl::SharedPointer category_sp,
|
|
|
|
const char* string,
|
|
|
|
ConstString type_name,
|
|
|
|
TypeSummaryImpl::Flags flags)
|
|
|
|
{
|
|
|
|
lldb::TypeSummaryImplSP summary_sp(new StringSummaryFormat(flags,
|
|
|
|
string));
|
|
|
|
category_sp->GetSummaryNavigator()->Add(type_name,
|
|
|
|
summary_sp);
|
|
|
|
}
|
|
|
|
|
2012-03-08 12:03:25 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-02-24 07:10:03 +08:00
|
|
|
static void
|
|
|
|
AddScriptSummary(TypeCategoryImpl::SharedPointer category_sp,
|
|
|
|
const char* funct_name,
|
|
|
|
ConstString type_name,
|
|
|
|
TypeSummaryImpl::Flags flags)
|
|
|
|
{
|
|
|
|
|
|
|
|
std::string code(" ");
|
2012-08-08 10:06:30 +08:00
|
|
|
code.append(funct_name).append("(valobj,internal_dict)");
|
2012-02-24 07:10:03 +08:00
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP summary_sp(new ScriptSummaryFormat(flags,
|
|
|
|
funct_name,
|
|
|
|
code.c_str()));
|
|
|
|
category_sp->GetSummaryNavigator()->Add(type_name,
|
|
|
|
summary_sp);
|
|
|
|
}
|
2012-03-08 12:03:25 +08:00
|
|
|
#endif
|
2012-02-24 07:10:03 +08:00
|
|
|
|
2012-02-21 13:33:55 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
2012-02-17 11:18:30 +08:00
|
|
|
void
|
|
|
|
FormatManager::LoadObjCFormatters()
|
|
|
|
{
|
|
|
|
TypeSummaryImpl::Flags objc_flags;
|
|
|
|
objc_flags.SetCascades(false)
|
2012-07-14 02:55:41 +08:00
|
|
|
.SetSkipPointers(true)
|
|
|
|
.SetSkipReferences(true)
|
2012-02-17 11:18:30 +08:00
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(true)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false);
|
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP ObjC_BOOL_summary(new ScriptSummaryFormat(objc_flags,
|
2012-04-26 01:53:41 +08:00
|
|
|
"lldb.formatters.objc.objc.BOOL_SummaryProvider",
|
2012-02-15 10:34:21 +08:00
|
|
|
""));
|
|
|
|
TypeCategoryImpl::SharedPointer objc_category_sp = GetCategory(m_objc_category_name);
|
2012-02-01 01:01:51 +08:00
|
|
|
objc_category_sp->GetSummaryNavigator()->Add(ConstString("BOOL"),
|
|
|
|
ObjC_BOOL_summary);
|
2012-07-14 02:55:41 +08:00
|
|
|
|
|
|
|
lldb::TypeSummaryImplSP ObjC_BOOLRef_summary(new ScriptSummaryFormat(objc_flags,
|
|
|
|
"lldb.formatters.objc.objc.BOOLRef_SummaryProvider",
|
|
|
|
""));
|
|
|
|
objc_category_sp->GetSummaryNavigator()->Add(ConstString("BOOL &"),
|
|
|
|
ObjC_BOOLRef_summary);
|
|
|
|
lldb::TypeSummaryImplSP ObjC_BOOLPtr_summary(new ScriptSummaryFormat(objc_flags,
|
|
|
|
"lldb.formatters.objc.objc.BOOLPtr_SummaryProvider",
|
|
|
|
""));
|
|
|
|
objc_category_sp->GetSummaryNavigator()->Add(ConstString("BOOL *"),
|
|
|
|
ObjC_BOOLPtr_summary);
|
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
|
2012-03-02 08:55:53 +08:00
|
|
|
// we need to skip pointers here since we are special casing a SEL* when retrieving its value
|
|
|
|
objc_flags.SetSkipPointers(true);
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(objc_category_sp, "lldb.formatters.objc.Selector.SEL_Summary", ConstString("SEL"), objc_flags);
|
|
|
|
AddScriptSummary(objc_category_sp, "lldb.formatters.objc.Selector.SEL_Summary", ConstString("struct objc_selector"), objc_flags);
|
|
|
|
AddScriptSummary(objc_category_sp, "lldb.formatters.objc.Selector.SEL_Summary", ConstString("objc_selector"), objc_flags);
|
|
|
|
AddScriptSummary(objc_category_sp, "lldb.formatters.objc.Selector.SELPointer_Summary", ConstString("objc_selector *"), objc_flags);
|
|
|
|
AddScriptSummary(objc_category_sp, "lldb.formatters.objc.Class.Class_Summary", ConstString("Class"), objc_flags);
|
2012-03-02 08:55:53 +08:00
|
|
|
objc_flags.SetSkipPointers(false);
|
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
TypeCategoryImpl::SharedPointer corefoundation_category_sp = GetCategory(m_corefoundation_category_name);
|
|
|
|
|
|
|
|
AddSummary(corefoundation_category_sp,
|
|
|
|
"${var.years} years, ${var.months} months, ${var.days} days, ${var.hours} hours, ${var.minutes} minutes ${var.seconds} seconds",
|
|
|
|
ConstString("CFGregorianUnits"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(corefoundation_category_sp,
|
|
|
|
"location=${var.location} length=${var.length}",
|
|
|
|
ConstString("CFRange"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(corefoundation_category_sp,
|
2012-03-02 03:32:33 +08:00
|
|
|
"(x=${var.x}, y=${var.y})",
|
2012-02-17 11:18:30 +08:00
|
|
|
ConstString("NSPoint"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(corefoundation_category_sp,
|
|
|
|
"location=${var.location}, length=${var.length}",
|
|
|
|
ConstString("NSRange"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(corefoundation_category_sp,
|
|
|
|
"${var.origin}, ${var.size}",
|
|
|
|
ConstString("NSRect"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(corefoundation_category_sp,
|
|
|
|
"(${var.origin}, ${var.size}), ...",
|
|
|
|
ConstString("NSRectArray"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(objc_category_sp,
|
2012-03-02 03:32:33 +08:00
|
|
|
"(width=${var.width}, height=${var.height})",
|
2012-02-17 11:18:30 +08:00
|
|
|
ConstString("NSSize"),
|
|
|
|
objc_flags);
|
|
|
|
|
|
|
|
TypeCategoryImpl::SharedPointer coregraphics_category_sp = GetCategory(m_coregraphics_category_name);
|
|
|
|
|
|
|
|
AddSummary(coregraphics_category_sp,
|
|
|
|
"(width=${var.width}, height=${var.height})",
|
|
|
|
ConstString("CGSize"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coregraphics_category_sp,
|
|
|
|
"(x=${var.x}, y=${var.y})",
|
|
|
|
ConstString("CGPoint"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coregraphics_category_sp,
|
|
|
|
"origin=${var.origin} size=${var.size}",
|
|
|
|
ConstString("CGRect"),
|
|
|
|
objc_flags);
|
|
|
|
|
|
|
|
TypeCategoryImpl::SharedPointer coreservices_category_sp = GetCategory(m_coreservices_category_name);
|
|
|
|
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"red=${var.red} green=${var.green} blue=${var.blue}",
|
|
|
|
ConstString("RGBColor"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"(t=${var.top}, l=${var.left}, b=${var.bottom}, r=${var.right})",
|
|
|
|
ConstString("Rect"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"(v=${var.v}, h=${var.h})",
|
|
|
|
ConstString("Point"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"${var.month}/${var.day}/${var.year} ${var.hour} :${var.minute} :${var.second} dayOfWeek:${var.dayOfWeek}",
|
|
|
|
ConstString("DateTimeRect *"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"${var.ld.month}/${var.ld.day}/${var.ld.year} ${var.ld.hour} :${var.ld.minute} :${var.ld.second} dayOfWeek:${var.ld.dayOfWeek}",
|
|
|
|
ConstString("LongDateRect"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"(x=${var.x}, y=${var.y})",
|
|
|
|
ConstString("HIPoint"),
|
|
|
|
objc_flags);
|
|
|
|
AddSummary(coreservices_category_sp,
|
|
|
|
"origin=${var.origin} size=${var.size}",
|
|
|
|
ConstString("HIRect"),
|
|
|
|
objc_flags);
|
|
|
|
|
2012-02-24 07:10:03 +08:00
|
|
|
TypeCategoryImpl::SharedPointer appkit_category_sp = GetCategory(m_appkit_category_name);
|
|
|
|
|
|
|
|
TypeSummaryImpl::Flags appkit_flags;
|
|
|
|
appkit_flags.SetCascades(true)
|
|
|
|
.SetSkipPointers(false)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(false)
|
|
|
|
.SetShowMembersOneLiner(false)
|
|
|
|
.SetHideItemNames(false);
|
|
|
|
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("NSArray"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("__NSArrayI"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("__NSArrayM"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("__NSCFArray"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("CFArrayRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFArray.CFArray_SummaryProvider", ConstString("CFMutableArrayRef"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBag.CFBag_SummaryProvider", ConstString("CFBagRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBag.CFBag_SummaryProvider", ConstString("__CFBag"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBag.CFBag_SummaryProvider", ConstString("const struct __CFBag"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBag.CFBag_SummaryProvider", ConstString("CFMutableBagRef"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBinaryHeap.CFBinaryHeap_SummaryProvider", ConstString("CFBinaryHeapRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBinaryHeap.CFBinaryHeap_SummaryProvider", ConstString("__CFBinaryHeap"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider", ConstString("NSDictionary"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider2", ConstString("CFDictionaryRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider2", ConstString("CFMutableDictionaryRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider", ConstString("__NSCFDictionary"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider", ConstString("__NSDictionaryI"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFDictionary.CFDictionary_SummaryProvider", ConstString("__NSDictionaryM"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("NSString"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("CFStringRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("CFMutableStringRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFAttributedString_SummaryProvider", ConstString("NSAttributedString"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("__NSCFConstantString"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("__NSCFString"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("NSCFConstantString"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("NSCFString"), appkit_flags);
|
2012-06-29 07:05:43 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFString.CFString_SummaryProvider", ConstString("NSPathStore2"), appkit_flags);
|
|
|
|
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSBundle.NSBundle_SummaryProvider", ConstString("NSBundle"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider", ConstString("NSData"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider2", ConstString("CFDataRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider2", ConstString("CFMutableDataRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider", ConstString("NSConcreteData"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider", ConstString("NSConcreteMutableData"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSData.NSData_SummaryProvider", ConstString("__NSCFData"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSException.NSException_SummaryProvider", ConstString("NSException"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSMachPort.NSMachPort_SummaryProvider", ConstString("NSMachPort"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNotification.NSNotification_SummaryProvider", ConstString("NSNotification"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNotification.NSNotification_SummaryProvider", ConstString("NSConcreteNotification"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNumber.NSNumber_SummaryProvider", ConstString("NSNumber"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNumber.NSNumber_SummaryProvider", ConstString("__NSCFBoolean"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNumber.NSNumber_SummaryProvider", ConstString("__NSCFNumber"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNumber.NSNumber_SummaryProvider", ConstString("NSCFBoolean"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSNumber.NSNumber_SummaryProvider", ConstString("NSCFNumber"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider", ConstString("NSSet"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider2", ConstString("CFSetRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider2", ConstString("CFMutableSetRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider", ConstString("__NSCFSet"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider", ConstString("__NSSetI"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider", ConstString("__NSSetM"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSSet.NSSet_SummaryProvider", ConstString("NSCountedSet"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSURL.NSURL_SummaryProvider", ConstString("NSURL"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSURL.NSURL_SummaryProvider", ConstString("CFURLRef"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSDate_SummaryProvider", ConstString("NSDate"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSDate_SummaryProvider", ConstString("__NSDate"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSDate_SummaryProvider", ConstString("__NSTaggedDate"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSDate_SummaryProvider", ConstString("NSCalendarDate"), appkit_flags);
|
|
|
|
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSTimeZone_SummaryProvider", ConstString("NSTimeZone"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSTimeZone_SummaryProvider", ConstString("CFTimeZoneRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.NSTimeZone_SummaryProvider", ConstString("__NSTimeZone"), appkit_flags);
|
2012-03-02 08:55:53 +08:00
|
|
|
|
2012-03-02 03:32:33 +08:00
|
|
|
// CFAbsoluteTime is actually a double rather than a pointer to an object
|
|
|
|
// we do not care about the numeric value, since it is probably meaningless to users
|
|
|
|
appkit_flags.SetDontShowValue(true);
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSDate.CFAbsoluteTime_SummaryProvider", ConstString("CFAbsoluteTime"), appkit_flags);
|
2012-03-02 03:32:33 +08:00
|
|
|
appkit_flags.SetDontShowValue(false);
|
|
|
|
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSIndexSet.NSIndexSet_SummaryProvider", ConstString("NSIndexSet"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSIndexSet.NSIndexSet_SummaryProvider", ConstString("NSMutableIndexSet"), appkit_flags);
|
2012-03-02 03:32:33 +08:00
|
|
|
|
2012-03-02 08:55:53 +08:00
|
|
|
AddSummary(appkit_category_sp, "@\"${var.month%d}/${var.day%d}/${var.year%d} ${var.hour%d}:${var.minute%d}:${var.second}\"", ConstString("CFGregorianDate"), appkit_flags);
|
|
|
|
|
2012-04-26 01:53:41 +08:00
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBitVector.CFBitVector_SummaryProvider", ConstString("CFBitVectorRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBitVector.CFBitVector_SummaryProvider", ConstString("CFMutableBitVectorRef"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBitVector.CFBitVector_SummaryProvider", ConstString("__CFBitVector"), appkit_flags);
|
|
|
|
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.CFBitVector.CFBitVector_SummaryProvider", ConstString("__CFMutableBitVector"), appkit_flags);
|
2012-03-03 08:45:57 +08:00
|
|
|
|
2012-02-17 11:18:30 +08:00
|
|
|
TypeCategoryImpl::SharedPointer vectors_category_sp = GetCategory(m_vectortypes_category_name);
|
|
|
|
|
|
|
|
TypeSummaryImpl::Flags vector_flags;
|
|
|
|
vector_flags.SetCascades(true)
|
|
|
|
.SetSkipPointers(true)
|
|
|
|
.SetSkipReferences(false)
|
|
|
|
.SetDontShowChildren(true)
|
|
|
|
.SetDontShowValue(false)
|
|
|
|
.SetShowMembersOneLiner(true)
|
|
|
|
.SetHideItemNames(true);
|
|
|
|
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"${var.uint128}",
|
|
|
|
ConstString("builtin_type_vec128"),
|
|
|
|
objc_flags);
|
|
|
|
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("float [4]"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("int32_t [4]"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("int16_t [8]"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vDouble"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vFloat"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vSInt8"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vSInt16"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vSInt32"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vUInt16"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vUInt8"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vUInt16"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vUInt32"),
|
|
|
|
vector_flags);
|
|
|
|
AddSummary(vectors_category_sp,
|
|
|
|
"",
|
|
|
|
ConstString("vBool32"),
|
|
|
|
vector_flags);
|
2011-10-12 08:53:29 +08:00
|
|
|
}
|
2012-02-21 13:33:55 +08:00
|
|
|
#endif // LLDB_DISABLE_PYTHON
|