diff options
author | Meador Inge <meadori@gmail.com> | 2012-07-23 15:01:29 (GMT) |
---|---|---|
committer | Meador Inge <meadori@gmail.com> | 2012-07-23 15:01:29 (GMT) |
commit | b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6 (patch) | |
tree | ef670d6bf6855e80f60c9eb9c75ce1f7a513511e | |
parent | 7e918cfe2805f4556995885a14e684029c7c95ba (diff) | |
download | cpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.zip cpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.tar.gz cpython-b14d8c9bcfb7f58e83a5c18c8b6eac0fa261c4b6.tar.bz2 |
Issue #15402: Add a __sizeof__ method to struct.Struct.
Initial patch by Serhiy Storchaka.
-rw-r--r-- | Lib/test/test_struct.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 4 | ||||
-rw-r--r-- | Modules/_struct.c | 17 |
3 files changed, 31 insertions, 0 deletions
diff --git a/Lib/test/test_struct.py b/Lib/test/test_struct.py index 2ccaad2..bd89950 100644 --- a/Lib/test/test_struct.py +++ b/Lib/test/test_struct.py @@ -556,6 +556,16 @@ class StructTest(unittest.TestCase): s = struct.Struct('i') s.__init__('ii') + def test_sizeof(self): + self.assertGreater(sys.getsizeof(struct.Struct('BHILfdspP')), + sys.getsizeof(struct.Struct('B'))) + self.assertGreaterEqual(sys.getsizeof(struct.Struct('123B')), + sys.getsizeof(struct.Struct('B'))) + self.assertGreaterEqual(sys.getsizeof(struct.Struct('B' * 123)), + sys.getsizeof(struct.Struct('123B'))) + self.assertGreaterEqual(sys.getsizeof(struct.Struct('123xB')), + sys.getsizeof(struct.Struct('B'))) + def test_main(): run_unittest(StructTest) @@ -98,6 +98,10 @@ Core and Builtins Library ------- +- Issue #15402: An issue in the struct module that caused sys.getsizeof to + return incorrect results for struct.Struct instances has been fixed. + Initial patch by Serhiy Storchaka. + - Issue #15232: when mangle_from is True, email.Generator now correctly mangles lines that start with 'From' that occur in a MIME preamble or epilogue. 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 */ }; |