Commit 91ac4224 authored by Thomas Heller's avatar Thomas Heller

Fix ctypes on 32-bit systems when Python is configured --with-system-ffi.

See also https://bugs.launchpad.net/bugs/72505.

Ported from release25-maint branch.
parent a2ba6ea9
...@@ -272,6 +272,9 @@ Core and builtins ...@@ -272,6 +272,9 @@ Core and builtins
Library Library
------- -------
- ctypes will now work correctly on 32-bit systems when Python is
configured with --with-system-ffi.
- Patch #1203: ctypes now does work on OS X when Python is built with - Patch #1203: ctypes now does work on OS X when Python is built with
--disable-toolbox-glue --disable-toolbox-glue
......
...@@ -1616,17 +1616,21 @@ static struct fielddesc formattable[] = { ...@@ -1616,17 +1616,21 @@ static struct fielddesc formattable[] = {
/* XXX Hm, sizeof(int) == sizeof(long) doesn't hold on every platform */ /* XXX Hm, sizeof(int) == sizeof(long) doesn't hold on every platform */
/* As soon as we can get rid of the type codes, this is no longer a problem */ /* As soon as we can get rid of the type codes, this is no longer a problem */
#if SIZEOF_LONG == 4 #if SIZEOF_LONG == 4
{ 'l', l_set, l_get, &ffi_type_sint, l_set_sw, l_get_sw}, { 'l', l_set, l_get, &ffi_type_sint32, l_set_sw, l_get_sw},
{ 'L', L_set, L_get, &ffi_type_uint, L_set_sw, L_get_sw}, { 'L', L_set, L_get, &ffi_type_uint32, L_set_sw, L_get_sw},
#elif SIZEOF_LONG == 8 #elif SIZEOF_LONG == 8
{ 'l', l_set, l_get, &ffi_type_slong, l_set_sw, l_get_sw}, { 'l', l_set, l_get, &ffi_type_sint64, l_set_sw, l_get_sw},
{ 'L', L_set, L_get, &ffi_type_ulong, L_set_sw, L_get_sw}, { 'L', L_set, L_get, &ffi_type_uint64, L_set_sw, L_get_sw},
#else #else
# error # error
#endif #endif
#ifdef HAVE_LONG_LONG #ifdef HAVE_LONG_LONG
{ 'q', q_set, q_get, &ffi_type_slong, q_set_sw, q_get_sw}, #if SIZEOF_LONG_LONG == 8
{ 'Q', Q_set, Q_get, &ffi_type_ulong, Q_set_sw, Q_get_sw}, { 'q', q_set, q_get, &ffi_type_sint64, q_set_sw, q_get_sw},
{ 'Q', Q_set, Q_get, &ffi_type_uint64, Q_set_sw, Q_get_sw},
#else
# error
#endif
#endif #endif
{ 'P', P_set, P_get, &ffi_type_pointer}, { 'P', P_set, P_get, &ffi_type_pointer},
{ 'z', z_set, z_get, &ffi_type_pointer}, { 'z', z_set, z_get, &ffi_type_pointer},
......
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