mirror of
https://github.com/python/cpython.git
synced 2025-10-08 08:01:55 +00:00
Issue #24731: Fixed crash on converting objects with special methods
__bytes__, __trunc__, and __float__ returning instances of subclasses of bytes, int, and float to subclasses of bytes, int, and float correspondingly.
This commit is contained in:
parent
a49de6be36
commit
15095800a3
8 changed files with 50 additions and 10 deletions
|
@ -2445,7 +2445,7 @@ bytes_methods[] = {
|
|||
};
|
||||
|
||||
static PyObject *
|
||||
str_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds);
|
||||
bytes_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds);
|
||||
|
||||
static PyObject *
|
||||
bytes_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||
|
@ -2460,7 +2460,7 @@ bytes_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
|||
_Py_IDENTIFIER(__bytes__);
|
||||
|
||||
if (type != &PyBytes_Type)
|
||||
return str_subtype_new(type, args, kwds);
|
||||
return bytes_subtype_new(type, args, kwds);
|
||||
if (!PyArg_ParseTupleAndKeywords(args, kwds, "|Oss:bytes", kwlist, &x,
|
||||
&encoding, &errors))
|
||||
return NULL;
|
||||
|
@ -2687,7 +2687,7 @@ PyBytes_FromObject(PyObject *x)
|
|||
}
|
||||
|
||||
static PyObject *
|
||||
str_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||
bytes_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||
{
|
||||
PyObject *tmp, *pnew;
|
||||
Py_ssize_t n;
|
||||
|
@ -2696,7 +2696,7 @@ str_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
|||
tmp = bytes_new(&PyBytes_Type, args, kwds);
|
||||
if (tmp == NULL)
|
||||
return NULL;
|
||||
assert(PyBytes_CheckExact(tmp));
|
||||
assert(PyBytes_Check(tmp));
|
||||
n = PyBytes_GET_SIZE(tmp);
|
||||
pnew = type->tp_alloc(type, n);
|
||||
if (pnew != NULL) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue