mirror of
https://github.com/python/cpython.git
synced 2025-07-17 00:05:20 +00:00
Issue #24115: Update uses of PyObject_IsTrue(), PyObject_Not(),
PyObject_IsInstance(), PyObject_RichCompareBool() and _PyDict_Contains() to check for and handle errors correctly.
This commit is contained in:
commit
ac5569b1fa
10 changed files with 92 additions and 40 deletions
|
@ -550,12 +550,13 @@ PyObject * _PyCodec_LookupTextEncoding(const char *encoding,
|
|||
} else {
|
||||
is_text_codec = PyObject_IsTrue(attr);
|
||||
Py_DECREF(attr);
|
||||
if (!is_text_codec) {
|
||||
if (is_text_codec <= 0) {
|
||||
Py_DECREF(codec);
|
||||
PyErr_Format(PyExc_LookupError,
|
||||
"'%.400s' is not a text encoding; "
|
||||
"use %s to handle arbitrary codecs",
|
||||
encoding, alternate_command);
|
||||
if (!is_text_codec)
|
||||
PyErr_Format(PyExc_LookupError,
|
||||
"'%.400s' is not a text encoding; "
|
||||
"use %s to handle arbitrary codecs",
|
||||
encoding, alternate_command);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1366,6 +1366,7 @@ PyImport_ImportModuleLevelObject(PyObject *name, PyObject *given_globals,
|
|||
PyObject *globals = NULL;
|
||||
PyObject *fromlist = NULL;
|
||||
PyInterpreterState *interp = PyThreadState_GET()->interp;
|
||||
int has_from;
|
||||
|
||||
/* Make sure to use default values so as to not have
|
||||
PyObject_CallMethodObjArgs() truncate the parameter list because of a
|
||||
|
@ -1596,7 +1597,10 @@ PyImport_ImportModuleLevelObject(PyObject *name, PyObject *given_globals,
|
|||
}
|
||||
/* From now on we don't hold the import lock anymore. */
|
||||
|
||||
if (PyObject_Not(fromlist)) {
|
||||
has_from = PyObject_IsTrue(fromlist);
|
||||
if (has_from < 0)
|
||||
goto error;
|
||||
if (!has_from) {
|
||||
if (level == 0 || PyUnicode_GET_LENGTH(name) > 0) {
|
||||
PyObject *front = NULL;
|
||||
PyObject *partition = NULL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue