]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
SF bug 705836: struct.pack of floats in non-native endian order
authorTim Peters <tim.peters@gmail.com>
Thu, 20 Mar 2003 18:31:20 +0000 (18:31 +0000)
committerTim Peters <tim.peters@gmail.com>
Thu, 20 Mar 2003 18:31:20 +0000 (18:31 +0000)
commit58d23ae9a919520ee5b849a4c6c48fa833c9958d
tree29ac77b4cf8253ac431bc9e4e7413f76253cdbb5
parent38d0ccfe963a1fa1cbc0a85298675d60d60437e2
SF bug 705836: struct.pack of floats in non-native endian order

pack_float, pack_double, save_float:  All the routines for creating
IEEE-format packed representations of floats and doubles simply ignored
that rounding can (in rare cases) propagate out of a long string of
1 bits.  At worst, the end-off carry can (by mistake) interfere with
the exponent value, and then unpacking yields a result wrong by a factor
of 2.  In less severe cases, it can end up losing more low-order bits
than intended, or fail to catch overflow *caused* by rounding.
Lib/test/test_struct.py
Misc/NEWS
Modules/cPickle.c
Modules/structmodule.c