mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
Issue #6493: Fix a ctypes problem setting bitfields more than 31 bits
wide.
This commit is contained in:
parent
4d4b7398a2
commit
6adda9641d
3 changed files with 19 additions and 2 deletions
|
@ -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
|
||||||
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)
|
||||||
#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
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue