summaryrefslogtreecommitdiff
path: root/dev-python
diff options
context:
space:
mode:
authorArthur Zamarin <arthurzam@gentoo.org>2025-04-16 10:27:26 +0300
committerArthur Zamarin <arthurzam@gentoo.org>2025-04-16 10:27:47 +0300
commitf3ee1efae2374a90b8b4237927316853c79b3e1b (patch)
tree0ab1b835ce6aeb66d96214c85b893fdc6f08c306 /dev-python
parent66f532f7ce6a5b895bd92e049694ebcec1fb62e4 (diff)
downloadgentoo-f3ee1efae2374a90b8b4237927316853c79b3e1b.tar.gz
gentoo-f3ee1efae2374a90b8b4237927316853c79b3e1b.tar.bz2
gentoo-f3ee1efae2374a90b8b4237927316853c79b3e1b.zip
dev-python/aiohttp: devendor llhttp
Closes: https://bugs.gentoo.org/953899 Signed-off-by: Arthur Zamarin <arthurzam@gentoo.org>
Diffstat (limited to 'dev-python')
-rw-r--r--dev-python/aiohttp/aiohttp-3.11.16-r1.ebuild (renamed from dev-python/aiohttp/aiohttp-3.11.16.ebuild)15
-rw-r--r--dev-python/aiohttp/files/aiohttp-3.11.16-devendor-llhttp.patch54
2 files changed, 67 insertions, 2 deletions
diff --git a/dev-python/aiohttp/aiohttp-3.11.16.ebuild b/dev-python/aiohttp/aiohttp-3.11.16-r1.ebuild
index 2c0d281aa753..dc9100ad7365 100644
--- a/dev-python/aiohttp/aiohttp-3.11.16.ebuild
+++ b/dev-python/aiohttp/aiohttp-3.11.16-r1.ebuild
@@ -17,10 +17,15 @@ HOMEPAGE="
LICENSE="Apache-2.0"
SLOT="0"
-KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
+KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
IUSE="+native-extensions test-rust"
-RDEPEND="
+DEPEND="
+ $(python_gen_cond_dep '
+ native-extensions? ( net-libs/llhttp:= )
+ ' 'python3*')
+"
+RDEPEND="${DEPEND}
>=dev-python/aiodns-3.2.0[${PYTHON_USEDEP}]
>=dev-python/aiohappyeyeballs-2.3.0[${PYTHON_USEDEP}]
>=dev-python/aiosignal-1.1.2[${PYTHON_USEDEP}]
@@ -57,6 +62,10 @@ BDEPEND="
DOCS=( CHANGES.rst CONTRIBUTORS.txt README.rst )
+PATCHES=(
+ "${FILESDIR}"/${PN}-3.11.16-devendor-llhttp.patch
+)
+
EPYTEST_XDIST=1
distutils_enable_tests pytest
@@ -66,6 +75,8 @@ src_prepare() {
# xfail_strict fails on py3.10
sed -i -e '/--cov/d' -e '/pytest_cov/d' -e '/xfail_strict/d' setup.cfg || die
sed -i -e 's:-Werror::' Makefile || die
+ # remove the bundled llhttp, we use the system one
+ rm -r vendor/llhttp || die
distutils-r1_src_prepare
}
diff --git a/dev-python/aiohttp/files/aiohttp-3.11.16-devendor-llhttp.patch b/dev-python/aiohttp/files/aiohttp-3.11.16-devendor-llhttp.patch
new file mode 100644
index 000000000000..26aa843ad936
--- /dev/null
+++ b/dev-python/aiohttp/files/aiohttp-3.11.16-devendor-llhttp.patch
@@ -0,0 +1,54 @@
+https://src.fedoraproject.org/rpms/python-aiohttp/raw/bceb660b835a4aaffd763a261cb2cd2392ee06db/f/0001-Unbundle-llhttp.patch
+From: =?UTF-8?q?Tom=C3=A1=C5=A1=20Hrn=C4=8Diar?= <thrnciar@redhat.com>
+Date: Wed, 16 Feb 2022 13:57:57 +0100
+Subject: [PATCH] Unbundle llhttp
+
+Modified a little by arthurzam@gentoo.org to force cythonize
+
+--- a/aiohttp/_cparser.pxd
++++ b/aiohttp/_cparser.pxd
+@@ -1,7 +1,7 @@
+ from libc.stdint cimport int32_t, uint8_t, uint16_t, uint64_t
+
+
+-cdef extern from "../vendor/llhttp/build/llhttp.h":
++cdef extern from "llhttp.h":
+
+ struct llhttp__internal_s:
+ int32_t _index
+--- a/setup.py
++++ b/setup.py
+@@ -27,23 +27,21 @@ if IS_GIT_REPO and not (HERE / "vendor/llhttp/README.md").exists():
+ # NOTE: makefile cythonizes all Cython modules
+
+ extensions = [
+- Extension("aiohttp._websocket.mask", ["aiohttp/_websocket/mask.c"]),
++ Extension("aiohttp._websocket.mask", ["aiohttp/_websocket/mask.pyx"]),
+ Extension(
+ "aiohttp._http_parser",
+ [
+- "aiohttp/_http_parser.c",
+- "aiohttp/_find_header.c",
+- "vendor/llhttp/build/c/llhttp.c",
+- "vendor/llhttp/src/native/api.c",
+- "vendor/llhttp/src/native/http.c",
++ "aiohttp/_http_parser.pyx",
+ ],
+- define_macros=[("LLHTTP_STRICT_MODE", 0)],
+- include_dirs=["vendor/llhttp/build"],
+ ),
+- Extension("aiohttp._http_writer", ["aiohttp/_http_writer.c"]),
++ Extension("aiohttp._http_writer", ["aiohttp/_http_writer.pyx"]),
+ Extension("aiohttp._websocket.reader_c", ["aiohttp/_websocket/reader_c.c"]),
+ ]
+
++if not NO_EXTENSIONS:
++ from Cython.Build import cythonize
++ extensions = cythonize(extensions, force=True, language_level=3)
++
+
+ build_type = "Pure" if NO_EXTENSIONS else "Accelerated"
+ setup_kwargs = {} if NO_EXTENSIONS else {"ext_modules": extensions}
+--
+2.48.1
+