Commit d4e58dc9 authored by Jesus Cea's avatar Jesus Cea

Closes #15469: Correct __sizeof__ support for deque

parent 3e3192d8
...@@ -6,6 +6,7 @@ import weakref ...@@ -6,6 +6,7 @@ import weakref
import copy import copy
import cPickle as pickle import cPickle as pickle
import random import random
import struct
BIG = 100000 BIG = 100000
...@@ -517,6 +518,21 @@ class TestBasic(unittest.TestCase): ...@@ -517,6 +518,21 @@ class TestBasic(unittest.TestCase):
gc.collect() gc.collect()
self.assertTrue(ref() is None, "Cycle was not collected") self.assertTrue(ref() is None, "Cycle was not collected")
check_sizeof = test_support.check_sizeof
@test_support.cpython_only
def test_sizeof(self):
BLOCKLEN = 62
basesize = test_support.calcobjsize('2P4PlP')
blocksize = struct.calcsize('2P%dP' % BLOCKLEN)
self.assertEqual(object.__sizeof__(deque()), basesize)
check = self.check_sizeof
check(deque(), basesize + blocksize)
check(deque('a'), basesize + blocksize)
check(deque('a' * (BLOCKLEN // 2)), basesize + blocksize)
check(deque('a' * (BLOCKLEN // 2 + 1)), basesize + 2 * blocksize)
check(deque('a' * (42 * BLOCKLEN)), basesize + 43 * blocksize)
class TestVariousIteratorArgs(unittest.TestCase): class TestVariousIteratorArgs(unittest.TestCase):
def test_constructor(self): def test_constructor(self):
......
...@@ -104,6 +104,9 @@ Library ...@@ -104,6 +104,9 @@ Library
- Issue #15489: Add a __sizeof__ implementation for BytesIO objects. - Issue #15489: Add a __sizeof__ implementation for BytesIO objects.
Patch by Serhiy Storchaka. Patch by Serhiy Storchaka.
- Issue #15469: Add a __sizeof__ implementation for deque objects.
Patch by Serhiy Storchaka.
- Issue #15487: Add a __sizeof__ implementation for buffered I/O objects. - Issue #15487: Add a __sizeof__ implementation for buffered I/O objects.
Patch by Serhiy Storchaka. Patch by Serhiy Storchaka.
......
...@@ -990,6 +990,23 @@ deque_init(dequeobject *deque, PyObject *args, PyObject *kwdargs) ...@@ -990,6 +990,23 @@ deque_init(dequeobject *deque, PyObject *args, PyObject *kwdargs)
return 0; return 0;
} }
static PyObject *
deque_sizeof(dequeobject *deque, void *unused)
{
Py_ssize_t res;
Py_ssize_t blocks;
res = sizeof(dequeobject);
blocks = (deque->leftindex + deque->len + BLOCKLEN - 1) / BLOCKLEN;
assert(deque->leftindex + deque->len - 1 ==
(blocks - 1) * BLOCKLEN + deque->rightindex);
res += blocks * sizeof(block);
return PyLong_FromSsize_t(res);
}
PyDoc_STRVAR(sizeof_doc,
"D.__sizeof__() -- size of D in memory, in bytes");
static PyObject * static PyObject *
deque_get_maxlen(dequeobject *deque) deque_get_maxlen(dequeobject *deque)
{ {
...@@ -1053,7 +1070,9 @@ static PyMethodDef deque_methods[] = { ...@@ -1053,7 +1070,9 @@ static PyMethodDef deque_methods[] = {
{"reverse", (PyCFunction)deque_reverse, {"reverse", (PyCFunction)deque_reverse,
METH_NOARGS, reverse_doc}, METH_NOARGS, reverse_doc},
{"rotate", (PyCFunction)deque_rotate, {"rotate", (PyCFunction)deque_rotate,
METH_VARARGS, rotate_doc}, METH_VARARGS, rotate_doc},
{"__sizeof__", (PyCFunction)deque_sizeof,
METH_NOARGS, sizeof_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