From 24802392506a12ded8d7936f2afc30c6a9b895a7 Mon Sep 17 00:00:00 2001 From: AN Long Date: Sat, 6 Apr 2024 18:30:54 +0800 Subject: [PATCH 1/2] Support cythonized ext on Windows --- setup.py | 15 +- thriftpy2/_compat.py | 2 +- thriftpy2/protocol/cybin/endian_port.h | 186 +++++++++++++++++++++---- 3 files changed, 170 insertions(+), 33 deletions(-) diff --git a/setup.py b/setup.py index 113017ae..ab45325c 100644 --- a/setup.py +++ b/setup.py @@ -46,14 +46,19 @@ # pypy detection PYPY = "__pypy__" in sys.modules UNIX = platform.system() in ("Linux", "Darwin") +WINDOWS = platform.system() == "Windows" -# only build ext in CPython with UNIX platform -if UNIX and not PYPY: +# only build ext in CPython +if not PYPY: from Cython.Build import cythonize cythonize("thriftpy2/transport/cybase.pyx") cythonize("thriftpy2/transport/**/*.pyx") cythonize("thriftpy2/protocol/cybin/cybin.pyx") + libraries = [] + if WINDOWS: + libraries.append("Ws2_32") + ext_modules.append(Extension("thriftpy2.transport.cybase", ["thriftpy2/transport/cybase.c"])) ext_modules.append(Extension("thriftpy2.transport.buffered.cybuffered", @@ -61,11 +66,13 @@ ext_modules.append(Extension("thriftpy2.transport.memory.cymemory", ["thriftpy2/transport/memory/cymemory.c"])) ext_modules.append(Extension("thriftpy2.transport.framed.cyframed", - ["thriftpy2/transport/framed/cyframed.c"])) + ["thriftpy2/transport/framed/cyframed.c"], + libraries=libraries)) ext_modules.append(Extension("thriftpy2.transport.sasl.cysasl", ["thriftpy2/transport/sasl/cysasl.c"])) ext_modules.append(Extension("thriftpy2.protocol.cybin", - ["thriftpy2/protocol/cybin/cybin.c"])) + ["thriftpy2/protocol/cybin/cybin.c"], + libraries=libraries)) setup(name="thriftpy2", version=version, diff --git a/thriftpy2/_compat.py b/thriftpy2/_compat.py index c52664a6..d1078426 100644 --- a/thriftpy2/_compat.py +++ b/thriftpy2/_compat.py @@ -15,4 +15,4 @@ PYPY = "__pypy__" in sys.modules UNIX = platform.system() in ("Linux", "Darwin") -CYTHON = UNIX and not PYPY # Cython always disabled in pypy and windows +CYTHON = not PYPY # Cython always disabled in pypy diff --git a/thriftpy2/protocol/cybin/endian_port.h b/thriftpy2/protocol/cybin/endian_port.h index be8299bd..9d826d2d 100644 --- a/thriftpy2/protocol/cybin/endian_port.h +++ b/thriftpy2/protocol/cybin/endian_port.h @@ -1,42 +1,172 @@ +// Copied from https://gist.github.com/PkmX/63dd23f28ba885be53a5 -#if defined(__APPLE__) +// "License": Public Domain +// I, Mathias Panzenböck, place this file hereby into the public domain. Use it at your own risk for whatever you like. +// In case there are jurisdictions that don't support putting things in the public domain you can also consider it to +// be "dual licensed" under the BSD, MIT and Apache licenses, if you want to. This code is trivial anyway. Consider it +// an example on how to get the endian conversion functions on different platforms. -#include +#ifndef PORTABLE_ENDIAN_H__ +#define PORTABLE_ENDIAN_H__ -#define htobe16(x) OSSwapHostToBigInt16(x) -#define htobe32(x) OSSwapHostToBigInt32(x) -#define htobe64(x) OSSwapHostToBigInt64(x) -#define be16toh(x) OSSwapBigToHostInt16(x) -#define be32toh(x) OSSwapBigToHostInt32(x) -#define be64toh(x) OSSwapBigToHostInt64(x) +#if (defined(_WIN16) || defined(_WIN32) || defined(_WIN64)) && !defined(__WINDOWS__) -#else - -#include -#include +# define __WINDOWS__ -#ifndef htobe16 -#define htobe16(x) bswap_16(x) #endif -#ifndef htobe32 -#define htobe32(x) bswap_32(x) -#endif +#if defined(__linux__) || defined(__CYGWIN__) -#ifndef htobe64 -#define htobe64(x) bswap_64(x) -#endif +# include -#ifndef be16toh -#define be16toh(x) bswap_16(x) -#endif +#elif defined(__APPLE__) -#ifndef be32toh -#define be32toh(x) bswap_32(x) -#endif +# include + +# define htobe16(x) OSSwapHostToBigInt16(x) +# define htole16(x) OSSwapHostToLittleInt16(x) +# define be16toh(x) OSSwapBigToHostInt16(x) +# define le16toh(x) OSSwapLittleToHostInt16(x) + +# define htobe32(x) OSSwapHostToBigInt32(x) +# define htole32(x) OSSwapHostToLittleInt32(x) +# define be32toh(x) OSSwapBigToHostInt32(x) +# define le32toh(x) OSSwapLittleToHostInt32(x) + +# define htobe64(x) OSSwapHostToBigInt64(x) +# define htole64(x) OSSwapHostToLittleInt64(x) +# define be64toh(x) OSSwapBigToHostInt64(x) +# define le64toh(x) OSSwapLittleToHostInt64(x) + +# define __BYTE_ORDER BYTE_ORDER +# define __BIG_ENDIAN BIG_ENDIAN +# define __LITTLE_ENDIAN LITTLE_ENDIAN +# define __PDP_ENDIAN PDP_ENDIAN + +#elif defined(__OpenBSD__) + +# include + +# define __BYTE_ORDER BYTE_ORDER +# define __BIG_ENDIAN BIG_ENDIAN +# define __LITTLE_ENDIAN LITTLE_ENDIAN +# define __PDP_ENDIAN PDP_ENDIAN + +#elif defined(__NetBSD__) || defined(__FreeBSD__) || defined(__DragonFly__) + +# include + +# define be16toh(x) betoh16(x) +# define le16toh(x) letoh16(x) + +# define be32toh(x) betoh32(x) +# define le32toh(x) letoh32(x) + +# define be64toh(x) betoh64(x) +# define le64toh(x) letoh64(x) + +#elif defined(__WINDOWS__) + +# include +# ifdef __GNUC__ +# include +# endif + +# if BYTE_ORDER == LITTLE_ENDIAN + +# define htobe16(x) htons(x) +# define htole16(x) (x) +# define be16toh(x) ntohs(x) +# define le16toh(x) (x) + +# define htobe32(x) htonl(x) +# define htole32(x) (x) +# define be32toh(x) ntohl(x) +# define le32toh(x) (x) + +# define htobe64(x) htonll(x) +# define htole64(x) (x) +# define be64toh(x) ntohll(x) +# define le64toh(x) (x) + +# elif BYTE_ORDER == BIG_ENDIAN + + /* that would be xbox 360 */ +# define htobe16(x) (x) +# define htole16(x) __builtin_bswap16(x) +# define be16toh(x) (x) +# define le16toh(x) __builtin_bswap16(x) + +# define htobe32(x) (x) +# define htole32(x) __builtin_bswap32(x) +# define be32toh(x) (x) +# define le32toh(x) __builtin_bswap32(x) + +# define htobe64(x) (x) +# define htole64(x) __builtin_bswap64(x) +# define be64toh(x) (x) +# define le64toh(x) __builtin_bswap64(x) + +# else + +# error byte order not supported + +# endif + +# define __BYTE_ORDER BYTE_ORDER +# define __BIG_ENDIAN BIG_ENDIAN +# define __LITTLE_ENDIAN LITTLE_ENDIAN +# define __PDP_ENDIAN PDP_ENDIAN + +#elif defined(__QNXNTO__) + +# include + +# define __LITTLE_ENDIAN 1234 +# define __BIG_ENDIAN 4321 +# define __PDP_ENDIAN 3412 + +# if defined(__BIGENDIAN__) + +# define __BYTE_ORDER __BIG_ENDIAN + +# define htobe16(x) (x) +# define htobe32(x) (x) +# define htobe64(x) (x) + +# define htole16(x) ENDIAN_SWAP16(x) +# define htole32(x) ENDIAN_SWAP32(x) +# define htole64(x) ENDIAN_SWAP64(x) + +# elif defined(__LITTLEENDIAN__) + +# define __BYTE_ORDER __LITTLE_ENDIAN + +# define htole16(x) (x) +# define htole32(x) (x) +# define htole64(x) (x) + +# define htobe16(x) ENDIAN_SWAP16(x) +# define htobe32(x) ENDIAN_SWAP32(x) +# define htobe64(x) ENDIAN_SWAP64(x) + +# else + +# error byte order not supported + +# endif + +# define be16toh(x) ENDIAN_BE16(x) +# define be32toh(x) ENDIAN_BE32(x) +# define be64toh(x) ENDIAN_BE64(x) +# define le16toh(x) ENDIAN_LE16(x) +# define le32toh(x) ENDIAN_LE32(x) +# define le64toh(x) ENDIAN_LE64(x) + +#else + +# error platform not supported -#ifndef be64toh -#define be64toh(x) bswap_64(x) #endif #endif From 0e49b7cebe9117ecd9386e0c654b16d85452ca6b Mon Sep 17 00:00:00 2001 From: AN Long Date: Mon, 8 Apr 2024 00:13:22 +0800 Subject: [PATCH 2/2] Skip some test --- tests/test_protocol_cybinary.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/test_protocol_cybinary.py b/tests/test_protocol_cybinary.py index 997bb5b1..4bc8f7e6 100644 --- a/tests/test_protocol_cybinary.py +++ b/tests/test_protocol_cybinary.py @@ -3,6 +3,7 @@ import collections import multiprocessing import os +import sys import time import pytest @@ -317,6 +318,7 @@ def test_skip_struct(): assert 123 == proto.read_val(b, TType.I32) +@pytest.mark.skipif(sys.platform == "win32", reason="Unix domain socket required") def test_read_long_data(): val = 'z' * 97 * 1024