Issue #9696: Fix exception incorrectly raised by xdrlib.Packer.pack_int when trying to pack a negative (in-range) integer.

This commit is contained in:
Mark Dickinson 2011-03-27 16:15:24 +01:00
parent 1829e8fc7c
commit d687be09b4
4 changed files with 9 additions and 1 deletions

View File

@ -12,6 +12,7 @@ class XDRTest(unittest.TestCase):
a = ['what', 'is', 'hapnin', 'doctor']
p.pack_int(42)
p.pack_int(-17)
p.pack_uint(9)
p.pack_bool(True)
p.pack_bool(False)
@ -29,6 +30,7 @@ class XDRTest(unittest.TestCase):
self.assertEqual(up.get_position(), 0)
self.assertEqual(up.unpack_int(), 42)
self.assertEqual(up.unpack_int(), -17)
self.assertEqual(up.unpack_uint(), 9)
self.assertTrue(up.unpack_bool() is True)

View File

@ -53,7 +53,9 @@ class Packer:
def pack_uint(self, x):
self.__buf.write(struct.pack('>L', x))
pack_int = pack_uint
def pack_int(self, x):
self.__buf.write(struct.pack('>l', x))
pack_enum = pack_int
def pack_bool(self, x):

View File

@ -306,6 +306,7 @@ Eddy De Greef
Duncan Grisby
Fabian Groffen
Dag Gruneau
Filip Gruszczyński
Michael Guravage
Lars Gustäbel
Thomas Güttler

View File

@ -47,6 +47,9 @@ Core and Builtins
Library
-------
- Issue #9696: Fix exception incorrectly raised by xdrlib.Packer.pack_int when
trying to pack a negative (in-range) integer.
- Issue #11675: multiprocessing.[Raw]Array objects created from an integer size
are now zeroed on creation. This matches the behaviour specified by the
documentation.