summaryrefslogtreecommitdiffstats
path: root/Modules/_struct.c
diff options
context:
space:
mode:
authorMeador Inge <meadori@gmail.com>2012-07-23 15:01:29 (GMT)
committerMeador Inge <meadori@gmail.com>2012-07-23 15:01:29 (GMT)
commitb14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6 (patch)
treeef670d6bf6855e80f60c9eb9c75ce1f7a513511e /Modules/_struct.c
parent7e918cfe2805f4556995885a14e684029c7c95ba (diff)
downloadcpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.zip
cpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.tar.gz
cpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.tar.bz2
Issue #15402: Add a __sizeof__ method to struct.Struct.
Initial patch by Serhiy Storchaka.
Diffstat (limited to 'Modules/_struct.c')
-rw-r--r--Modules/_struct.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/Modules/_struct.c b/Modules/_struct.c
index 1604b90..0a09fd8 100644
--- a/Modules/_struct.c
+++ b/Modules/_struct.c
@@ -1665,6 +1665,22 @@ s_get_size(PyStructObject *self, void *unused)
return PyLong_FromSsize_t(self->s_size);
}
+PyDoc_STRVAR(s_sizeof__doc__,
+"S.__sizeof__() -> size of S in memory, in bytes");
+
+static PyObject *
+s_sizeof(PyStructObject *self)
+{
+ Py_ssize_t size;
+ formatcode *code;
+
+ size = sizeof(PyStructObject) + sizeof(formatcode);
+ for (code = self->s_codes; code->fmtdef != NULL; code++) {
+ size += sizeof(formatcode);
+ }
+ return PyLong_FromSsize_t(size);
+}
+
/* List of functions */
static struct PyMethodDef s_methods[] = {
@@ -1673,6 +1689,7 @@ static struct PyMethodDef s_methods[] = {
{"unpack", s_unpack, METH_O, s_unpack__doc__},
{"unpack_from", (PyCFunction)s_unpack_from, METH_VARARGS|METH_KEYWORDS,
s_unpack_from__doc__},
+ {"__sizeof__", (PyCFunction)s_sizeof, METH_NOARGS, s_sizeof__doc__},
{NULL, NULL} /* sentinel */
};