diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2015-03-10 21:35:24 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2015-03-10 21:35:24 (GMT) |
commit | 63afdaa1105de24e87658e82de314a37d341f02b (patch) | |
tree | f9795c023e2737feb82f974f351beff0b665d87d /Objects | |
parent | 12541dc22ef3bbc2469b910eeb8daa4cd5675873 (diff) | |
parent | a654510150cb738b61033c32e30bd4be9f0ed6ed (diff) | |
download | cpython-63afdaa1105de24e87658e82de314a37d341f02b.zip cpython-63afdaa1105de24e87658e82de314a37d341f02b.tar.gz cpython-63afdaa1105de24e87658e82de314a37d341f02b.tar.bz2 |
Issue #23629: Fix the default __sizeof__ implementation for variable-sized objects.
Diffstat (limited to 'Objects')
-rw-r--r-- | Objects/bytesobject.c | 37 | ||||
-rw-r--r-- | Objects/tupleobject.c | 12 | ||||
-rw-r--r-- | Objects/typeobject.c | 2 |
3 files changed, 1 insertions, 50 deletions
diff --git a/Objects/bytesobject.c b/Objects/bytesobject.c index b015974..2ceba48 100644 --- a/Objects/bytesobject.c +++ b/Objects/bytesobject.c @@ -3463,42 +3463,6 @@ bytes_fromhex_impl(PyTypeObject *type, PyObject *string) return NULL; } -/*[clinic input] -bytes.__sizeof__ as bytes_sizeof - - self: self(type="PyBytesObject *") - -Returns the size of the bytes object in memory, in bytes. -[clinic start generated code]*/ - -PyDoc_STRVAR(bytes_sizeof__doc__, -"__sizeof__($self, /)\n" -"--\n" -"\n" -"Returns the size of the bytes object in memory, in bytes."); - -#define BYTES_SIZEOF_METHODDEF \ - {"__sizeof__", (PyCFunction)bytes_sizeof, METH_NOARGS, bytes_sizeof__doc__}, - -static PyObject * -bytes_sizeof_impl(PyBytesObject *self); - -static PyObject * -bytes_sizeof(PyBytesObject *self, PyObject *Py_UNUSED(ignored)) -{ - return bytes_sizeof_impl(self); -} - -static PyObject * -bytes_sizeof_impl(PyBytesObject *self) -/*[clinic end generated code: output=44933279343f24ae input=bee4c64bb42078ed]*/ -{ - Py_ssize_t res; - res = PyBytesObject_SIZE + Py_SIZE(self) * Py_TYPE(self)->tp_itemsize; - return PyLong_FromSsize_t(res); -} - - static PyObject * bytes_getnewargs(PyBytesObject *v) { @@ -3559,7 +3523,6 @@ bytes_methods[] = { BYTES_TRANSLATE_METHODDEF {"upper", (PyCFunction)stringlib_upper, METH_NOARGS, _Py_upper__doc__}, {"zfill", (PyCFunction)stringlib_zfill, METH_VARARGS, zfill__doc__}, - BYTES_SIZEOF_METHODDEF {NULL, NULL} /* sentinel */ }; diff --git a/Objects/tupleobject.c b/Objects/tupleobject.c index e45462b..7efa1a6 100644 --- a/Objects/tupleobject.c +++ b/Objects/tupleobject.c @@ -759,27 +759,15 @@ tuple_getnewargs(PyTupleObject *v) } -static PyObject * -tuple_sizeof(PyTupleObject *self) -{ - Py_ssize_t res; - - res = PyTuple_Type.tp_basicsize + Py_SIZE(self) * sizeof(PyObject *); - return PyLong_FromSsize_t(res); -} - PyDoc_STRVAR(index_doc, "T.index(value, [start, [stop]]) -> integer -- return first index of value.\n" "Raises ValueError if the value is not present." ); PyDoc_STRVAR(count_doc, "T.count(value) -> integer -- return number of occurrences of value"); -PyDoc_STRVAR(sizeof_doc, -"T.__sizeof__() -- size of T in memory, in bytes"); static PyMethodDef tuple_methods[] = { {"__getnewargs__", (PyCFunction)tuple_getnewargs, METH_NOARGS}, - {"__sizeof__", (PyCFunction)tuple_sizeof, METH_NOARGS, sizeof_doc}, {"index", (PyCFunction)tupleindex, METH_VARARGS, index_doc}, {"count", (PyCFunction)tuplecount, METH_O, count_doc}, {NULL, NULL} /* sentinel */ diff --git a/Objects/typeobject.c b/Objects/typeobject.c index be53868..030dc1f 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -4276,7 +4276,7 @@ object_sizeof(PyObject *self, PyObject *args) res = 0; isize = self->ob_type->tp_itemsize; if (isize > 0) - res = Py_SIZE(self->ob_type) * isize; + res = Py_SIZE(self) * isize; res += self->ob_type->tp_basicsize; return PyLong_FromSsize_t(res); |