forked from ashvardanian/NumKong
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathpyproject.toml
More file actions
166 lines (142 loc) · 6.76 KB
/
pyproject.toml
File metadata and controls
166 lines (142 loc) · 6.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
# This file configures wheels compilation for `cibuilwheel` for SimSIMD CPython bindings.
# On a good day it will produce:
# - `manylinux` and `musllinux` vectorized wheels for Linux on x86_64, aarch64;
# - `manylinux` and `musllinux` wheels for Linux on i686, ppc64le, s390x;
# - `macos` wheels for x86_64, arm64;
# - `windows` wheels for AMD64, ARM64.
# * for 7 Python versions from 3.8 to 3.14.
# * for 2 free-threading Python versions from 3.13 to 3.14.
# * running thousands of fuzzy tests on each wheel.
# = meaning 12 platforms * 9 Python versions = 108 builds.
[build-system]
requires = ["setuptools>=42"]
build-backend = "setuptools.build_meta"
[tool.pytest.ini_options]
minversion = "6.0"
addopts = ["-ra", "--showlocals", "--strict-markers", "--strict-config"]
xfail_strict = true
filterwarnings = ["error"]
[tool.cibuildwheel]
build-verbosity = 0
test-requires = ["pytest", "pytest-repeat", "tabulate"]
# Assuming NumPy and SciPy aren't available precompiled for some platforms,
# we will end up compiling them from source on emulated hardware...
# To avoid that use `--only-binary=:all:` to only fetch precompiled wheels.
# For better compatibility, we use (&&) to chain commands instead of (;).
test-command = """
python -m pip install numpy --only-binary=:all: || (echo "Failed to install NumPy" && exit 0) &&
python -m pip install scipy --only-binary=:all: || (echo "Failed to install SciPy" && exit 0) &&
python -c "import simsimd; print(simsimd.get_capabilities())" &&
pytest {project}/scripts/test.py -s -x -Wd
"""
# We need to build for all platforms:
# - on Linux: x86_64, aarch64, i686
# - on macOS: x86_64, arm64
# - on Windows: AMD64, ARM64
# https://cibuildwheel.readthedocs.io/en/stable/options/#archs
#
# Important to note, not all those platforms have recent images.
# The `manylinux_2_28` seems to be missing for `i686`.
# The `i686` is 32-bit x86, and `x86_64` is 64-bit x86.
archs = ["all"]
# Add "pp*" to skip PyPy builds, but they should work fine these days :)
# https://cibuildwheel.readthedocs.io/en/stable/options/#build-skip
# https://cibuildwheel.readthedocs.io/en/stable/#what-does-it-do
skip = [] # we also don't use any SIMD on: ["*s390x*", "*ppc64le*"]
enable = [] # don't enable PyPy
# Testing half-precision math in QEMU is unreliable!
environment-pass = ["SIMSIMD_IN_QEMU"]
[tool.cibuildwheel.environment]
SIMSIMD_IN_QEMU = "1"
[tool.cibuildwheel.linux]
before-build = ["rm -rf {project}/build"]
repair-wheel-command = "auditwheel repair -w {dest_dir} {wheel}"
# Use more recent images for the most popular SIMD-capable CPU architectures, to have access to newer compilers.
# Otherwise, prepare yourself to all kinds of AVX-512 issues and other SIMD-related pain.
# You can keep track of the most recent images on Quay:
# - for `manylinux`: https://quay.io/search?q=manylinux
# - for `musllinux`: https://quay.io/search?q=musllinux
manylinux-x86_64-image = "manylinux_2_28"
manylinux-aarch64-image = "manylinux_2_28"
musllinux-x86_64-image = "musllinux_1_2"
musllinux-aarch64-image = "musllinux_1_2"
# On CentOS we have to use `yum`.
# The healthy version would be: `apt-get update && apt-get install -y libc6-dev wget python3-dev`.
# We can't even use direct YUM variant: `yum update -y && yum install -y glibc-devel wget python3-devel`
# as downloading from `extras` fails on Arm instances!
before-all = ["yum update -y --disablerepo=extras && yum install -y --disablerepo=extras glibc-devel wget python3-devel"]
# With `musl` builds, we obviously don't need the `glibc` and can't use `yum`.
# This may also be handy for using custom dependencies for different Python versions:
# https://cibuildwheel.readthedocs.io/en/stable/options/#overrides
[[tool.cibuildwheel.overrides]]
select = "*-musllinux*"
before-all = "apk add --update wget python3-dev"
[tool.cibuildwheel.macos]
before-build = ["rm -rf {project}/build"]
repair-wheel-command = "delocate-wheel --require-archs {delocate_archs} -w {dest_dir} -v {wheel}"
[tool.cibuildwheel.windows]
before-build = ["rd /s /q {project}\\build || echo Done"]
# Windows-based OSes and PowerShell don't support the logical operators
# In PowerShell we could write something like:
# python -m pip install numpy; if ($LASTEXITCODE -ne 0) { echo "Failed to install NumPy... Nothing can stop me, I'm all the way up!" }
# but its safer to use the CMD syntax
[[tool.cibuildwheel.overrides]]
select = "*win*"
test-command = """
cmd /c "python -m pip install numpy pypy & if errorlevel 1 echo Failed to install NumPy... Nothing can stop me, I'm all the way up! &
python -m pip install scipy & if errorlevel 1 echo Failed to install SciPy... Nothing can stop me, I'm all the way up! &
pytest {project}/scripts/test.py -s -x -Wd"
"""
# --------------------------------------------------------------------------- #
# Architecture overrides for cross-compilation #
# --------------------------------------------------------------------------- #
# These environment variables allow setup.py to detect the target architecture
# during cross-compilation (e.g., building ARM64 wheels on x64 host).
# The SIMSIMD_TARGET_* variables override platform.machine() detection.
# x86-64 builds
[[tool.cibuildwheel.overrides]]
select = "*-win_amd64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "1"
environment.SIMSIMD_TARGET_ARM64 = "0"
[[tool.cibuildwheel.overrides]]
select = "*-manylinux*_x86_64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "1"
environment.SIMSIMD_TARGET_ARM64 = "0"
[[tool.cibuildwheel.overrides]]
select = "*-musllinux*_x86_64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "1"
environment.SIMSIMD_TARGET_ARM64 = "0"
[[tool.cibuildwheel.overrides]]
select = "*-macos*_x86_64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "1"
environment.SIMSIMD_TARGET_ARM64 = "0"
# ARM64 builds
[[tool.cibuildwheel.overrides]]
select = "*-win_arm64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "0"
environment.SIMSIMD_TARGET_ARM64 = "1"
[[tool.cibuildwheel.overrides]]
select = "*-manylinux*_aarch64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "0"
environment.SIMSIMD_TARGET_ARM64 = "1"
[[tool.cibuildwheel.overrides]]
select = "*-musllinux*_aarch64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "0"
environment.SIMSIMD_TARGET_ARM64 = "1"
[[tool.cibuildwheel.overrides]]
select = "*-macos*_arm64"
inherit.environment = "append"
environment.SIMSIMD_TARGET_X86 = "0"
environment.SIMSIMD_TARGET_ARM64 = "1"
# Configuration options for the Black formatter:
# https://black.readthedocs.io/en/latest/usage_and_configuration/the_basics.html#where-black-looks-for-the-file
[tool.black]
line-length = 120 # Set line length to the same value as in `.clang-format` for modern wide screens
target-version = ['py39', 'py312']