diff options
| author | Ćukasz Langa <lukasz@langa.pl> | 2017-08-22 13:20:40 -0700 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-08-22 13:20:40 -0700 | 
| commit | 8e572491b59c2334723bfd7411ab2a9fbd100f70 (patch) | |
| tree | ba579b9969c2f96b52984663a71a3587d86709c2 /Tools/gdb/libpython.py | |
| parent | 680f04a926bce04e4320ba883068c345eba502a6 (diff) | |
| download | cpython-git-8e572491b59c2334723bfd7411ab2a9fbd100f70.tar.gz | |
[3.6] bpo-30983: [gdb] Fix py-bt, etc. for non-debug shared builds (GH-3153) (#3192)
PEP 523 introduced _PyEval_EvalFrameDefault which inlines PyEval_EvalFrameEx on
non-debug shared builds.  This breaks the ability to use py-bt, py-up, and
a few other Python-specific gdb integrations.
This patch fixes the problem by only looking for _PyEval_EvalFrameDefault
frames.
test_gdb passes on both a debug and a non-debug build.
Original patch by Bruno "Polaco" Penteado.
(cherry picked from commit 5fe59f8e3a0a56a155c18f9d581205ec533764b6)
Diffstat (limited to 'Tools/gdb/libpython.py')
| -rwxr-xr-x | Tools/gdb/libpython.py | 20 | 
1 files changed, 11 insertions, 9 deletions
| diff --git a/Tools/gdb/libpython.py b/Tools/gdb/libpython.py index 31ae8117c7..aac9b5c1b8 100755 --- a/Tools/gdb/libpython.py +++ b/Tools/gdb/libpython.py @@ -99,6 +99,8 @@ hexdigits = "0123456789abcdef"  ENCODING = locale.getpreferredencoding() +EVALFRAME = '_PyEval_EvalFrameDefault' +  class NullPyObjectPtr(RuntimeError):      pass @@ -1492,18 +1494,18 @@ class Frame(object):      #   - everything else      def is_python_frame(self): -        '''Is this a PyEval_EvalFrameEx frame, or some other important +        '''Is this a _PyEval_EvalFrameDefault frame, or some other important          frame? (see is_other_python_frame for what "important" means in this          context)''' -        if self.is_evalframeex(): +        if self.is_evalframe():              return True          if self.is_other_python_frame():              return True          return False -    def is_evalframeex(self): -        '''Is this a PyEval_EvalFrameEx frame?''' -        if self._gdbframe.name() == 'PyEval_EvalFrameEx': +    def is_evalframe(self): +        '''Is this a _PyEval_EvalFrameDefault frame?''' +        if self._gdbframe.name() == EVALFRAME:              '''              I believe we also need to filter on the inline              struct frame_id.inline_depth, only regarding frames with @@ -1512,7 +1514,7 @@ class Frame(object):              So we reject those with type gdb.INLINE_FRAME              '''              if self._gdbframe.type() == gdb.NORMAL_FRAME: -                # We have a PyEval_EvalFrameEx frame: +                # We have a _PyEval_EvalFrameDefault frame:                  return True          return False @@ -1631,7 +1633,7 @@ class Frame(object):          frame = cls.get_selected_frame()          while frame: -            if frame.is_evalframeex(): +            if frame.is_evalframe():                  return frame              frame = frame.older() @@ -1639,7 +1641,7 @@ class Frame(object):          return None      def print_summary(self): -        if self.is_evalframeex(): +        if self.is_evalframe():              pyop = self.get_pyop()              if pyop:                  line = pyop.get_truncated_repr(MAX_OUTPUT_LEN) @@ -1658,7 +1660,7 @@ class Frame(object):                  sys.stdout.write('#%i\n' % self.get_index())      def print_traceback(self): -        if self.is_evalframeex(): +        if self.is_evalframe():              pyop = self.get_pyop()              if pyop:                  pyop.print_traceback() | 
