Kaydet (Commit) 73e9ffc8 authored tarafından Robert Schuppenies's avatar Robert Schuppenies

Fixed: sys.getsizeof does not take the actual length of the tuples into account.

üst 60c0be3a
...@@ -567,6 +567,9 @@ class SizeofTest(unittest.TestCase): ...@@ -567,6 +567,9 @@ class SizeofTest(unittest.TestCase):
# string # string
self.check_sizeof('', h + l + self.align(i + 1)) self.check_sizeof('', h + l + self.align(i + 1))
self.check_sizeof('abc', h + l + self.align(i + 1) + 3) self.check_sizeof('abc', h + l + self.align(i + 1) + 3)
# tuple
self.check_sizeof((), h)
self.check_sizeof((1,2,3), h + 3*p)
def test_main(): def test_main():
......
...@@ -708,13 +708,25 @@ tuple_getnewargs(PyTupleObject *v) ...@@ -708,13 +708,25 @@ 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, PyDoc_STRVAR(index_doc,
"T.index(value, [start, [stop]]) -> integer -- return first index of value"); "T.index(value, [start, [stop]]) -> integer -- return first index of value");
PyDoc_STRVAR(count_doc, PyDoc_STRVAR(count_doc,
"T.count(value) -> integer -- return number of occurrences of value"); "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[] = { static PyMethodDef tuple_methods[] = {
{"__getnewargs__", (PyCFunction)tuple_getnewargs, METH_NOARGS}, {"__getnewargs__", (PyCFunction)tuple_getnewargs, METH_NOARGS},
{"__sizeof__", (PyCFunction)tuple_sizeof, METH_NOARGS, sizeof_doc},
{"index", (PyCFunction)tupleindex, METH_VARARGS, index_doc}, {"index", (PyCFunction)tupleindex, METH_VARARGS, index_doc},
{"count", (PyCFunction)tuplecount, METH_O, count_doc}, {"count", (PyCFunction)tuplecount, METH_O, count_doc},
{NULL, NULL} /* sentinel */ {NULL, NULL} /* sentinel */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment