forked from OSchip/llvm-project
Moving CFBag and NSBundle summaries from Python to C++
Temporarily disabled non-code-running summaries for CF*Dictionary and NSCountedSet llvm-svn: 177171
This commit is contained in:
parent
9d7a3827e4
commit
f68f732746
|
@ -91,6 +91,12 @@ namespace lldb_private {
|
|||
bool
|
||||
NSNumberSummaryProvider (ValueObject& valobj, Stream& stream);
|
||||
|
||||
bool
|
||||
CFBagSummaryProvider (ValueObject& valobj, Stream& stream);
|
||||
|
||||
bool
|
||||
NSBundleSummaryProvider (ValueObject& valobj, Stream& stream);
|
||||
|
||||
bool
|
||||
NSStringSummaryProvider (ValueObject& valobj, Stream& stream);
|
||||
|
||||
|
|
|
@ -614,6 +614,118 @@ lldb_private::formatters::NSDataSummaryProvider (ValueObject& valobj, Stream& st
|
|||
return true;
|
||||
}
|
||||
|
||||
bool
|
||||
lldb_private::formatters::NSBundleSummaryProvider (ValueObject& valobj, Stream& stream)
|
||||
{
|
||||
ProcessSP process_sp = valobj.GetProcessSP();
|
||||
if (!process_sp)
|
||||
return false;
|
||||
|
||||
ObjCLanguageRuntime* runtime = (ObjCLanguageRuntime*)process_sp->GetLanguageRuntime(lldb::eLanguageTypeObjC);
|
||||
|
||||
if (!runtime)
|
||||
return false;
|
||||
|
||||
ObjCLanguageRuntime::ClassDescriptorSP descriptor(runtime->GetClassDescriptor(valobj));
|
||||
|
||||
if (!descriptor.get() || !descriptor->IsValid())
|
||||
return false;
|
||||
|
||||
uint32_t ptr_size = process_sp->GetAddressByteSize();
|
||||
|
||||
lldb::addr_t valobj_addr = valobj.GetValueAsUnsigned(0);
|
||||
|
||||
if (!valobj_addr)
|
||||
return false;
|
||||
|
||||
const char* class_name = descriptor->GetClassName().GetCString();
|
||||
|
||||
if (!class_name || !*class_name)
|
||||
return false;
|
||||
|
||||
if (!strcmp(class_name,"NSBundle"))
|
||||
{
|
||||
uint64_t offset = 5 * ptr_size;
|
||||
ClangASTType type(valobj.GetClangAST(),valobj.GetClangType());
|
||||
ValueObjectSP text(valobj.GetSyntheticChildAtOffset(offset, type, true));
|
||||
StreamString summary_stream;
|
||||
bool was_nsstring_ok = NSStringSummaryProvider(*text.get(), summary_stream);
|
||||
if (was_nsstring_ok && summary_stream.GetSize() > 0)
|
||||
{
|
||||
stream.Printf("%s",summary_stream.GetData());
|
||||
return true;
|
||||
}
|
||||
}
|
||||
// this is either an unknown subclass or an NSBundle that comes from [NSBundle mainBundle]
|
||||
// which is encoded differently and needs to be handled by running code
|
||||
return ExtractSummaryFromObjCExpression(valobj, "NSString*", "bundlePath", stream);
|
||||
}
|
||||
|
||||
bool
|
||||
lldb_private::formatters::CFBagSummaryProvider (ValueObject& valobj, Stream& stream)
|
||||
{
|
||||
ProcessSP process_sp = valobj.GetProcessSP();
|
||||
if (!process_sp)
|
||||
return false;
|
||||
|
||||
ObjCLanguageRuntime* runtime = (ObjCLanguageRuntime*)process_sp->GetLanguageRuntime(lldb::eLanguageTypeObjC);
|
||||
|
||||
if (!runtime)
|
||||
return false;
|
||||
|
||||
ObjCLanguageRuntime::ClassDescriptorSP descriptor(runtime->GetClassDescriptor(valobj));
|
||||
|
||||
if (!descriptor.get() || !descriptor->IsValid())
|
||||
return false;
|
||||
|
||||
uint32_t ptr_size = process_sp->GetAddressByteSize();
|
||||
|
||||
lldb::addr_t valobj_addr = valobj.GetValueAsUnsigned(0);
|
||||
|
||||
if (!valobj_addr)
|
||||
return false;
|
||||
|
||||
uint32_t count = 0;
|
||||
|
||||
bool is_type_ok = false; // check to see if this is a CFBag we know about
|
||||
if (descriptor->IsCFType())
|
||||
{
|
||||
ConstString type_name(valobj.GetTypeName());
|
||||
if (type_name == ConstString("__CFBag") || type_name == ConstString("const struct __CFBag"))
|
||||
{
|
||||
if (valobj.IsPointerType())
|
||||
is_type_ok = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (is_type_ok == false)
|
||||
{
|
||||
// num_children_vo = self.valobj.CreateValueFromExpression("count","(int)CFBagGetCount(" + stream.GetData() + " )")
|
||||
StackFrameSP frame_sp(valobj.GetFrameSP());
|
||||
if (!frame_sp)
|
||||
return false;
|
||||
ValueObjectSP count_sp;
|
||||
StreamString expr;
|
||||
expr.Printf("(int)CFBagGetCount((void*)0x%" PRIx64 ")",valobj.GetPointerValue());
|
||||
if (process_sp->GetTarget().EvaluateExpression(expr.GetData(), frame_sp.get(), count_sp) != eExecutionCompleted)
|
||||
return false;
|
||||
if (!count_sp)
|
||||
return false;
|
||||
count = count_sp->GetValueAsUnsigned(0);
|
||||
}
|
||||
else
|
||||
{
|
||||
uint32_t offset = 2*ptr_size+4 + valobj_addr;
|
||||
Error error;
|
||||
count = process_sp->ReadUnsignedIntegerFromMemory(offset, 4, 0, error);
|
||||
if (error.Fail())
|
||||
return false;
|
||||
}
|
||||
stream.Printf("@\"%u value%s\"",
|
||||
count,(count == 1 ? "" : "s"));
|
||||
return true;
|
||||
}
|
||||
|
||||
bool
|
||||
lldb_private::formatters::NSNumberSummaryProvider (ValueObject& valobj, Stream& stream)
|
||||
{
|
||||
|
|
|
@ -921,10 +921,10 @@ FormatManager::LoadObjCFormatters()
|
|||
AddCXXSynthetic(appkit_category_sp, lldb_private::formatters::NSSetSyntheticFrontEndCreator, "NSSet synthetic children", ConstString("__NSSetM"), ScriptedSyntheticChildren::Flags());
|
||||
AddCXXSynthetic(appkit_category_sp, lldb_private::formatters::NSSetSyntheticFrontEndCreator, "NSSet synthetic children", ConstString("NSMutableSet"), ScriptedSyntheticChildren::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);
|
||||
AddCXXSummary(appkit_category_sp,lldb_private::formatters::CFBagSummaryProvider, "CFBag summary provider", ConstString("CFBagRef"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp,lldb_private::formatters::CFBagSummaryProvider, "CFBag summary provider", ConstString("__CFBag"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp,lldb_private::formatters::CFBagSummaryProvider, "CFBag summary provider", ConstString("const struct __CFBag"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp,lldb_private::formatters::CFBagSummaryProvider, "CFBag summary provider", 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);
|
||||
|
@ -943,7 +943,7 @@ FormatManager::LoadObjCFormatters()
|
|||
AddCXXSummary(appkit_category_sp, lldb_private::formatters::NSMutableAttributedStringSummaryProvider, "NSMutableAttributedString summary provider", ConstString("NSMutableAttributedString"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp, lldb_private::formatters::NSMutableAttributedStringSummaryProvider, "NSMutableAttributedString summary provider", ConstString("NSConcreteMutableAttributedString"), appkit_flags);
|
||||
|
||||
AddScriptSummary(appkit_category_sp, "lldb.formatters.objc.NSBundle.NSBundle_SummaryProvider", ConstString("NSBundle"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp, lldb_private::formatters::NSBundleSummaryProvider, "NSBundle summary provider", ConstString("NSBundle"), appkit_flags);
|
||||
|
||||
AddCXXSummary(appkit_category_sp, lldb_private::formatters::NSDataSummaryProvider<false>, "NSData summary provider", ConstString("NSData"), appkit_flags);
|
||||
AddCXXSummary(appkit_category_sp, lldb_private::formatters::NSDataSummaryProvider<false>, "NSData summary provider", ConstString("NSConcreteData"), appkit_flags);
|
||||
|
|
|
@ -74,15 +74,15 @@ lldb_private::formatters::NSDictionarySummaryProvider (ValueObject& valobj, Stre
|
|||
return false;
|
||||
value &= (is_64bit ? ~0xFC00000000000000UL : ~0xFC000000U);
|
||||
}
|
||||
else if (!strcmp(class_name,"__NSCFDictionary"))
|
||||
/*else if (!strcmp(class_name,"__NSCFDictionary"))
|
||||
{
|
||||
Error error;
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(valobj_addr + (is_64bit ? 20 : 12), ptr_size, 0, error);
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(valobj_addr + (is_64bit ? 20 : 12), 4, 0, error);
|
||||
if (error.Fail())
|
||||
return false;
|
||||
if (is_64bit)
|
||||
value &= ~0x0f1f000000000000UL;
|
||||
}
|
||||
}*/
|
||||
else
|
||||
{
|
||||
if (!ExtractValueFromObjCExpression(valobj, "int", "count", value))
|
||||
|
|
|
@ -77,24 +77,24 @@ lldb_private::formatters::NSSetSummaryProvider (ValueObject& valobj, Stream& str
|
|||
else if (!strcmp(class_name,"__NSCFSet"))
|
||||
{
|
||||
Error error;
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(valobj_addr + (is_64bit ? 20 : 12), ptr_size, 0, error);
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(valobj_addr + (is_64bit ? 20 : 12), 4, 0, error);
|
||||
if (error.Fail())
|
||||
return false;
|
||||
if (is_64bit)
|
||||
value &= ~0x1fff000000000000UL;
|
||||
}
|
||||
else if (!strcmp(class_name,"NSCountedSet"))
|
||||
/*else if (!strcmp(class_name,"NSCountedSet"))
|
||||
{
|
||||
Error error;
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(valobj_addr + ptr_size, ptr_size, 0, error);
|
||||
if (error.Fail())
|
||||
return false;
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(value + (is_64bit ? 20 : 12), ptr_size, 0, error);
|
||||
value = process_sp->ReadUnsignedIntegerFromMemory(value + (is_64bit ? 20 : 12), 4, 0, error);
|
||||
if (error.Fail())
|
||||
return false;
|
||||
if (is_64bit)
|
||||
value &= ~0x1fff000000000000UL;
|
||||
}
|
||||
}*/
|
||||
else
|
||||
{
|
||||
if (!ExtractValueFromObjCExpression(valobj, "int", "count", value))
|
||||
|
|
Loading…
Reference in New Issue