diff options
| author | Armin Rigo <arigo@tunes.org> | 2004-10-28 16:32:00 (GMT) |
|---|---|---|
| committer | Armin Rigo <arigo@tunes.org> | 2004-10-28 16:32:00 (GMT) |
| commit | 89a39461bff04b80bb4857790350e1ab30ff2df9 (patch) | |
| tree | 54bc00a9ad30e8e49849874cfbca8543de62fa58 /Include/listobject.h | |
| parent | 063e1e846dc5c3fe593cef5b14cc429369dcd2c2 (diff) | |
| download | cpython-89a39461bff04b80bb4857790350e1ab30ff2df9.zip cpython-89a39461bff04b80bb4857790350e1ab30ff2df9.tar.gz cpython-89a39461bff04b80bb4857790350e1ab30ff2df9.tar.bz2 | |
Wrote down the invariants of some common objects whose structure is
exposed in header files. Fixed a few comments in these headers.
As we might have expected, writing down invariants systematically exposed a
(minor) bug. In this case, function objects have a writeable func_code
attribute, which could be set to code objects with the wrong number of
free variables. Calling the resulting function segfaulted the interpreter.
Added a corresponding test.
Diffstat (limited to 'Include/listobject.h')
| -rw-r--r-- | Include/listobject.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/Include/listobject.h b/Include/listobject.h index e4867a5..0999a82 100644 --- a/Include/listobject.h +++ b/Include/listobject.h @@ -31,6 +31,9 @@ typedef struct { * len(list) == ob_size * ob_item == NULL implies ob_size == allocated == 0 * list.sort() temporarily sets allocated to -1 to detect mutations. + * + * Items must normally not be NULL, except during construction when + * the list is not yet visible outside the function that builds it. */ int allocated; } PyListObject; |
