diff options
author | Tim Peters <tim.peters@gmail.com> | 2001-10-27 00:46:09 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2001-10-27 00:46:09 (GMT) |
commit | a9f4739a1b315417d5b79055a64ee8dd11d1b173 (patch) | |
tree | bee52848ea3b622342d2bdc6f4741bc65c9f2e07 /Python/hypot.c | |
parent | f4331c1c3874651cfa872c9dda8ab504e0129349 (diff) | |
download | cpython-a9f4739a1b315417d5b79055a64ee8dd11d1b173.zip cpython-a9f4739a1b315417d5b79055a64ee8dd11d1b173.tar.gz cpython-a9f4739a1b315417d5b79055a64ee8dd11d1b173.tar.bz2 |
tuple(3,4,5,x=2) dumped core on my box. vgetargskeywords() overindexed
the kwlist vector whenever there was a mix of positional and keyword
arguments, and the number of positional arguments exceeded the length
of the kwlist vector. If there was just one more positional arg than
keyword, the kwlist-terminating NULL got passed to PyMapping_HasKeyString,
which set an internal error that vgetargskeywords() then squashed (but
it's impossible to say whether it knew it was masking an error). If
more than one more positional argument, it went on to pass random trash
to PyMapping_HasKeyString, which is why the example at the start
happened to kill the process.
Pure bugfix candidate.
Diffstat (limited to 'Python/hypot.c')
0 files changed, 0 insertions, 0 deletions