diff options
author | Enrico Granata <egranata@apple.com> | 2012-09-29 00:47:43 +0000 |
---|---|---|
committer | Enrico Granata <egranata@apple.com> | 2012-09-29 00:47:43 +0000 |
commit | 6d39077fe7f42c51d3c5b76feb91b82d99e4206c (patch) | |
tree | 0a9edcd7f118328eec91a00ef9e67090a152569c /lldb/source/Core/CXXFormatterFunctions.cpp | |
parent | 60b81dff85029de1db5fbb50f6b2000632e03b73 (diff) | |
download | bcm5719-llvm-6d39077fe7f42c51d3c5b76feb91b82d99e4206c.tar.gz bcm5719-llvm-6d39077fe7f42c51d3c5b76feb91b82d99e4206c.zip |
<rdar://problem/12378910> Fix a bunch of other places where similar problems could happen
llvm-svn: 164871
Diffstat (limited to 'lldb/source/Core/CXXFormatterFunctions.cpp')
-rw-r--r-- | lldb/source/Core/CXXFormatterFunctions.cpp | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/lldb/source/Core/CXXFormatterFunctions.cpp b/lldb/source/Core/CXXFormatterFunctions.cpp index 7cf9e37f760..fb0b2bbc58b 100644 --- a/lldb/source/Core/CXXFormatterFunctions.cpp +++ b/lldb/source/Core/CXXFormatterFunctions.cpp @@ -164,6 +164,10 @@ lldb_private::formatters::NSDictionarySummaryProvider (ValueObject& valobj, Stre uint64_t value = 0; const char* class_name = descriptor->GetClassName().GetCString(); + + if (!class_name || !*class_name) + return false; + if (!strcmp(class_name,"__NSDictionaryI")) { Error error; @@ -230,6 +234,10 @@ lldb_private::formatters::NSArraySummaryProvider (ValueObject& valobj, Stream& s uint64_t value = 0; const char* class_name = descriptor->GetClassName().GetCString(); + + if (!class_name || !*class_name) + return false; + if (!strcmp(class_name,"__NSArrayI")) { Error error; @@ -290,6 +298,10 @@ lldb_private::formatters::NSDataSummaryProvider (ValueObject& valobj, Stream& st uint64_t value = 0; const char* class_name = descriptor->GetClassName().GetCString(); + + if (!class_name || !*class_name) + return false; + if (!strcmp(class_name,"NSConcreteData") || !strcmp(class_name,"NSConcreteMutableData") || !strcmp(class_name,"__NSCFData")) @@ -341,6 +353,9 @@ lldb_private::formatters::NSNumberSummaryProvider (ValueObject& valobj, Stream& const char* class_name = descriptor->GetClassName().GetCString(); + if (!class_name || !*class_name) + return false; + if (!strcmp(class_name,"NSNumber") || !strcmp(class_name,"__NSCFNumber")) { if (descriptor->IsTagged()) @@ -979,6 +994,10 @@ SyntheticChildrenFrontEnd* lldb_private::formatters::NSArraySyntheticFrontEndCre return NULL; const char* class_name = descriptor->GetClassName().GetCString(); + + if (!class_name || !*class_name) + return NULL; + if (!strcmp(class_name,"__NSArrayI")) { return (new NSArrayISyntheticFrontEnd(valobj_sp)); @@ -1056,6 +1075,10 @@ SyntheticChildrenFrontEnd* lldb_private::formatters::NSDictionarySyntheticFrontE return NULL; const char* class_name = descriptor->GetClassName().GetCString(); + + if (!class_name || !*class_name) + return NULL; + if (!strcmp(class_name,"__NSDictionaryI")) { return (new NSDictionaryISyntheticFrontEnd(valobj_sp)); |