mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
gh-108511: Add C API functions which do not silently ignore errors (GH-109025)
Add the following functions: * PyObject_HasAttrWithError() * PyObject_HasAttrStringWithError() * PyMapping_HasKeyWithError() * PyMapping_HasKeyStringWithError()
This commit is contained in:
parent
e57ecf6bbc
commit
add16f1a5e
28 changed files with 330 additions and 111 deletions
|
@ -1776,13 +1776,11 @@ PyErr_SyntaxLocationObjectEx(PyObject *filename, int lineno, int col_offset,
|
|||
}
|
||||
}
|
||||
if ((PyObject *)Py_TYPE(exc) != PyExc_SyntaxError) {
|
||||
if (PyObject_GetOptionalAttr(exc, &_Py_ID(msg), &tmp) < 0) {
|
||||
int rc = PyObject_HasAttrWithError(exc, &_Py_ID(msg));
|
||||
if (rc < 0) {
|
||||
_PyErr_Clear(tstate);
|
||||
}
|
||||
else if (tmp) {
|
||||
Py_DECREF(tmp);
|
||||
}
|
||||
else {
|
||||
else if (!rc) {
|
||||
tmp = PyObject_Str(exc);
|
||||
if (tmp) {
|
||||
if (PyObject_SetAttr(exc, &_Py_ID(msg), tmp)) {
|
||||
|
@ -1795,13 +1793,11 @@ PyErr_SyntaxLocationObjectEx(PyObject *filename, int lineno, int col_offset,
|
|||
}
|
||||
}
|
||||
|
||||
if (PyObject_GetOptionalAttr(exc, &_Py_ID(print_file_and_line), &tmp) < 0) {
|
||||
rc = PyObject_HasAttrWithError(exc, &_Py_ID(print_file_and_line));
|
||||
if (rc < 0) {
|
||||
_PyErr_Clear(tstate);
|
||||
}
|
||||
else if (tmp) {
|
||||
Py_DECREF(tmp);
|
||||
}
|
||||
else {
|
||||
else if (!rc) {
|
||||
if (PyObject_SetAttr(exc, &_Py_ID(print_file_and_line), Py_None)) {
|
||||
_PyErr_Clear(tstate);
|
||||
}
|
||||
|
|
|
@ -2887,12 +2887,11 @@ PyImport_ImportModuleLevelObject(PyObject *name, PyObject *globals,
|
|||
}
|
||||
}
|
||||
else {
|
||||
PyObject *path;
|
||||
if (PyObject_GetOptionalAttr(mod, &_Py_ID(__path__), &path) < 0) {
|
||||
int has_path = PyObject_HasAttrWithError(mod, &_Py_ID(__path__));
|
||||
if (has_path < 0) {
|
||||
goto error;
|
||||
}
|
||||
if (path) {
|
||||
Py_DECREF(path);
|
||||
if (has_path) {
|
||||
final_mod = PyObject_CallMethodObjArgs(
|
||||
IMPORTLIB(interp), &_Py_ID(_handle_fromlist),
|
||||
mod, fromlist, IMPORT_FUNC(interp), NULL);
|
||||
|
|
|
@ -245,14 +245,12 @@ get_suggestions_for_name_error(PyObject* name, PyFrameObject* frame)
|
|||
goto error;
|
||||
}
|
||||
|
||||
PyObject *value;
|
||||
res = PyObject_GetOptionalAttr(self, name, &value);
|
||||
res = PyObject_HasAttrWithError(self, name);
|
||||
Py_DECREF(locals);
|
||||
if (res < 0) {
|
||||
goto error;
|
||||
}
|
||||
if (value) {
|
||||
Py_DECREF(value);
|
||||
if (res) {
|
||||
Py_DECREF(dir);
|
||||
return PyUnicode_FromFormat("self.%U", name);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue