Commit 6adda964 authored by Thomas Heller's avatar Thomas Heller

Issue #6493: Fix a ctypes problem setting bitfields more than 31 bits

wide.
parent 4d4b7398
...@@ -240,5 +240,20 @@ class BitFieldTest(unittest.TestCase): ...@@ -240,5 +240,20 @@ class BitFieldTest(unittest.TestCase):
_anonymous_ = ["_"] _anonymous_ = ["_"]
_fields_ = [("_", X)] _fields_ = [("_", X)]
def test_uint32(self):
class X(Structure):
_fields_ = [("a", c_uint32, 32)]
x = X()
x.a = 10
self.failUnlessEqual(x.a, 10)
def test_uint64(self):
class X(Structure):
_fields_ = [("a", c_uint64, 64)]
x = X()
x.a = 10
self.failUnlessEqual(x.a, 10)
if __name__ == "__main__": if __name__ == "__main__":
unittest.main() unittest.main()
...@@ -349,6 +349,8 @@ Core and Builtins ...@@ -349,6 +349,8 @@ Core and Builtins
Library Library
------- -------
- Issue #6493: Fix a ctypes problem setting bitfields more than 31 bits wide.
- unittest has been split up into a package. All old names should still work. - unittest has been split up into a package. All old names should still work.
- Issue #6431: Make Fraction type return NotImplemented when it doesn't - Issue #6431: Make Fraction type return NotImplemented when it doesn't
......
...@@ -426,9 +426,9 @@ get_ulonglong(PyObject *v, unsigned PY_LONG_LONG *p) ...@@ -426,9 +426,9 @@ get_ulonglong(PyObject *v, unsigned PY_LONG_LONG *p)
#define LOW_BIT(x) ((x) & 0xFFFF) #define LOW_BIT(x) ((x) & 0xFFFF)
#define NUM_BITS(x) ((x) >> 16) #define NUM_BITS(x) ((x) >> 16)
/* This seems nore a compiler issue than a Windows/non-Windows one */ /* This seems more a compiler issue than a Windows/non-Windows one */
#ifdef MS_WIN32 #ifdef MS_WIN32
# define BIT_MASK(size) ((1 << NUM_BITS(size))-1) # define BIT_MASK(size) ((1i64 << NUM_BITS(size))-1)
#else #else
# define BIT_MASK(size) ((1LL << NUM_BITS(size))-1) # define BIT_MASK(size) ((1LL << NUM_BITS(size))-1)
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment