Sync from SUSE:SLFO:Main python-numcodecs revision 755e4dda643d95f723d966ef7404d273
This commit is contained in:
commit
3247667f01
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
## Default LFS
|
||||
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
||||
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||
*.zst filter=lfs diff=lfs merge=lfs -text
|
95
move-from-entrypoints.patch
Normal file
95
move-from-entrypoints.patch
Normal file
@ -0,0 +1,95 @@
|
||||
From af20af8210384371f91f30251fc78a35ffd0c072 Mon Sep 17 00:00:00 2001
|
||||
From: Steve Kowalik <steven@wedontsleep.org>
|
||||
Date: Wed, 9 Aug 2023 15:15:52 +1000
|
||||
Subject: [PATCH] Remove use of entrypoints
|
||||
|
||||
Since Python 3.8, the standard library has included functionality to
|
||||
query entry points directly using importlib.metadata. Since the API has
|
||||
changed for the better with Python 3.10, we need to support both ways of
|
||||
using it.
|
||||
---
|
||||
numcodecs/registry.py | 14 +++++++++-----
|
||||
numcodecs/tests/test_entrypoints.py | 2 --
|
||||
pyproject.toml | 7 ++++++-
|
||||
3 files changed, 15 insertions(+), 8 deletions(-)
|
||||
|
||||
diff --git a/numcodecs/registry.py b/numcodecs/registry.py
|
||||
index 532e9967..a4dff6d7 100644
|
||||
--- a/numcodecs/registry.py
|
||||
+++ b/numcodecs/registry.py
|
||||
@@ -1,7 +1,7 @@
|
||||
"""The registry module provides some simple convenience functions to enable
|
||||
applications to dynamically register and look-up codec classes."""
|
||||
+from importlib.metadata import entry_points
|
||||
import logging
|
||||
-from contextlib import suppress
|
||||
|
||||
logger = logging.getLogger("numcodecs")
|
||||
codec_registry = {}
|
||||
@@ -9,13 +9,17 @@
|
||||
|
||||
|
||||
def run_entrypoints():
|
||||
- import entrypoints
|
||||
entries.clear()
|
||||
- entries.update(entrypoints.get_group_named("numcodecs.codecs"))
|
||||
+ eps = entry_points()
|
||||
+ if hasattr(eps, 'select'):
|
||||
+ # If entry_points() has a select method, use that. Python 3.10+
|
||||
+ entries.update(eps.select(group="numcodecs.codecs"))
|
||||
+ else:
|
||||
+ # Otherwise, fallback to using get
|
||||
+ entries.update(eps.get("numcodecs.codecs", []))
|
||||
|
||||
|
||||
-with suppress(ImportError):
|
||||
- run_entrypoints()
|
||||
+run_entrypoints()
|
||||
|
||||
|
||||
def get_codec(config):
|
||||
diff --git a/numcodecs/tests/test_entrypoints.py b/numcodecs/tests/test_entrypoints.py
|
||||
index 81af635d..0d017f2d 100644
|
||||
--- a/numcodecs/tests/test_entrypoints.py
|
||||
+++ b/numcodecs/tests/test_entrypoints.py
|
||||
@@ -7,7 +7,6 @@
|
||||
|
||||
|
||||
here = os.path.abspath(os.path.dirname(__file__))
|
||||
-pytest.importorskip("entrypoints")
|
||||
|
||||
|
||||
@pytest.fixture()
|
||||
@@ -20,7 +19,6 @@ def set_path():
|
||||
numcodecs.registry.codec_registry.pop("test")
|
||||
|
||||
|
||||
-@pytest.mark.xfail(reason="FIXME: not working in wheels build")
|
||||
def test_entrypoint_codec(set_path):
|
||||
cls = numcodecs.registry.get_codec({"id": "test"})
|
||||
assert cls.codec_id == "test"
|
||||
diff --git a/pyproject.toml b/pyproject.toml
|
||||
index a2b50e32..147f9b54 100644
|
||||
--- a/pyproject.toml
|
||||
+++ b/pyproject.toml
|
||||
@@ -15,7 +15,6 @@ in data storage and communication applications.
|
||||
"""
|
||||
readme = "README.rst"
|
||||
dependencies = [
|
||||
- "entrypoints",
|
||||
"numpy>=1.7",
|
||||
]
|
||||
requires-python = ">=3.8"
|
||||
@@ -71,6 +70,12 @@ package-dir = {"" = "."}
|
||||
packages = ["numcodecs", "numcodecs.tests"]
|
||||
zip-safe = false
|
||||
|
||||
+[tool.setuptools.package-data]
|
||||
+numcodecs = [
|
||||
+ "tests/package_with_entrypoint/__init__.py",
|
||||
+ "tests/package_with_entrypoint-0.1.dist-info/entry_points.txt"
|
||||
+]
|
||||
+
|
||||
[tool.setuptools_scm]
|
||||
version_scheme = "guess-next-dev"
|
||||
local_scheme = "dirty-tag"
|
BIN
numcodecs-0.11.0.tar.gz
(Stored with Git LFS)
Normal file
BIN
numcodecs-0.11.0.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
151
numcodecs-pr417-raggednumpy.patch
Normal file
151
numcodecs-pr417-raggednumpy.patch
Normal file
@ -0,0 +1,151 @@
|
||||
diff --git a/numcodecs/json.py b/numcodecs/json.py
|
||||
index 670f223..b803a77 100644
|
||||
--- a/numcodecs/json.py
|
||||
+++ b/numcodecs/json.py
|
||||
@@ -54,7 +54,10 @@ class JSON(Codec):
|
||||
self._decoder = _json.JSONDecoder(**self._decoder_config)
|
||||
|
||||
def encode(self, buf):
|
||||
- buf = np.asarray(buf)
|
||||
+ try:
|
||||
+ buf = np.asarray(buf)
|
||||
+ except ValueError:
|
||||
+ buf = np.asarray(buf, dtype=object)
|
||||
items = buf.tolist()
|
||||
items.extend((buf.dtype.str, buf.shape))
|
||||
return self._encoder.encode(items).encode(self._text_encoding)
|
||||
diff --git a/numcodecs/msgpacks.py b/numcodecs/msgpacks.py
|
||||
index 026f583..6556498 100644
|
||||
--- a/numcodecs/msgpacks.py
|
||||
+++ b/numcodecs/msgpacks.py
|
||||
@@ -52,7 +52,10 @@ class MsgPack(Codec):
|
||||
self.raw = raw
|
||||
|
||||
def encode(self, buf):
|
||||
- buf = np.asarray(buf)
|
||||
+ try:
|
||||
+ buf = np.asarray(buf)
|
||||
+ except ValueError:
|
||||
+ buf = np.asarray(buf, dtype=object)
|
||||
items = buf.tolist()
|
||||
items.extend((buf.dtype.str, buf.shape))
|
||||
return msgpack.packb(items, use_bin_type=self.use_bin_type,
|
||||
diff --git a/numcodecs/tests/test_json.py b/numcodecs/tests/test_json.py
|
||||
index 7e8fcd6..8dac2b4 100644
|
||||
--- a/numcodecs/tests/test_json.py
|
||||
+++ b/numcodecs/tests/test_json.py
|
||||
@@ -2,7 +2,7 @@ import itertools
|
||||
|
||||
|
||||
import numpy as np
|
||||
-
|
||||
+import pytest
|
||||
|
||||
from numcodecs.json import JSON
|
||||
from numcodecs.tests.common import (check_config, check_repr, check_encode_decode_array,
|
||||
@@ -53,21 +53,23 @@ def test_backwards_compatibility():
|
||||
check_backwards_compatibility(JSON.codec_id, arrays, codecs)
|
||||
|
||||
|
||||
-def test_non_numpy_inputs():
|
||||
+@pytest.mark.parametrize(
|
||||
+ "input_data, dtype",
|
||||
+ [
|
||||
+ ([0, 1], None),
|
||||
+ ([[0, 1], [2, 3]], None),
|
||||
+ ([[0], [1], [2, 3]], object),
|
||||
+ ([[[0, 0]], [[1, 1]], [[2, 3]]], None),
|
||||
+ (["1"], None),
|
||||
+ (["11", "11"], None),
|
||||
+ (["11", "1", "1"], None),
|
||||
+ ([{}], None),
|
||||
+ ([{"key": "value"}, ["list", "of", "strings"]], object),
|
||||
+ ]
|
||||
+)
|
||||
+def test_non_numpy_inputs(input_data, dtype):
|
||||
# numpy will infer a range of different shapes and dtypes for these inputs.
|
||||
# Make sure that round-tripping through encode preserves this.
|
||||
- data = [
|
||||
- [0, 1],
|
||||
- [[0, 1], [2, 3]],
|
||||
- [[0], [1], [2, 3]],
|
||||
- [[[0, 0]], [[1, 1]], [[2, 3]]],
|
||||
- ["1"],
|
||||
- ["11", "11"],
|
||||
- ["11", "1", "1"],
|
||||
- [{}],
|
||||
- [{"key": "value"}, ["list", "of", "strings"]],
|
||||
- ]
|
||||
- for input_data in data:
|
||||
- for codec in codecs:
|
||||
- output_data = codec.decode(codec.encode(input_data))
|
||||
- assert np.array_equal(np.array(input_data), output_data)
|
||||
+ for codec in codecs:
|
||||
+ output_data = codec.decode(codec.encode(input_data))
|
||||
+ assert np.array_equal(np.array(input_data, dtype=dtype), output_data)
|
||||
diff --git a/numcodecs/tests/test_msgpacks.py b/numcodecs/tests/test_msgpacks.py
|
||||
index 6aeadcf..d76aa12 100644
|
||||
--- a/numcodecs/tests/test_msgpacks.py
|
||||
+++ b/numcodecs/tests/test_msgpacks.py
|
||||
@@ -2,6 +2,7 @@ import unittest
|
||||
|
||||
|
||||
import numpy as np
|
||||
+import pytest
|
||||
|
||||
|
||||
try:
|
||||
@@ -52,30 +53,32 @@ def test_backwards_compatibility():
|
||||
check_backwards_compatibility(codec.codec_id, arrays, [codec])
|
||||
|
||||
|
||||
-def test_non_numpy_inputs():
|
||||
+@pytest.mark.parametrize(
|
||||
+ "input_data, dtype",
|
||||
+ [
|
||||
+ ([0, 1], None),
|
||||
+ ([[0, 1], [2, 3]], None),
|
||||
+ ([[0], [1], [2, 3]], object),
|
||||
+ ([[[0, 0]], [[1, 1]], [[2, 3]]], None),
|
||||
+ (["1"], None),
|
||||
+ (["11", "11"], None),
|
||||
+ (["11", "1", "1"], None),
|
||||
+ ([{}], None),
|
||||
+ ([{"key": "value"}, ["list", "of", "strings"]], object),
|
||||
+ ([b"1"], None),
|
||||
+ ([b"11", b"11"], None),
|
||||
+ ([b"11", b"1", b"1"], None),
|
||||
+ ([{b"key": b"value"}, [b"list", b"of", b"strings"]], object),
|
||||
+ ]
|
||||
+)
|
||||
+def test_non_numpy_inputs(input_data, dtype):
|
||||
codec = MsgPack()
|
||||
# numpy will infer a range of different shapes and dtypes for these inputs.
|
||||
# Make sure that round-tripping through encode preserves this.
|
||||
- data = [
|
||||
- [0, 1],
|
||||
- [[0, 1], [2, 3]],
|
||||
- [[0], [1], [2, 3]],
|
||||
- [[[0, 0]], [[1, 1]], [[2, 3]]],
|
||||
- ["1"],
|
||||
- ["11", "11"],
|
||||
- ["11", "1", "1"],
|
||||
- [{}],
|
||||
- [{"key": "value"}, ["list", "of", "strings"]],
|
||||
- [b"1"],
|
||||
- [b"11", b"11"],
|
||||
- [b"11", b"1", b"1"],
|
||||
- [{b"key": b"value"}, [b"list", b"of", b"strings"]],
|
||||
- ]
|
||||
- for input_data in data:
|
||||
- actual = codec.decode(codec.encode(input_data))
|
||||
- expect = np.array(input_data)
|
||||
- assert expect.shape == actual.shape
|
||||
- assert np.array_equal(expect, actual)
|
||||
+ actual = codec.decode(codec.encode(input_data))
|
||||
+ expect = np.array(input_data, dtype=dtype)
|
||||
+ assert expect.shape == actual.shape
|
||||
+ assert np.array_equal(expect, actual)
|
||||
|
||||
|
||||
def test_encode_decode_shape_dtype_preserved():
|
131
python-numcodecs.changes
Normal file
131
python-numcodecs.changes
Normal file
@ -0,0 +1,131 @@
|
||||
-------------------------------------------------------------------
|
||||
Mon Aug 28 02:21:23 UTC 2023 - Steve Kowalik <steven.kowalik@suse.com>
|
||||
|
||||
- Add patch move-from-entrypoints.patch:
|
||||
* Drop requirements on entrypoints, use importlib.metadata.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Thu Jan 12 16:00:40 UTC 2023 - Ben Greiner <code@bnavigator.de>
|
||||
|
||||
- Update to 0.11.0
|
||||
* Speed up isinstance checks of
|
||||
numcodecs.ndarray_like.NDArrayLike,
|
||||
numcodecs.ndarray_like.DType and
|
||||
numcodecs.ndarray_like.FlagsObj. By Andreas Poehlmann, #379.
|
||||
* Remove unnecessary None argument to .get(), it is the default
|
||||
value. By Dimitri Papadopoulos Orfanos, #395.
|
||||
* Apply refurb suggestions. By Dimitri Papadopoulos Orfanos,
|
||||
#372.
|
||||
* Migrate codespell configuration to pyproject.toml and get rid
|
||||
of setup.cfg. By Dimitri Papadopoulos Orfanos #374.
|
||||
* Unvendor cpuinfo. By Dimitri Papadopoulos Orfanos #373.
|
||||
* Drop headers. By John Kirkham, #375.
|
||||
* Remove Python 2 code. By Dimitri Papadopoulos Orfanos #368,
|
||||
#387.
|
||||
* Support Python 3.11. By Dimitri Papadopoulos Orfanos, #369.
|
||||
* Drop Python 3.7. By John Kirkham,, #405 #406.
|
||||
* Test with zfpy 1.0.0. By John Kirkham, #385.
|
||||
* Remove vendored C files and re-generate them on the fly using
|
||||
Cython. Add a pyproject.toml file to define Cython as a build
|
||||
dependency. By Dimitri Papadopoulos Orfanos, #369.
|
||||
* Add tests for all registry classes. By Josh Moore, #349.
|
||||
* Finish pyproject.toml migration. By John Kirkham #382.
|
||||
- Add numcodecs-pr417-raggednumpy.patch
|
||||
* gh#zarr-developers/numcodecs#417
|
||||
- Refresh unbundle-libs.patch for system blosc supporting snappy
|
||||
* gh#zarr-developers/numcodecs#264
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Sun Sep 25 20:23:44 UTC 2022 - Arun Persaud <arun@gmx.de>
|
||||
|
||||
- specfile:
|
||||
* update copyright year
|
||||
* require python >= 3.7
|
||||
|
||||
- update to version 0.10.2:
|
||||
* Fix
|
||||
+ Add BitRound (0.10.0) to registry. By Josh Moore, #342.
|
||||
|
||||
- changes from version 0.10.1:
|
||||
* Maintenance
|
||||
+ Add entrypoints to setup.py. By Josh Moore, #332.
|
||||
+ Fix spelling. By Dimitri Papadopoulos Orfanos, #336.
|
||||
+ Drop Python 3.6 from tests By Dimitri Papadopoulos Orfanos,
|
||||
#338, #339.
|
||||
+ Remove trailing spaces and empty lines. By Dimitri Papadopoulos
|
||||
Orfanos, #341.
|
||||
+ Add LGTM.com configuration file By Dimitri Papadopoulos Orfanos,
|
||||
#337.
|
||||
|
||||
- changes from version 0.10.0:
|
||||
* Enhancements
|
||||
+ Add support of alternative array classes (other than NumPy
|
||||
arrays) By Mads R. B. Kristensen, #305.
|
||||
+ Add ability to find codecs via entrypoint numcodecs.codecs. By
|
||||
Martin Durant, #290.
|
||||
+ Add bitround codec By Ryan Abernathy and Martin Durant, #298.
|
||||
+ Introduce a flat option to ensure_contiguous_ndarray to switch
|
||||
off flatten for ZFPY codec By Haiying Xu, #307.
|
||||
* Bug fixes
|
||||
+ Fix a flatten array error for ZFPY, ZFPY codec is supported on
|
||||
Python 3.9 and 3.10 on Linux and MacOS, the docs about ZFPY is
|
||||
also available. By Haiying Xu, John Kirkham, Ryan Abernathey
|
||||
#303.
|
||||
+ Codex: make encode and decode @abstractmethods By Mads
|
||||
R. B. Kristensen, #306.
|
||||
+ Fix expected result test for Shuffle. By Elliott Sales de
|
||||
Andrade, #282.
|
||||
* Maintenance
|
||||
+ Multiple code linting fixes. By Dimitri Papadopoulos Orfanos,
|
||||
#295, #294, #293, and #292.
|
||||
+ Drop Python 3.6 By Josh Moore, #318.
|
||||
+ Fix macOS Python 3.10 By John Kirkham, #311.
|
||||
+ chore: bump cibuildwheel version, use action By Henry Schreiner,
|
||||
#309.
|
||||
+ Specify language as ‘en’ instead of None. By John Kirkham, #329.
|
||||
+ Move master to main. By John Kirkham, #322.
|
||||
+ Drop fastparquet benchmark. By John Kirkham, #321.
|
||||
+ Trim wheel builds. By John Kirkham, #320.
|
||||
|
||||
- changes from version 0.9.1:
|
||||
* Fix inaccurate docstrings for Blosc. By James Webber, #287.
|
||||
|
||||
- changes from version 0.9.0:
|
||||
* c-blosc upgrade 1.18.1 -> 1.21.0. Warning: this temporarily
|
||||
removes support for snappy compression! By kindjacket, #283.
|
||||
* Fix an ImportError with Blosc on Android. By Daniel Jewell, #284.
|
||||
|
||||
- changes from version 0.8.1:
|
||||
* Fix an ImportError with Blosc on Android. By Daniel Jewell, #284.
|
||||
|
||||
- changes from version 0.8.0:
|
||||
* The numcodecs.zfpy.ZFPY codec is now supported on Python 3.8 if
|
||||
zfpy==0.5.5 is installed. By haiying xu, #229.
|
||||
* Add support for byte Shuffle filter By Paul Branson and Martin
|
||||
Durant #273.
|
||||
* Update Windows + Mac CI to run all tests. By Jackson Maxfield
|
||||
Brown, #276. Help from Oleg Höfling, #273.
|
||||
* Update cpuinfo to 8.0.0. By Florian Jetter, #280.
|
||||
* Drop out-of-date manual release docs. By John Kirkham, #272.
|
||||
* Add support for Python 3.9 and Update GitHub Actions.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Mon Apr 25 11:13:12 UTC 2022 - Bernhard Wiedemann <bwiedemann@suse.com>
|
||||
|
||||
- Disable AVX2 to make package build reproducible (boo#1198818)
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Sat Apr 17 14:41:47 UTC 2021 - Ben Greiner <code@bnavigator.de>
|
||||
|
||||
- Update to v0.7.3
|
||||
* Add support for Python 3.9
|
||||
- Disable python36 build (NumPy not available, NEP 29)
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Mon Dec 28 12:24:07 UTC 2020 - Benjamin Greiner <code@bnavigator.de>
|
||||
|
||||
- initial specfile for v0.7.2
|
||||
- use and link against system provided blosc, zstd, lz4
|
||||
* unbundle-libs.patch
|
||||
* gh#zarr-developers/numcodecs#264
|
||||
- required by zarr, which is required by dask
|
86
python-numcodecs.spec
Normal file
86
python-numcodecs.spec
Normal file
@ -0,0 +1,86 @@
|
||||
#
|
||||
# spec file for package python-numcodecs
|
||||
#
|
||||
# Copyright (c) 2023 SUSE LLC
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
# upon. The license for this file, and modifications and additions to the
|
||||
# file, is the same license as for the pristine package itself (unless the
|
||||
# license for the pristine package is not an Open Source License, in which
|
||||
# case the license is the MIT License). An "Open Source License" is a
|
||||
# license that conforms to the Open Source Definition (Version 1.9)
|
||||
# published by the Open Source Initiative.
|
||||
|
||||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||
#
|
||||
|
||||
|
||||
Name: python-numcodecs
|
||||
Version: 0.11.0
|
||||
Release: 0
|
||||
Summary: Buffer compression and transformation codecs
|
||||
License: MIT
|
||||
URL: https://github.com/zarr-developers/numcodecs
|
||||
Source: https://files.pythonhosted.org/packages/source/n/numcodecs/numcodecs-%{version}.tar.gz
|
||||
# PATCH-FEATURE-UPSTREAM unbundle-libs.patch -- unbundle system libs gh#zarr-developers/numcodecs#264
|
||||
Patch0: unbundle-libs.patch
|
||||
# PATCH-FIX-UPSTREAM numcodecs-pr417-raggednumpy.patch gh#zarr-developers/numcodecs#417
|
||||
Patch1: numcodecs-pr417-raggednumpy.patch
|
||||
# PATCH-FIX-UPSTREAM gh#zarr-developers/numcodecs#442
|
||||
Patch2: move-from-entrypoints.patch
|
||||
BuildRequires: %{python_module Cython}
|
||||
BuildRequires: %{python_module base >= 3.8}
|
||||
BuildRequires: %{python_module pip}
|
||||
BuildRequires: %{python_module py-cpuinfo}
|
||||
BuildRequires: %{python_module setuptools > 64}
|
||||
BuildRequires: %{python_module setuptools_scm > 6.2}
|
||||
BuildRequires: %{python_module wheel}
|
||||
BuildRequires: blosc-devel
|
||||
BuildRequires: cmake
|
||||
BuildRequires: fdupes
|
||||
BuildRequires: gcc-c++
|
||||
BuildRequires: pkgconfig
|
||||
BuildRequires: python-rpm-macros
|
||||
BuildRequires: pkgconfig(liblz4)
|
||||
BuildRequires: pkgconfig(libzstd)
|
||||
BuildRequires: pkgconfig(zlib)
|
||||
Requires: python-numpy >= 1.7
|
||||
Suggests: python-msgpack
|
||||
Suggests: python-zfpy >= 1
|
||||
# SECTION test requirements
|
||||
BuildRequires: %{python_module numpy >= 1.7}
|
||||
BuildRequires: %{python_module msgpack}
|
||||
BuildRequires: %{python_module pytest}
|
||||
# /SECTION
|
||||
%python_subpackages
|
||||
|
||||
%description
|
||||
A Python package providing buffer compression and transformation codecs for use
|
||||
in data storage and communication applications.
|
||||
|
||||
%prep
|
||||
%autosetup -p1 -n numcodecs-%{version}
|
||||
# use system libraries instead of bundled ones
|
||||
rm -r c-blosc
|
||||
sed -i 's/--cov=numcodecs --cov-report xml//' pyproject.toml
|
||||
|
||||
%build
|
||||
export CFLAGS="%{optflags}"
|
||||
export DISABLE_NUMCODECS_AVX2=1
|
||||
%pyproject_wheel
|
||||
|
||||
%install
|
||||
%pyproject_install
|
||||
%python_expand %fdupes %{buildroot}%{$python_sitearch}
|
||||
|
||||
%check
|
||||
%pytest_arch --pyargs numcodecs -rsfE
|
||||
|
||||
%files %{python_files}
|
||||
%doc README.rst
|
||||
%license LICENSE.txt
|
||||
%{python_sitearch}/numcodecs
|
||||
%{python_sitearch}/numcodecs-%{version}*-info
|
||||
|
||||
%changelog
|
48
unbundle-libs.patch
Normal file
48
unbundle-libs.patch
Normal file
@ -0,0 +1,48 @@
|
||||
Index: numcodecs-0.11.0/setup.py
|
||||
===================================================================
|
||||
--- numcodecs-0.11.0.orig/setup.py
|
||||
+++ numcodecs-0.11.0/setup.py
|
||||
@@ -104,6 +104,7 @@ def blosc_extension():
|
||||
Extension('numcodecs.blosc',
|
||||
sources=sources + blosc_sources,
|
||||
include_dirs=include_dirs,
|
||||
+ libraries=[] if blosc_sources else ['blosc'],
|
||||
define_macros=define_macros,
|
||||
extra_compile_args=extra_compile_args,
|
||||
),
|
||||
@@ -138,6 +139,7 @@ def zstd_extension():
|
||||
Extension('numcodecs.zstd',
|
||||
sources=sources + zstd_sources,
|
||||
include_dirs=include_dirs,
|
||||
+ libraries=[] if zstd_sources else ['zstd'],
|
||||
define_macros=define_macros,
|
||||
extra_compile_args=extra_compile_args,
|
||||
),
|
||||
@@ -165,6 +167,7 @@ def lz4_extension():
|
||||
Extension('numcodecs.lz4',
|
||||
sources=sources + lz4_sources,
|
||||
include_dirs=include_dirs,
|
||||
+ libraries=[] if lz4_sources else ['lz4'],
|
||||
define_macros=define_macros,
|
||||
extra_compile_args=extra_compile_args,
|
||||
),
|
||||
Index: numcodecs-0.11.0/numcodecs/tests/test_blosc.py
|
||||
===================================================================
|
||||
--- numcodecs-0.11.0.orig/numcodecs/tests/test_blosc.py
|
||||
+++ numcodecs-0.11.0/numcodecs/tests/test_blosc.py
|
||||
@@ -155,10 +155,11 @@ def test_compress_complib(use_threads):
|
||||
}
|
||||
blosc.use_threads = use_threads
|
||||
for cname in blosc.list_compressors():
|
||||
- enc = blosc.compress(arr, cname.encode(), 1, Blosc.NOSHUFFLE)
|
||||
- complib = blosc.cbuffer_complib(enc)
|
||||
- expected_complib = expected_complibs[cname]
|
||||
- assert complib == expected_complib
|
||||
+ if cname in expected_complibs:
|
||||
+ enc = blosc.compress(arr, cname.encode(), 1, Blosc.NOSHUFFLE)
|
||||
+ complib = blosc.cbuffer_complib(enc)
|
||||
+ expected_complib = expected_complibs[cname]
|
||||
+ assert complib == expected_complib
|
||||
with pytest.raises(ValueError):
|
||||
# capitalized cname
|
||||
blosc.compress(arr, b'LZ4', 1)
|
Loading…
Reference in New Issue
Block a user