mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +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
|
@ -1419,25 +1419,36 @@ bytes_richcompare(PyBytesObject *a, PyBytesObject *b, int op)
|
|||
Py_ssize_t len_a, len_b;
|
||||
Py_ssize_t min_len;
|
||||
PyObject *result;
|
||||
int rc;
|
||||
|
||||
/* Make sure both arguments are strings. */
|
||||
if (!(PyBytes_Check(a) && PyBytes_Check(b))) {
|
||||
if (Py_BytesWarningFlag && (op == Py_EQ || op == Py_NE)) {
|
||||
if (PyObject_IsInstance((PyObject*)a,
|
||||
(PyObject*)&PyUnicode_Type) ||
|
||||
PyObject_IsInstance((PyObject*)b,
|
||||
(PyObject*)&PyUnicode_Type)) {
|
||||
rc = PyObject_IsInstance((PyObject*)a,
|
||||
(PyObject*)&PyUnicode_Type);
|
||||
if (!rc)
|
||||
rc = PyObject_IsInstance((PyObject*)b,
|
||||
(PyObject*)&PyUnicode_Type);
|
||||
if (rc < 0)
|
||||
return NULL;
|
||||
if (rc) {
|
||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||
"Comparison between bytes and string", 1))
|
||||
"Comparison between bytes and string", 1))
|
||||
return NULL;
|
||||
}
|
||||
else if (PyObject_IsInstance((PyObject*)a,
|
||||
(PyObject*)&PyLong_Type) ||
|
||||
PyObject_IsInstance((PyObject*)b,
|
||||
(PyObject*)&PyLong_Type)) {
|
||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||
"Comparison between bytes and int", 1))
|
||||
else {
|
||||
rc = PyObject_IsInstance((PyObject*)a,
|
||||
(PyObject*)&PyLong_Type);
|
||||
if (!rc)
|
||||
rc = PyObject_IsInstance((PyObject*)b,
|
||||
(PyObject*)&PyLong_Type);
|
||||
if (rc < 0)
|
||||
return NULL;
|
||||
if (rc) {
|
||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||
"Comparison between bytes and int", 1))
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
}
|
||||
result = Py_NotImplemented;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue