diff -r 43ae2a243eca Lib/test/test_sys.py --- a/Lib/test/test_sys.py Thu Jul 26 00:47:15 2012 +0200 +++ b/Lib/test/test_sys.py Thu Jul 26 13:10:05 2012 +0300 @@ -702,6 +702,12 @@ check(get_cell().__closure__[0], size(h + 'P')) # code check(get_cell().__code__, size(h + '5i9Pi3P')) + check(get_cell.__code__, size(h + '5i9Pi3P')) + def get_cell2(x): + def inner(): + return x + return inner + check(get_cell2.__code__, size(h + '5i9Pi3P') + 1) # complex check(complex(0,1), size(h + '2d')) # method_descriptor (descriptor object) diff -r 43ae2a243eca Objects/codeobject.c --- a/Objects/codeobject.c Thu Jul 26 00:47:15 2012 +0200 +++ b/Objects/codeobject.c Thu Jul 26 13:10:05 2012 +0300 @@ -375,6 +375,17 @@ } static PyObject * +code_sizeof(PyCodeObject *co, void *unused) +{ + Py_ssize_t res; + + res = sizeof(PyCodeObject); + if (co->co_cell2arg != NULL && co->co_cellvars != NULL) + res += PyTuple_GET_SIZE(co->co_cellvars) * sizeof(unsigned char); + return PyLong_FromSsize_t(res); +} + +static PyObject * code_repr(PyCodeObject *co) { int lineno; @@ -480,6 +491,11 @@ /* XXX code objects need to participate in GC? */ +static struct PyMethodDef code_methods[] = { + {"__sizeof__", (PyCFunction)code_sizeof, METH_NOARGS}, + {NULL, NULL} /* sentinel */ +}; + PyTypeObject PyCode_Type = { PyVarObject_HEAD_INIT(&PyType_Type, 0) "code", @@ -508,7 +524,7 @@ offsetof(PyCodeObject, co_weakreflist), /* tp_weaklistoffset */ 0, /* tp_iter */ 0, /* tp_iternext */ - 0, /* tp_methods */ + code_methods, /* tp_methods */ code_memberlist, /* tp_members */ 0, /* tp_getset */ 0, /* tp_base */