summaryrefslogtreecommitdiffstats
path: root/lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py
diff options
context:
space:
mode:
authorEnrico Granata <granata.enrico@gmail.com>2012-01-31 17:50:00 +0000
committerEnrico Granata <granata.enrico@gmail.com>2012-01-31 17:50:00 +0000
commit56a27bb5fa309819a333d1d0807ab36dcd9dd193 (patch)
tree1d17d92aac23843d24771528174f6b5ee3e6544f /lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py
parent7e7d0ca1a2f853000671dc636785971178459b2c (diff)
downloadbcm5719-llvm-56a27bb5fa309819a333d1d0807ab36dcd9dd193.tar.gz
bcm5719-llvm-56a27bb5fa309819a333d1d0807ab36dcd9dd193.zip
Splitting test case for Python synthetic children: part 1 test is only testing the synthetic children feature itself. More test cases will be commited for individual STL containers
llvm-svn: 149393
Diffstat (limited to 'lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py')
-rw-r--r--lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py52
1 files changed, 0 insertions, 52 deletions
diff --git a/lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py b/lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py
deleted file mode 100644
index f2b3d442925..00000000000
--- a/lldb/test/functionalities/data-formatter/data-formatter-python-synth/StdVectorSynthProvider.py
+++ /dev/null
@@ -1,52 +0,0 @@
-class StdVectorSynthProvider:
-
- def __init__(self, valobj, dict):
- self.valobj = valobj;
- self.update()
-
- def num_children(self):
- start_val = self.start.GetValueAsUnsigned(0)
- finish_val = self.finish.GetValueAsUnsigned(0)
- end_val = self.end.GetValueAsUnsigned(0)
- # Before a vector has been constructed, it will contain bad values
- # so we really need to be careful about the length we return since
- # unitialized data can cause us to return a huge number. We need
- # to also check for any of the start, finish or end of storage values
- # being zero (NULL). If any are, then this vector has not been
- # initialized yet and we should return zero
-
- # Make sure nothing is NULL
- if start_val == 0 or finish_val == 0 or end_val == 0:
- return 0
- # Make sure start is less than finish
- if start_val >= finish_val:
- return 0
- # Make sure finish is less than or equal to end of storage
- if finish_val > end_val:
- return 0
-
- # We might still get things wrong, so cap things at 256 items for now
- # TODO: read a target "settings set" variable for this to allow it to
- # be customized
- num_children = (finish_val-start_val)/self.data_size
- if num_children > 256:
- return 256
- return num_children
-
- def get_child_index(self,name):
- return int(name.lstrip('[').rstrip(']'))
-
- def get_child_at_index(self,index):
- if index >= self.num_children():
- return None;
- offset = index * self.data_size
- return self.start.CreateChildAtOffset('['+str(index)+']',offset,self.data_type)
-
- def update(self):
- impl = self.valobj.GetChildMemberWithName('_M_impl')
- self.start = impl.GetChildMemberWithName('_M_start')
- self.finish = impl.GetChildMemberWithName('_M_finish')
- self.end = impl.GetChildMemberWithName('_M_end_of_storage')
- self.data_type = self.start.GetType().GetPointeeType()
- self.data_size = self.data_type.GetByteSize()
-
OpenPOWER on IntegriCloud