mirror of
https://github.com/python/cpython.git
synced 2025-07-07 19:35:27 +00:00
gh-109179: Fix traceback display for SyntaxErrors with notes (#109197)
This commit is contained in:
parent
de5f8f7d13
commit
ecd21a629a
3 changed files with 30 additions and 30 deletions
|
@ -1125,21 +1125,16 @@ error:
|
|||
}
|
||||
|
||||
static int
|
||||
print_exception_notes(struct exception_print_context *ctx, PyObject *value)
|
||||
print_exception_notes(struct exception_print_context *ctx, PyObject *notes)
|
||||
{
|
||||
PyObject *f = ctx->file;
|
||||
|
||||
if (!PyExceptionInstance_Check(value)) {
|
||||
if (notes == NULL) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
PyObject *notes;
|
||||
int res = PyObject_GetOptionalAttr(value, &_Py_ID(__notes__), ¬es);
|
||||
if (res <= 0) {
|
||||
return res;
|
||||
}
|
||||
if (!PySequence_Check(notes) || PyUnicode_Check(notes) || PyBytes_Check(notes)) {
|
||||
res = 0;
|
||||
int res = 0;
|
||||
if (write_indented_margin(ctx, f) < 0) {
|
||||
res = -1;
|
||||
}
|
||||
|
@ -1152,7 +1147,6 @@ print_exception_notes(struct exception_print_context *ctx, PyObject *value)
|
|||
res = PyFile_WriteObject(s, f, Py_PRINT_RAW);
|
||||
Py_DECREF(s);
|
||||
}
|
||||
Py_DECREF(notes);
|
||||
if (PyFile_WriteString("\n", f) < 0) {
|
||||
res = -1;
|
||||
}
|
||||
|
@ -1197,17 +1191,16 @@ print_exception_notes(struct exception_print_context *ctx, PyObject *value)
|
|||
}
|
||||
}
|
||||
|
||||
Py_DECREF(notes);
|
||||
return 0;
|
||||
error:
|
||||
Py_XDECREF(lines);
|
||||
Py_DECREF(notes);
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int
|
||||
print_exception(struct exception_print_context *ctx, PyObject *value)
|
||||
{
|
||||
PyObject *notes = NULL;
|
||||
PyObject *f = ctx->file;
|
||||
|
||||
if (!PyExceptionInstance_Check(value)) {
|
||||
|
@ -1221,8 +1214,11 @@ print_exception(struct exception_print_context *ctx, PyObject *value)
|
|||
goto error;
|
||||
}
|
||||
|
||||
/* grab the type now because value can change below */
|
||||
/* grab the type and notes now because value can change below */
|
||||
PyObject *type = (PyObject *) Py_TYPE(value);
|
||||
if (PyObject_GetOptionalAttr(value, &_Py_ID(__notes__), ¬es) < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (print_exception_file_and_line(ctx, &value) < 0) {
|
||||
goto error;
|
||||
|
@ -1236,14 +1232,16 @@ print_exception(struct exception_print_context *ctx, PyObject *value)
|
|||
if (PyFile_WriteString("\n", f) < 0) {
|
||||
goto error;
|
||||
}
|
||||
if (print_exception_notes(ctx, value) < 0) {
|
||||
if (print_exception_notes(ctx, notes) < 0) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
Py_XDECREF(notes);
|
||||
Py_DECREF(value);
|
||||
assert(!PyErr_Occurred());
|
||||
return 0;
|
||||
error:
|
||||
Py_XDECREF(notes);
|
||||
Py_DECREF(value);
|
||||
return -1;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue