
* python/py-framefilter.c (py_print_frame): Remove usage of PyString_AsString. Use python_string_to_host_string instead. Refactor function to work with a string as a new allocation instead of a pointer. (py_print_frame): Ditto. * python/lib/gdb/frames.py (return_list): Cain iterators together instead of adding them as a list. (_sort_list): Call return_list, and remove duplicate code. (execute_frame_filters): Convert iterator to a list with list(). * python/lib/gdb/command/frame_filters.py (SetFrameFilterPriority._set_filter_priority): Convert priority attribute to an integer. * python/lib/gdb/FrameIterator.py (FrameIterator.next): Define wrapper function __next__. * python/lib/gdb/FrameDecorator.py: If basestring not defined, define as "str". 2013-08-29 Phil Muldoon <pmuldoon@redhat.com> * gdb.python/py-framefilter.py (FrameFilter.filter): Check itertools for imap attribute. Otherwise use map(). (ElidingIterator): Define wrapper function __next__. * gdb.python/py-framefilter-mi.exp: Do not use execfile, use exec (open (read ())) instead. * gdb.python/py-framefilter.exp: Ditto. * gdb.python/py-arch.exp: Update print based test to Python 3.x compliance. * gdb.python/py-frame.exp: Ditto. * gdb.python/py-type.exp: Ditto.
51 lines
1.5 KiB
Python
51 lines
1.5 KiB
Python
# Copyright (C) 2013 Free Software Foundation, Inc.
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
import gdb
|
|
import itertools
|
|
|
|
class FrameIterator(object):
|
|
"""A gdb.Frame iterator. Iterates over gdb.Frames or objects that
|
|
conform to that interface."""
|
|
|
|
def __init__(self, frame_obj):
|
|
"""Initialize a FrameIterator.
|
|
|
|
Arguments:
|
|
frame_obj the starting frame."""
|
|
|
|
super(FrameIterator, self).__init__()
|
|
self.frame = frame_obj
|
|
|
|
def __iter__(self):
|
|
return self
|
|
|
|
def next(self):
|
|
"""next implementation.
|
|
|
|
Returns:
|
|
The next oldest frame."""
|
|
|
|
result = self.frame
|
|
if result is None:
|
|
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()
|