Skip to content

Commit

Permalink
wip: limited api wheels
Browse files Browse the repository at this point in the history
  • Loading branch information
minrk committed Dec 3, 2024
1 parent 7ba9349 commit f024625
Show file tree
Hide file tree
Showing 6 changed files with 58 additions and 12 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/wheels.yml
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ jobs:
env:
MACOSX_DEPLOYMENT_TARGET: "10.9"
CIBW_BUILD: "${{ matrix.cibw.build || '*' }}"
CIBW_SKIP: "${{ matrix.cibw.skip || '' }}"
CIBW_SKIP: "cp38-* cp39-* cp310-* cp311-* cp313-* ${{ matrix.cibw.skip || '' }}"
CIBW_ARCHS: "${{ matrix.cibw.arch || 'auto' }}"
CIBW_MANYLINUX_X86_64_IMAGE: "${{ matrix.cibw.manylinux_x86_64_image || '' }}"

Expand Down
14 changes: 12 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ set(CMAKE_POLICY_DEFAULT_CMP0077 NEW)
list(PREPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
find_package(
Python
COMPONENTS Interpreter Development.Module
COMPONENTS Interpreter Development.Module ${SKBUILD_SABI_COMPONENT}
REQUIRED)

# Python_SOABI isn't always right when cross-compiling
# SKBUILD_SOABI seems to be
if (DEFINED SKBUILD_SOABI AND NOT "${SKBUILD_SOABI}" STREQUAL "${Python_SOABI}")
message(WARNING "SKBUILD_SOABI=${SKBUILD_SOABI} != Python_SOABI=${Python_SOABI}; likely cross-compiling, using SOABI=${SKBUILD_SOABI} from scikit-build")
message(WARNING "SKBUILD_SOABI=${SKBUILD_SOABI} != Python_SOABI=${Python_SOABI}; likely cross-compiling or Limited API, using SOABI=${SKBUILD_SOABI} from scikit-build")
set(Python_SOABI "${SKBUILD_SOABI}")
endif()

Expand Down Expand Up @@ -404,9 +404,19 @@ endif()

file(MAKE_DIRECTORY ${ZMQ_BACKEND_DEST})

if(NOT "${SKBUILD_SABI_COMPONENT}" STREQUAL "")
# set stable API
# assume we are targeting >= current Python version
# this isn't required, but we can't seem to get `wheel.py-api
message("SKBUILD_LIMITED_API=${SKBUILD_LIMITED_API}")
set(SABI_ARG "USE_SABI;${Python_VERSION_MAJOR}.${Python_VERSION_MINOR}")
message("Building with stable API ${SABI_ARG} for ${Python_SOABI}")
endif()

python_add_library(
${ZMQ_EXT_NAME} MODULE
WITH_SOABI
${SABI_ARG}
${ZMQ_C}
)

Expand Down
19 changes: 16 additions & 3 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
[build-system]
requires = [
"cffi; implementation_name == 'pypy'",
"cython>=3.0.0; implementation_name != 'pypy'",
"cython>=3.1.0a1; implementation_name != 'pypy'",
"packaging",
"scikit-build-core",
"scikit-build-core>=0.10",
]
build-backend = "scikit_build_core.build"

Expand Down Expand Up @@ -56,7 +56,7 @@ wheel.license-files = ["licenses/LICENSE*"]
# 3.15 is required by scikit-build-core
cmake.version = ">=3.15"
# only build/install the pyzmq component
cmake.targets = ["pyzmq"]
build.targets = ["pyzmq"]
install.components = ["pyzmq"]

[tool.ruff]
Expand Down Expand Up @@ -202,6 +202,19 @@ select = "cp3{7,8,9}-* pp3{7,8}-*"
manylinux-x86_64-image = "manylinux2010"
manylinux-i686-image = "manylinux2010"

# build limited-api wheels for 3.7, 3.12
[[tool.cibuildwheel.overrides]]
select = "cp312-*"
config-settings = {
wheel = {py-api = "cp312"},
}

[[tool.cibuildwheel.overrides]]
select = "cp37-*"
config-settings = {
wheel = {py-api = "cp37"},
}

# note: manylinux_2_28 builds are added
# in .github/workflows/wheels.yml

Expand Down
10 changes: 10 additions & 0 deletions zmq/backend/cython/_cpython.pxd
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
# These should be cimported from cpython.bytes
# but that has a transitive import of cpython.type
# which currently conflicts with limited API
cdef extern from "Python.h":
# cpython.bytes
char* PyBytes_AsString(object string) except NULL
bytes PyBytes_FromStringAndSize(char *v, Py_ssize_t len)
Py_ssize_t PyBytes_Size(object string) except -1
# cpython.exc
int PyErr_CheckSignals() except -1
23 changes: 17 additions & 6 deletions zmq/backend/cython/_zmq.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,15 @@
size_t,
sizeof,
)
from cython.cimports.cpython import (
PyBytes_AsString,
PyBytes_FromStringAndSize,
PyBytes_Size,
PyErr_CheckSignals,
)

# Cannot cimport these with Limited API yet
# see https://github.com/cython/cython/issues/5634
# from cython.cimports.cpython.bytes import (
# PyBytes_AsString,
# PyBytes_FromStringAndSize,
# PyBytes_Size,
# )
# from cython.cimports.cpython.exc import PyErr_CheckSignals
from cython.cimports.libc.errno import EAGAIN, EINTR, ENAMETOOLONG, ENOENT, ENOTSOCK

# cimports require Cython 3
Expand All @@ -70,6 +73,14 @@
from cython.cimports.libc.stdio import stderr as cstderr
from cython.cimports.libc.stdlib import free, malloc
from cython.cimports.libc.string import memcpy

# these should be from cython.cimports.cpython
from cython.cimports.zmq.backend.cython._cpython import (
PyBytes_AsString,
PyBytes_FromStringAndSize,
PyBytes_Size,
PyErr_CheckSignals,
)
from cython.cimports.zmq.backend.cython._externs import (
get_ipc_path_max_len,
getpid,
Expand Down
2 changes: 2 additions & 0 deletions zmq/utils/mutex.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@

#pragma once

#include <stdlib.h>

#if defined(_WIN32)
# include <windows.h>
#else
Expand Down

0 comments on commit f024625

Please sign in to comment.