Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Gwenaël Samain
cython
Commits
e325fbee
Commit
e325fbee
authored
Dec 14, 2010
by
Mark Florisson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Detect Python exceptions
parent
da24fe31
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
35 additions
and
16 deletions
+35
-16
Cython/Debugger/libcython.py
Cython/Debugger/libcython.py
+6
-3
Cython/Debugger/libpython.py
Cython/Debugger/libpython.py
+29
-13
No files found.
Cython/Debugger/libcython.py
View file @
e325fbee
...
...
@@ -835,7 +835,7 @@ class CyBreak(CythonCommand):
return
compl
class
CythonInfo
(
CythonBase
,
libpython
.
Language
Info
):
class
CythonInfo
(
CythonBase
,
libpython
.
Python
Info
):
"""
Implementation of the interface dictated by libpython.LanguageInfo.
"""
...
...
@@ -847,8 +847,7 @@ class CythonInfo(CythonBase, libpython.LanguageInfo):
# related code. The C level should be dispatched to the 'step' command.
if
self
.
is_cython_function
(
frame
):
return
self
.
get_cython_lineno
(
frame
)
else
:
return
libpython
.
py_step
.
lang_info
.
lineno
(
frame
)
return
super
(
CythonInfo
,
self
).
lineno
(
frame
)
def
get_source_line
(
self
,
frame
):
try
:
...
...
@@ -858,6 +857,10 @@ class CythonInfo(CythonBase, libpython.LanguageInfo):
else
:
return
line
.
strip
()
or
None
def
exc_info
(
self
,
frame
):
if
self
.
is_python_function
:
return
super
(
CythonInfo
,
self
).
exc_info
(
frame
)
def
runtime_break_functions
(
self
):
if
self
.
is_cython_function
():
return
self
.
get_cython_function
().
step_into_functions
...
...
Cython/Debugger/libpython.py
View file @
e325fbee
...
...
@@ -369,8 +369,8 @@ class PyObjectPtr(object):
if
tp_name
in
name_map
:
return
name_map
[
tp_name
]
if
tp_flags
&
Py_TPFLAGS_HEAPTYPE
:
return
Heap
TypeObjectPtr
if
tp_flags
&
(
Py_TPFLAGS_HEAPTYPE
|
Py_TPFLAGS_TYPE_SUBCLASS
)
:
return
Py
TypeObjectPtr
if
tp_flags
&
Py_TPFLAGS_INT_SUBCLASS
:
return
PyIntObjectPtr
...
...
@@ -392,8 +392,6 @@ class PyObjectPtr(object):
return
PyDictObjectPtr
if
tp_flags
&
Py_TPFLAGS_BASE_EXC_SUBCLASS
:
return
PyBaseExceptionObjectPtr
#if tp_flags & Py_TPFLAGS_TYPE_SUBCLASS:
# return PyTypeObjectPtr
# Use the base class:
return
cls
...
...
@@ -484,8 +482,8 @@ def _PyObject_VAR_SIZE(typeobj, nitems):
)
&
~
(
SIZEOF_VOID_P
-
1
)
).
cast
(
gdb
.
lookup_type
(
'size_t'
))
class
Heap
TypeObjectPtr
(
PyObjectPtr
):
_typename
=
'PyObject'
class
Py
TypeObjectPtr
(
PyObjectPtr
):
_typename
=
'Py
Type
Object'
def
get_attr_dict
(
self
):
'''
...
...
@@ -545,10 +543,17 @@ class HeapTypeObjectPtr(PyObjectPtr):
out
.
write
(
'<...>'
)
return
visited
.
add
(
self
.
as_address
())
pyop_attrdict
=
self
.
get_attr_dict
()
_write_instance_repr
(
out
,
visited
,
self
.
safe_tp_name
(),
pyop_attrdict
,
self
.
as_address
())
try
:
tp_name
=
self
.
field
(
'tp_name'
).
string
()
except
RuntimeError
:
tp_name
=
'unknown'
out
.
write
(
'<type %s at remote 0x%x>'
%
(
tp_name
,
self
.
as_address
()))
# pyop_attrdict = self.get_attr_dict()
# _write_instance_repr(out, visited,
# self.safe_tp_name(), pyop_attrdict, self.as_address())
class
ProxyException
(
Exception
):
def
__init__
(
self
,
tp_name
,
args
):
...
...
@@ -1136,9 +1141,6 @@ class PyTupleObjectPtr(PyObjectPtr):
else
:
out
.
write
(
')'
)
class
PyTypeObjectPtr
(
PyObjectPtr
):
_typename
=
'PyTypeObject'
def
_unichr_is_printable
(
char
):
# Logic adapted from Python 3's Tools/unicode/makeunicodedata.py
...
...
@@ -2171,6 +2173,20 @@ class PythonInfo(LanguageInfo):
except IOError, e:
return None
def exc_info(self, frame):
try:
tstate = frame.read_var('
tstate
').dereference()
if gdb.parse_and_eval('
tstate
->
frame
==
f'):
# tstate local variable initialized
inf_type = tstate['
curexc_type
']
inf_value = tstate['
curexc_value
']
if inf_type:
return '
An
exception
was
raised
:
%
s
(
%
s
)
' % (inf_type,
inf_value)
except (ValueError, RuntimeError), e:
# Could not read the variable tstate or it'
s
memory
,
it
's ok
pass
def static_break_functions(self):
yield '
PyEval_EvalFrameEx
'
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment