aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEivind Uggedal <eu@eju.no>2019-05-12 19:01:36 +0000
committerNatanael Copa <ncopa@alpinelinux.org>2019-08-21 14:04:42 +0000
commit06b2c874a9dc365e2190c60bb93ea7a6f27fc72c (patch)
treeefcd3729521313a6ff9e44fc2f807f986d0145b2
parentde4dad0b9450b25c3a13f7eeff38c914b2721ead (diff)
downloadaports-06b2c874a9dc365e2190c60bb93ea7a6f27fc72c.tar.bz2
aports-06b2c874a9dc365e2190c60bb93ea7a6f27fc72c.tar.xz
main/py3-hiredis: update to 1.0.0, py3 only, adopt
* Drop py2 version * Adopt package (again) * Modernize * Add python3 support * Run tests * Patch to work with system hiredis 0.14
-rw-r--r--main/py-hiredis/APKBUILD44
-rw-r--r--main/py-hiredis/system-hiredis.patch39
-rw-r--r--main/py3-hiredis/APKBUILD37
-rw-r--r--main/py3-hiredis/hiredis-0.14-compat.patch31
-rw-r--r--main/py3-hiredis/system-hiredis.patch14
5 files changed, 82 insertions, 83 deletions
diff --git a/main/py-hiredis/APKBUILD b/main/py-hiredis/APKBUILD
deleted file mode 100644
index 765d4c15ea..0000000000
--- a/main/py-hiredis/APKBUILD
+++ /dev/null
@@ -1,44 +0,0 @@
-# Maintainer:
-pkgname=py-hiredis
-_pkgname=${pkgname#py-}
-pkgver=0.1.4
-pkgrel=2
-pkgdesc="Python extension that wraps hiredis"
-url="https://github.com/redis/hiredis-py"
-arch="all"
-license="BSD"
-depends="python2"
-depends_dev=""
-makedepends="python2-dev py-setuptools hiredis-dev"
-install=""
-subpackages=""
-source="https://files.pythonhosted.org/packages/source/${_pkgname:0:1}/$_pkgname/$_pkgname-$pkgver.tar.gz
- system-hiredis.patch"
-
-_builddir="$srcdir"/$_pkgname-$pkgver
-prepare() {
- local i
- cd "$_builddir"
- for i in $source; do
- case $i in
- *.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;;
- esac
- done
-}
-
-build() {
- cd "$_builddir"
- python2 setup.py build || return 1
-}
-
-package() {
- cd "$_builddir"
- python2 setup.py install --prefix=/usr --root="$pkgdir" || return 1
-}
-
-md5sums="8e253ef6021a7b5dc95b389a01e0e233 hiredis-0.1.4.tar.gz
-3cb7a0662f3627bb3943b5b0f00090d2 system-hiredis.patch"
-sha256sums="eb78e5b2f9f3b5f460b1da24b2d5e6179b3f918295697f8e3a71e982619d1a11 hiredis-0.1.4.tar.gz
-45de7d65538e01a521e9f4adc76ae90d3518211726d49fddf1a0c7ff8fd2c853 system-hiredis.patch"
-sha512sums="8767c836a845b5bd8a07dec33d0e27522d8c0b888bcd912eebf701a3826a59bf7b24cee26bfac33a19079e94f62ef1b823ab4ace505e5a146a33d676d7168693 hiredis-0.1.4.tar.gz
-4b39b75777f1955d17312841aaf602a9d97c6618f8dd81bbc3cc40ab2a5b91ecb7830e633dcbb029c47cc89f3a0e871189fd30edf7dfe3dec482d82898768e01 system-hiredis.patch"
diff --git a/main/py-hiredis/system-hiredis.patch b/main/py-hiredis/system-hiredis.patch
deleted file mode 100644
index 57dc709b99..0000000000
--- a/main/py-hiredis/system-hiredis.patch
+++ /dev/null
@@ -1,39 +0,0 @@
---- a/setup.py
-+++ b/setup.py
-@@ -21,27 +21,9 @@ class install_lib(_install_lib.install_lib):
- if self.distribution.has_ext_modules():
- self.run_command('build_ext')
-
--# To link the extension with the C library, distutils passes the "-lLIBRARY"
--# option to the linker. This makes it go through its library search path. If it
--# finds a shared object of the specified library in one of the system-wide
--# library paths, it will dynamically link it.
--#
--# We want the linker to statically link the version of hiredis that is included
--# with hiredis-py. However, the linker may pick up the shared library version
--# of hiredis, if it is available through one of the system-wide library paths.
--# To prevent this from happening, we use an obfuscated library name such that
--# the only version the linker will be able to find is the right version.
--#
--# This is a terrible hack, but patching distutils to do the right thing for all
--# supported Python versions is worse...
--#
--# Also see: https://github.com/pietern/hiredis-py/issues/15
--lib = ("hiredis_for_hiredis_py", {
-- "sources": ["vendor/hiredis/%s.c" % src for src in ("hiredis", "net", "sds")]})
--
- ext = Extension("hiredis.hiredis",
- sources=glob.glob("src/*.c"),
-- include_dirs=["vendor"])
-+ libraries=["hiredis"])
-
- setup(
- name="hiredis",
-@@ -53,7 +35,6 @@ setup(
- keywords=["Redis"],
- license="BSD",
- packages=["hiredis"],
-- libraries=[lib],
- ext_modules=[ext],
-
- # Override "install_lib" command
diff --git a/main/py3-hiredis/APKBUILD b/main/py3-hiredis/APKBUILD
new file mode 100644
index 0000000000..b52e3b5598
--- /dev/null
+++ b/main/py3-hiredis/APKBUILD
@@ -0,0 +1,37 @@
+# Maintainer: Eivind Uggedal <eu@eju.no>
+pkgname=py3-hiredis
+_pkgname=${pkgname#py3-}
+pkgver=1.0.0
+pkgrel=0
+pkgdesc="Python extension that wraps hiredis"
+url="https://github.com/redis/hiredis-py"
+arch="all"
+license="BSD-3-Clause"
+makedepends="python3-dev py3-setuptools hiredis-dev"
+source="https://files.pythonhosted.org/packages/source/${_pkgname:0:1}/$_pkgname/$_pkgname-$pkgver.tar.gz
+ system-hiredis.patch
+ hiredis-0.14-compat.patch"
+
+# keep these til after alpine v3.11
+provides="py-$_pkgname=$pkgver-r$pkgrel" # for backward compatibility
+replaces="py-$_pkgname" # for backward compatibility
+
+builddir="$srcdir"/$_pkgname-$pkgver
+
+build() {
+ cd "$builddir"
+ python3 setup.py build
+}
+
+check() {
+ cd "$builddir"
+ python3 test.py
+}
+
+package() {
+ python3 setup.py install --prefix=/usr --root="$pkgdir"
+}
+
+sha512sums="2dfe124977770431cfd77bd3c6d22fd6dcafdd69da3016d5459bf697668682e809f2c3a8b8b41e95c884a297e5f74e0163e43b05c808cb866e2317357fba11ff hiredis-1.0.0.tar.gz
+4be1599851215547b4b994a966087024cc86b495dbfdcb9807dabcffb5505509f25398c55a07b2a8fb7221cf9c5d27738a38f8c87fe2e37d991a2de3cfa38451 system-hiredis.patch
+a066ceab985be6ae87f0c30b98a496e6929909ac5d94b21fac9544bc8f649b0c1f0b66760441a90dc8bc50f4d748775f3d3a042fe8a4b466b5371bfb49b16f7a hiredis-0.14-compat.patch"
diff --git a/main/py3-hiredis/hiredis-0.14-compat.patch b/main/py3-hiredis/hiredis-0.14-compat.patch
new file mode 100644
index 0000000000..86e0d3f585
--- /dev/null
+++ b/main/py3-hiredis/hiredis-0.14-compat.patch
@@ -0,0 +1,31 @@
+--- hiredis-1.0.0/src/reader.c
++++ hiredis-1.0.0_p/src/reader.c
+@@ -167,7 +167,7 @@
+ static void Reader_dealloc(hiredis_ReaderObject *self) {
+ // we don't need to free self->encoding as the buffer is managed by Python
+ // https://docs.python.org/3/c-api/arg.html#strings-and-buffers
+- redisReplyReaderFree(self->reader);
++ redisReaderFree(self->reader);
+ Py_XDECREF(self->protocolErrorClass);
+ Py_XDECREF(self->replyErrorClass);
+
+@@ -272,7 +272,7 @@
+ goto error;
+ }
+
+- redisReplyReaderFeed(self->reader, (char *)buf.buf + off, len);
++ redisReaderFeed(self->reader, (char *)buf.buf + off, len);
+ PyBuffer_Release(&buf);
+ Py_RETURN_NONE;
+
+@@ -291,8 +291,8 @@
+ return NULL;
+ }
+
+- if (redisReplyReaderGetReply(self->reader, (void**)&obj) == REDIS_ERR) {
+- errstr = redisReplyReaderGetError(self->reader);
++ if (redisReaderGetReply(self->reader, (void**)&obj) == REDIS_ERR) {
++ errstr = redisReaderGetError(self->reader);
+ /* protocolErrorClass might be a callable. call it, then use it's type */
+ err = createError(self->protocolErrorClass, errstr, strlen(errstr));
+ if (err != NULL) {
diff --git a/main/py3-hiredis/system-hiredis.patch b/main/py3-hiredis/system-hiredis.patch
new file mode 100644
index 0000000000..e5aaa28bc4
--- /dev/null
+++ b/main/py3-hiredis/system-hiredis.patch
@@ -0,0 +1,14 @@
+--- hiredis-1.0.0/setup.py
++++ hiredis-1.0.0_p/setup.py
+@@ -11,9 +11,8 @@
+ return module.__version__
+
+ ext = Extension("hiredis.hiredis",
+- sources=sorted(glob.glob("src/*.c") +
+- ["vendor/hiredis/%s.c" % src for src in ("read", "sds")]),
+- include_dirs=["vendor"])
++ sources=sorted(glob.glob("src/*.c")),
++ libraries=["hiredis"])
+
+ setup(
+ name="hiredis",