summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohnny Chen <johnny.chen@apple.com>2011-07-26 20:57:10 +0000
committerJohnny Chen <johnny.chen@apple.com>2011-07-26 20:57:10 +0000
commite33b166da1586296b44d609c9edd1d9d89a4e54e (patch)
tree20f82a3d10823913253b856431c7ad2f45b583c4
parent2aedba6c5e18fa3e62a0eca95d50c6ab77abd109 (diff)
downloadbcm5719-llvm-e33b166da1586296b44d609c9edd1d9d89a4e54e.tar.gz
bcm5719-llvm-e33b166da1586296b44d609c9edd1d9d89a4e54e.zip
We can do better with the SBValue.linked_list_iter() API by supplying a default
end of list test function as __eol_test__. The simple example can be reduced to: for t in task_head.linked_list_iter('next'): print t Modify the test program to exercise the API for both cases: supplying or not supplying an end of list test function. llvm-svn: 136144
-rw-r--r--lldb/scripts/Python/modify-python-lldb.py28
-rw-r--r--lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py36
2 files changed, 42 insertions, 22 deletions
diff --git a/lldb/scripts/Python/modify-python-lldb.py b/lldb/scripts/Python/modify-python-lldb.py
index 3a784a6e74c..3cd312638bf 100644
--- a/lldb/scripts/Python/modify-python-lldb.py
+++ b/lldb/scripts/Python/modify-python-lldb.py
@@ -89,10 +89,21 @@ def lldb_iter(obj, getsize, getelem):
# which takes an SBValue and returns True if EOL is reached and False if not.
#
linked_list_iter_def = '''
+ def __eol_test__(val):
+ """Default function for end of list test takes an SBValue object.
+
+ Return True if val is invalid or it corresponds to a null pointer.
+ Otherwise, return False.
+ """
+ if not val or int(val.GetValue(), 0) == 0:
+ return True
+ else:
+ return False
+
# ==================================================
# Iterator for lldb.SBValue treated as a linked list
# ==================================================
- def linked_list_iter(self, next_item_name, end_of_list_test):
+ def linked_list_iter(self, next_item_name, end_of_list_test=__eol_test__):
"""Generator adaptor to support iteration for SBValue as a linked list.
linked_list_iter() is a special purpose iterator to treat the SBValue as
@@ -101,17 +112,10 @@ linked_list_iter_def = '''
end-of-list test function which takes an SBValue for an item and returns
True if EOL is reached and False if not.
- For example,
-
- def eol(val):
- \'\'\'Test function to determine end of list.\'\'\'
- # End of list is reached if either the value object is invalid
- # or it corresponds to a null pointer.
- if not val or int(val.GetValue(), 16) == 0:
- return True
+ The end_of_list_test arg, if omitted, defaults to the __eol_test__
+ function above.
- # Otherwise, return False.
- return False
+ For example,
# Get Frame #0.
...
@@ -120,7 +124,7 @@ linked_list_iter_def = '''
task_head = frame0.FindVariable('task_head')
...
- for t in task_head.linked_list_iter('next', eol):
+ for t in task_head.linked_list_iter('next'):
print t
"""
try:
diff --git a/lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py b/lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py
index d915f99d29a..6456a2ea380 100644
--- a/lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py
+++ b/lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py
@@ -54,16 +54,6 @@ class ValueAsLinkedListTestCase(TestBase):
process = target.LaunchSimple(None, None, os.getcwd())
self.assertTrue(process, PROCESS_IS_VALID)
- def eol(val):
- """Test function to determine end of list."""
- # End of list is reached if either the value object is invalid
- # or it corresponds to a null pointer.
- if not val or int(val.GetValue(), 16) == 0:
- return True
-
- # Otherwise, return False.
- return False
-
# Get Frame #0.
self.assertTrue(process.GetState() == lldb.eStateStopped)
thread = lldbutil.get_stopped_thread(process, lldb.eStopReasonBreakpoint)
@@ -80,6 +70,32 @@ class ValueAsLinkedListTestCase(TestBase):
list = []
cvf = lldbutil.ChildVisitingFormatter(indent_child=2)
+ for t in task_head.linked_list_iter('next'):
+ self.assertTrue(t, VALID_VARIABLE)
+ # Make sure that 'next' corresponds to an SBValue with pointer type.
+ self.assertTrue(t.TypeIsPointerType())
+ if self.TraceOn():
+ print cvf.format(t)
+ list.append(int(t.GetChildMemberWithName("id").GetValue()))
+
+ # Sanity checks that the we visited all the items (no more, no less).
+ if self.TraceOn():
+ print "visited IDs:", list
+ self.assertTrue(visitedIDs == list)
+
+ # Let's exercise the linked_list_iter() API again, this time supplying
+ # our end of list test function.
+ def eol(val):
+ """Test function to determine end of list."""
+ # End of list is reached if either the value object is invalid
+ # or it corresponds to a null pointer.
+ if not val or int(val.GetValue(), 16) == 0:
+ return True
+
+ # Otherwise, return False.
+ return False
+
+ list = []
for t in task_head.linked_list_iter('next', eol):
self.assertTrue(t, VALID_VARIABLE)
# Make sure that 'next' corresponds to an SBValue with pointer type.
OpenPOWER on IntegriCloud