diff options
| author | Johnny Chen <johnny.chen@apple.com> | 2011-07-26 20:57:10 +0000 |
|---|---|---|
| committer | Johnny Chen <johnny.chen@apple.com> | 2011-07-26 20:57:10 +0000 |
| commit | e33b166da1586296b44d609c9edd1d9d89a4e54e (patch) | |
| tree | 20f82a3d10823913253b856431c7ad2f45b583c4 | |
| parent | 2aedba6c5e18fa3e62a0eca95d50c6ab77abd109 (diff) | |
| download | bcm5719-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.py | 28 | ||||
| -rw-r--r-- | lldb/test/python_api/value/linked_list/TestValueAPILinkedList.py | 36 |
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. |

