diff options
Diffstat (limited to 'gdb/python')
-rw-r--r-- | gdb/python/lib/gdb/FrameDecorator.py | 9 | ||||
-rw-r--r-- | gdb/python/lib/gdb/FrameIterator.py | 6 | ||||
-rw-r--r-- | gdb/python/lib/gdb/command/frame_filters.py | 5 | ||||
-rw-r--r-- | gdb/python/lib/gdb/frames.py | 33 | ||||
-rw-r--r-- | gdb/python/py-framefilter.c | 10 |
5 files changed, 43 insertions, 20 deletions
diff --git a/gdb/python/lib/gdb/FrameDecorator.py b/gdb/python/lib/gdb/FrameDecorator.py index cacab4d..4e9cd7a 100644 --- a/gdb/python/lib/gdb/FrameDecorator.py +++ b/gdb/python/lib/gdb/FrameDecorator.py @@ -15,6 +15,15 @@ import gdb +# This small code snippet deals with problem of strings in Python 2.x +# and Python 3.x. Python 2.x has str and unicode classes which are +# sub-classes of basestring. In Python 3.x all strings are encoded +# and basestring has been removed. +try: + basestring +except NameError: + basestring = str + class FrameDecorator(object): """Basic implementation of a Frame Decorator""" diff --git a/gdb/python/lib/gdb/FrameIterator.py b/gdb/python/lib/gdb/FrameIterator.py index b3af94b..3f33bbb 100644 --- a/gdb/python/lib/gdb/FrameIterator.py +++ b/gdb/python/lib/gdb/FrameIterator.py @@ -43,3 +43,9 @@ class FrameIterator(object): raise StopIteration self.frame = result.older() return result + + # Python 3.x requires __next__(self) while Python 2.x requires + # next(self). Define next(self), and for Python 3.x create this + # wrapper. + def __next__(self): + return self.next() diff --git a/gdb/python/lib/gdb/command/frame_filters.py b/gdb/python/lib/gdb/command/frame_filters.py index 1b73059..b5d34ad 100644 --- a/gdb/python/lib/gdb/command/frame_filters.py +++ b/gdb/python/lib/gdb/command/frame_filters.py @@ -335,7 +335,10 @@ class SetFrameFilterPriority(gdb.Command): list_op = command_tuple[0] frame_filter = command_tuple[1] - priority = command_tuple[2] + + # GDB returns arguments as a string, so convert priority to + # a number. + priority = int(command_tuple[2]) op_list = gdb.frames.return_list(list_op) diff --git a/gdb/python/lib/gdb/frames.py b/gdb/python/lib/gdb/frames.py index 10dce8e..c148b98 100644 --- a/gdb/python/lib/gdb/frames.py +++ b/gdb/python/lib/gdb/frames.py @@ -108,13 +108,15 @@ def return_list(name): # cannot return a combined dictionary as keys() may clash in # between different dictionaries. As we just want all the frame # filters to enable/disable them all, just return the combined - # items() as a list. + # items() as a chained iterator of dictionary values. if name == "all": - all_dicts = gdb.frame_filters.values() - all_dicts = all_dicts + gdb.current_progspace().frame_filters.values() + glob = gdb.frame_filters.values() + prog = gdb.current_progspace().frame_filters.values() + return_iter = itertools.chain(glob, prog) for objfile in gdb.objfiles(): - all_dicts = all_dicts + objfile.frame_filters.values() - return all_dicts + return_iter = itertools.chain(return_iter, objfile.frame_filters.values()) + + return return_iter if name == "global": return gdb.frame_filters @@ -140,14 +142,7 @@ def _sort_list(): execute. """ - all_filters = [] - for objfile in gdb.objfiles(): - all_filters = all_filters + objfile.frame_filters.values() - cp = gdb.current_progspace() - - all_filters = all_filters + cp.frame_filters.values() - all_filters = all_filters + gdb.frame_filters.values() - + all_filters = return_list("all") sorted_frame_filters = sorted(all_filters, key = get_priority, reverse = True) @@ -180,7 +175,7 @@ def execute_frame_filters(frame, frame_low, frame_high): """ # Get a sorted list of frame filters. - sorted_list = _sort_list() + sorted_list = list(_sort_list()) # Check to see if there are any frame-filters. If not, just # return None and let default backtrace printing occur. @@ -189,9 +184,13 @@ def execute_frame_filters(frame, frame_low, frame_high): frame_iterator = FrameIterator(frame) - # Apply a basic frame decorator to all gdb.Frames. This unifies the - # interface. - frame_iterator = itertools.imap(FrameDecorator, frame_iterator) + # Apply a basic frame decorator to all gdb.Frames. This unifies + # the interface. Python 3.x moved the itertools.imap + # functionality to map(), so check if it is available. + if hasattr(itertools,"imap"): + frame_iterator = itertools.imap(FrameDecorator, frame_iterator) + else: + frame_iterator = map(FrameDecorator, frame_iterator) for ff in sorted_list: frame_iterator = ff.filter(frame_iterator) diff --git a/gdb/python/py-framefilter.c b/gdb/python/py-framefilter.c index 5ac8e47..871c245 100644 --- a/gdb/python/py-framefilter.c +++ b/gdb/python/py-framefilter.c @@ -1170,13 +1170,17 @@ py_print_frame (PyObject *filter, int flags, enum py_frame_args args_type, if (gdbpy_is_string (py_func)) { - function = PyString_AsString (py_func); + char *function_to_free = NULL; + + function = function_to_free = + python_string_to_host_string (py_func); if (function == NULL) { Py_DECREF (py_func); goto error; } + make_cleanup (xfree, function_to_free); } else if (PyLong_Check (py_func)) { @@ -1251,13 +1255,15 @@ py_print_frame (PyObject *filter, int flags, enum py_frame_args args_type, { if (py_fn != Py_None) { - char *filename = PyString_AsString (py_fn); + char *filename = python_string_to_host_string (py_fn); if (filename == NULL) { Py_DECREF (py_fn); goto error; } + + make_cleanup (xfree, filename); TRY_CATCH (except, RETURN_MASK_ALL) { ui_out_wrap_hint (out, " "); |