diff options
author | Enrico Granata <egranata@apple.com> | 2012-03-05 19:56:33 +0000 |
---|---|---|
committer | Enrico Granata <egranata@apple.com> | 2012-03-05 19:56:33 +0000 |
commit | cfdafa37b4d3552268a92d7dfd107ed92d3dca51 (patch) | |
tree | 92e111d6a1450a643d22c851f599a0e4e3a567ae /lldb/examples/summaries/cocoa/CFBag.py | |
parent | 35e2ab60397ec15d9a2ce31ad71614ecc62f34b6 (diff) | |
download | bcm5719-llvm-cfdafa37b4d3552268a92d7dfd107ed92d3dca51.tar.gz bcm5719-llvm-cfdafa37b4d3552268a92d7dfd107ed92d3dca51.zip |
Several performance-oriented changes to the introspecting data formatters:
(a) the SystemParameters object is now passed around to the formatters; doing so enables the formatters to reuse computed values for things such as pointer-size and endianness
instead of repeatedly computing these on their own
(b) replacing the global ISA cache with a per-process one
(c) providing a per-process types cache where each formatter can store the types it needs to operate, and be sure to find them the next time without recalculating them
this also enables formatters to share types if they agree on a local naming convention
(d) lazy fetching of data from Objective-C runtime data structures
data is fetched as needed and we stop reading as soon as we determine that an ISA is actually garbage
llvm-svn: 152052
Diffstat (limited to 'lldb/examples/summaries/cocoa/CFBag.py')
-rw-r--r-- | lldb/examples/summaries/cocoa/CFBag.py | 37 |
1 files changed, 17 insertions, 20 deletions
diff --git a/lldb/examples/summaries/cocoa/CFBag.py b/lldb/examples/summaries/cocoa/CFBag.py index 1403a122eb6..2db70ab603c 100644 --- a/lldb/examples/summaries/cocoa/CFBag.py +++ b/lldb/examples/summaries/cocoa/CFBag.py @@ -15,27 +15,26 @@ statistics.add_metric('code_notrun') # obey the interface specification for synthetic children providers class CFBagRef_SummaryProvider: def adjust_for_architecture(self): - self.is_64_bit = (self.valobj.GetTarget().GetProcess().GetAddressByteSize() == 8) - self.is_little = (self.valobj.GetTarget().GetProcess().GetByteOrder() == lldb.eByteOrderLittle) - self.pointer_size = self.valobj.GetTarget().GetProcess().GetAddressByteSize() + pass - def __init__(self, valobj): + def __init__(self, valobj, params): self.valobj = valobj; + self.sys_params = params + if not(self.sys_params.types_cache.NSUInteger): + if self.sys_params.is_64_bit: + self.sys_params.types_cache.NSUInteger = self.valobj.GetType().GetBasicType(lldb.eBasicTypeUnsignedLong) + else: + self.sys_params.types_cache.NSUInteger = self.valobj.GetType().GetBasicType(lldb.eBasicTypeUnsignedInt) self.update(); def update(self): self.adjust_for_architecture(); - self.id_type = self.valobj.GetType().GetBasicType(lldb.eBasicTypeObjCID) - if self.is_64_bit: - self.NSUInteger = self.valobj.GetType().GetBasicType(lldb.eBasicTypeUnsignedLong) - else: - self.NSUInteger = self.valobj.GetType().GetBasicType(lldb.eBasicTypeUnsignedInt) # 12 bytes on i386 # 20 bytes on x64 # most probably 2 pointers and 4 bytes of data def offset(self): - if self.is_64_bit: + if self.sys_params.is_64_bit: return 20 else: return 12 @@ -43,23 +42,21 @@ class CFBagRef_SummaryProvider: def length(self): size = self.valobj.CreateChildAtOffset("count", self.offset(), - self.NSUInteger) + self.sys_params.types_cache.NSUInteger) return size.GetValueAsUnsigned(0) class CFBagUnknown_SummaryProvider: def adjust_for_architecture(self): - self.is_64_bit = (self.valobj.GetTarget().GetProcess().GetAddressByteSize() == 8) - self.is_little = (self.valobj.GetTarget().GetProcess().GetByteOrder() == lldb.eByteOrderLittle) - self.pointer_size = self.valobj.GetTarget().GetProcess().GetAddressByteSize() + pass - def __init__(self, valobj): + def __init__(self, valobj, params): self.valobj = valobj; - self.update() + self.sys_params = params + self.update(); def update(self): self.adjust_for_architecture(); - self.id_type = self.valobj.GetType().GetBasicType(lldb.eBasicTypeObjCID) def length(self): stream = lldb.SBStream() @@ -98,10 +95,10 @@ def GetSummary_Impl(valobj): actual_name = pointee_type.GetName() if actual_name == '__CFBag' or \ actual_name == 'const struct __CFBag': - wrapper = CFBagRef_SummaryProvider(valobj) + wrapper = CFBagRef_SummaryProvider(valobj, class_data.sys_params) statistics.metric_hit('code_notrun',valobj) return wrapper - wrapper = CFBagUnknown_SummaryProvider(valobj) + wrapper = CFBagUnknown_SummaryProvider(valobj, class_data.sys_params) statistics.metric_hit('unknown_class',str(valobj) + " seen as " + actual_name) return wrapper; @@ -120,7 +117,7 @@ def CFBag_SummaryProvider (valobj,dict): if summary == None: summary = 'no valid set here' else: - if provider.is_64_bit: + if provider.sys_params.is_64_bit: summary = summary & ~0x1fff000000000000 if summary == 1: return '1 item' |