Skip to main content

A setuptools command for packaging pre-built binary python extension modules.

Project description

A setuptools command for packaging pre-built binary python extension modules.

If you are already using cmake as your build tool, having to then build your library with setuptools in order to package it can be annoying.

prebuild_binaries allows you to pass an already built extension module (.pyd file) to setuptools for inclusion in a wheel.

Note that it is your responsibility to do this with the same python version as the file was created with - however this is pretty easy to get right when it’s part of the same build chain.

API

class PrebuiltExtension (input_filename, package=None)

input_filename is the full path to the pre-built extension module (.pyd file) The stem of input_filename is used for the name of the extension module.

If package is passed then the name of the extension module will be <package>.<name>

class prebuilt_binary

setuptools command class that takes PrebuiltExtension instances as parameters and copies the input file to the correct location. It is a replacement for the setuptools build_ext command.

Minimal setup.py example

import os
from setuptools import setup
from prebuilt_binaries import prebuilt_binary, PrebuiltExtension

ext_module = PrebuiltExtension(os.environ['PREBUILT_FILE'])

setup(
    name='my_package',
    version='version',
    cmdclass={
        'build_ext': prebuilt_binary,
    },
    ext_modules=[ext_module]
)

In this example the PREBUILT_FILE environment variable contains the desired path. The cmdclass mapping is required to tell setuptools to use the prebuilt_binary class to “build” the extensions specified in ext_modules.

CMakeLists.txt example

find_package(Python REQUIRED)

file(GLOB build_wheel_SOURCE_FILES pyproject.toml setup.py)

add_custom_target(build_wheel
    COMMAND ${CMAKE_COMMAND} -E env PREBUILT_FILE=$<TARGET_FILE:py_module> ${Python_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/setup.py bdist_wheel
    SOURCES ${build_wheel_SOURCE_FILES}
    )

add_dependencies(build_wheel py_module)

In this example cmake file py_module is the name of the target that builds the extension module. It sets the PREBUILT_FILE environment variable used by setup.py to the output file of the py_module target.

Build dependencies

Don’t forget to set prebuilt_binaries as a build-time dependancy in your pyproject.toml file:

[build-system]
requires = ["setuptools", "prebuilt_binaries"]

or in your setup.cfg file:

[options]
setup_requires =
    setuptools
    prebuilt_binaries

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prebuilt-binaries-0.5.0.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

prebuilt_binaries-0.5.0-py3-none-any.whl (4.1 kB view details)

Uploaded Python 3

File details

Details for the file prebuilt-binaries-0.5.0.tar.gz.

File metadata

  • Download URL: prebuilt-binaries-0.5.0.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.0

File hashes

Hashes for prebuilt-binaries-0.5.0.tar.gz
Algorithm Hash digest
SHA256 1abdfd4f95ad2eada643db11b77145ecab9b309a5fc16e0a58e738c583fe9625
MD5 fe34bc9e4022519733a9668a23c44681
BLAKE2b-256 2361d2e16ff4d33e76439594321a24c09be31b180ace41085e3d26aaef9636b9

See more details on using hashes here.

File details

Details for the file prebuilt_binaries-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: prebuilt_binaries-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 4.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.0

File hashes

Hashes for prebuilt_binaries-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 859568868899044823cb31eb2523168faf51953044a9174a3e97fa4aabc572cf
MD5 3a59f9afd5363dd0ce750a2b21c10874
BLAKE2b-256 fc050fa7dab47fccac6dab4fd0322e79adb17d8a862db0e50cdf89843bf059a0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page