]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Issue #23629: Fix the default __sizeof__ implementation for variable-sized objects.
authorAntoine Pitrou <solipsis@pitrou.net>
Tue, 10 Mar 2015 21:32:00 +0000 (22:32 +0100)
committerAntoine Pitrou <solipsis@pitrou.net>
Tue, 10 Mar 2015 21:32:00 +0000 (22:32 +0100)
Misc/NEWS
Objects/tupleobject.c
Objects/typeobject.c

index a1ff5aa3548a8ee16c2b56c7803738ffaa3e99fd..a90db8e39ab58bc24c4fe4c38049601ce9e181b1 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,9 @@ What's New in Python 2.7.10?
 Core and Builtins
 -----------------
 
+- Issue #23629: Fix the default __sizeof__ implementation for variable-sized
+  objects.
+
 - Issue #23055: Fixed a buffer overflow in PyUnicode_FromFormatV.  Analysis
   and fix by Guido Vranken.
 
index a3c185e3e6cffcd5eb9b6814780ca3ab7ec5f1f4..5d72806959d1682383631d3a33d9ae3867124255 100644 (file)
@@ -761,27 +761,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 PyInt_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 */
index 23dda2ac93bad84ba4aca00c6f76faf5373f50d4..6055cd9542d1a9aa149e952c9dabf8dd8aac391e 100644 (file)
@@ -3507,7 +3507,7 @@ object_sizeof(PyObject *self, PyObject *args)
     res = 0;
     isize = self->ob_type->tp_itemsize;
     if (isize > 0)
-        res = self->ob_type->ob_size * isize;
+        res = Py_SIZE(self) * isize;
     res += self->ob_type->tp_basicsize;
 
     return PyInt_FromSsize_t(res);