/cibuildwheel

๐ŸŽก Build Python wheels for all the platforms on CI with minimal configuration.

Primary LanguagePythonOtherNOASSERTION

cibuildwheel

PyPI Documentation Status Build Status Build status CircleCI Build Status

Documentation

Python wheels are great. Building them across Mac, Linux, Windows, on multiple versions of Python, is not.

cibuildwheel is here to help. cibuildwheel runs on your CI server - currently it supports Azure Pipelines, Travis CI, AppVeyor, GitHub Actions and CircleCI - and it builds and tests your wheels across all of your platforms.

What does it do?

macOS x86_64 Windows 64bit Windows 32bit manylinux x86_64 manylinux i686 manylinux aarch64 manylinux ppc64le manylinux s390x
CPython 2.7 โœ… โœ…ยน โœ…ยน โœ… โœ…
CPython 3.5 โœ… โœ… โœ… โœ… โœ… โœ… โœ… โœ…ยฒ
CPython 3.6 โœ… โœ… โœ… โœ… โœ… โœ… โœ… โœ…ยฒ
CPython 3.7 โœ… โœ… โœ… โœ… โœ… โœ… โœ… โœ…ยฒ
CPython 3.8 โœ… โœ… โœ… โœ… โœ… โœ… โœ… โœ…ยฒ
CPython 3.9ยณ ๐Ÿ›  ๐Ÿ›  ๐Ÿ›  ๐Ÿ›  ๐Ÿ›  ๐Ÿ›  ๐Ÿ› 
PyPy 2.7 v7.3.0 โœ… โœ… โœ…
PyPy 3.6 v7.3.0 โœ… โœ… โœ…

ยน Not supported on Travis
ยฒ Beta support until Travis CI fixes a bug
ยณ Python 3.9 is not yet ABI stable, so you shouldn't publish wheels with it yet. But if you want to check that your wheels build on Python 3.9, try our python3.9 branch!

  • Builds manylinux, macOS and Windows wheels for CPython and PyPy using Azure Pipelines, Travis CI, AppVeyor, and CircleCI
  • Bundles shared library dependencies on Linux and macOS through auditwheel and delocate
  • Runs the library test suite against the wheel-installed version of your library

Usage

cibuildwheel currently works on Travis CI, Azure Pipelines, AppVeyor and GitHub Actions to build wheels for all three supported platforms (Linux, macOS, Windows). On CircleCI Linux and macOS wheels can be built.

Linux macOS Windows
Azure Pipelines โœ… โœ… โœ…
Travis CI โœ… โœ… โœ…
AppVeyor โœ… โœ… โœ…
GitHub Actions โœ… โœ… โœ…
CircleCI โœ… โœ…

cibuildwheel is not intended to run on your development machine. Because it uses system Python from Python.org it will try to install packages globally - not what you expect from a build tool! Instead, isolated CI services like Travis CI, CircleCI, Azure Pipelines and AppVeyor are ideal.

Example setup

To build manylinux, macOS, and Windows wheels on Travis CI and upload them to PyPI whenever you tag a version, you could use this .travis.yml:

language: python

jobs:
  include:
    # perform a linux build
    - services: docker
    # and a mac build
    - os: osx
      language: shell
    # and a windows build
    - os: windows
      language: shell
      before_install:
        - choco install python --version 3.8.0
        - export PATH="/c/Python38:/c/Python38/Scripts:$PATH"

env:
  global:
    - TWINE_USERNAME=__token__
    # Note: TWINE_PASSWORD is set to a PyPI API token in Travis settings

install:
  - python3 -m pip install cibuildwheel==1.5.2

script:
  # build the wheels, put them into './wheelhouse'
  - python3 -m cibuildwheel --output-dir wheelhouse

after_success:
  # if the release was tagged, upload them to PyPI
  - |
    if [[ $TRAVIS_TAG ]]; then
      python3 -m pip install twine
      python3 -m twine upload wheelhouse/*.whl
    fi

For more information, including how to build on GitHub Actions, Appveyor, Azure Pipelines, or CircleCI, check out the documentation and the examples.

Options

Option Description
Build selection CIBW_PLATFORM Override the auto-detected target platform
CIBW_BUILD
CIBW_SKIP
Choose the Python versions to build
Build customization CIBW_ENVIRONMENT Set environment variables needed during the build
CIBW_BEFORE_ALL Execute a shell command on the build system before any wheels are built.
CIBW_BEFORE_BUILD Execute a shell command preparing each wheel's build
CIBW_REPAIR_WHEEL_COMMAND Execute a shell command to repair each (non-pure Python) built wheel
CIBW_MANYLINUX_X86_64_IMAGE
CIBW_MANYLINUX_I686_IMAGE
CIBW_MANYLINUX_PYPY_X86_64_IMAGE
CIBW_MANYLINUX_AARCH64_IMAGE
CIBW_MANYLINUX_PPC64LE_IMAGE
CIBW_MANYLINUX_S390X_IMAGE
Specify alternative manylinux docker images
CIBW_DEPENDENCY_VERSIONS Specify how cibuildwheel controls the versions of the tools it uses
Testing CIBW_TEST_COMMAND Execute a shell command to test each built wheel
CIBW_BEFORE_TEST Execute a shell command before testing each wheel
CIBW_TEST_REQUIRES Install Python dependencies before running the tests
CIBW_TEST_EXTRAS Install your wheel for testing using extras_require
Other CIBW_BUILD_VERBOSITY Increase/decrease the output of pip wheel

Working examples

Here are some repos that use cibuildwheel.

Add your repo here! Send a PR.

Legal note

Since cibuildwheel repairs the wheel with delocate or auditwheel, it might automatically bundle dynamically linked libraries from the build machine.

It helps ensure that the library can run without any dependencies outside of the pip toolchain.

This is similar to static linking, so it might have some licence implications. Check the license for any code you're pulling in to make sure that's allowed.

Changelog

1.5.2

8 July 2020

  • ๐Ÿ› Fix an issue on Windows where pyproject.toml would cause an error when some requirements formats were used. (#401)
  • ๐Ÿ›  Update CPython 3.7 to 3.7.8 (#394)

1.5.1

25 June 2020

  • ๐Ÿ› Fix "OSError: [WinError 17] The system cannot move the file to a different disk drive" on Github Actions (#388, #389)

1.5.0

24 June 2020

  • ๐ŸŒŸ Add CIBW_BEFORE_ALL option, which lets you run a command on the build machine before any wheels are built. This is especially useful when building on Linux, to make something external to Python, or to yum install a dependency. (#342)
  • โœจ Added support for projects using pyproject.toml instead of setup.py (#360, #358)
  • โœจ Added workaround to allow Python 3.5 on Windows to pull dependencies from pyproject.toml. (#358)
  • ๐Ÿ“š Improved Github Actions examples and docs (#354, #362)
  • ๐Ÿ› Ensure pip wheel uses the specified package, and doesn't build a wheel from PyPI (#369)
  • ๐Ÿ›  Internal changes: using pathlib.Path, precommit hooks, testing improvements.

1.4.2

25 May 2020

  • ๐Ÿ›  Dependency updates, including CPython 3.8.3 & manylinux images.
  • ๐Ÿ›  Lots of internal updates - type annotations and checking using mypy, and a new integration testing system.
  • โš ๏ธ Removed support for running cibuildwheel using Python 3.5. cibuildwheel will continue to build Python 3.5 wheels until EOL.

1.4.1

4 May 2020

  • ๐Ÿ› Fix a bug causing programs running inside the i686 manylinux images to think they were running x86_64 and target the wrong architecture. (#336, #338)

1.4.0

2 May 2020

  • ๐ŸŒŸ Deterministic builds. cibuildwheel now locks the versions of the tools it uses. This means that pinning your version of cibuildwheel pins the versions of pip, setuptools, manylinux etc. that are used under the hood. This should make things more reliable. But note that we don't control the entire build environment on macOS and Windows, where the version of Xcode and Visual Studio can still effect things.

    This can be controlled using the CIBW_DEPENDENCY_VERSIONS and manylinux image options - if you always want to use the latest toolchain, you can still do that, or you can specify your own pip constraints file and manylinux image. (#256)

  • โœจ Added package_dir command line option, meaning we now support building a package that lives in a subdirectory and pulls in files from the wider project. See the package_dir option help for more information.

    Note that this change makes the working directory (where you call cibuildwheel from) relevant on Linux, as it's considered the 'project' and will be copied into the Docker container. If your builds are slower on this version, that's likely the reason. cd to your project and then call cibuildwheel from there. (#319, #295)

  • ๐Ÿ›  On macOS, we make MACOSX_DEPLOYMENT_TARGET default to 10.9 if it's not set. This should make things more consistent between Python versions.

  • ๐Ÿ›  Dependency updates - CPython 3.7.7, CPython 2.7.18, Pypy 7.3.1.

1.3.0

12 March 2020

  • ๐ŸŒŸ Add support for building on Github Actions! Check out the docs for information on how to set it up. (#194)
  • โœจ Add the CIBW_BEFORE_TEST option, which lets you run a command to prepare the environment before your tests are run. (#242)

1.2.0

8 March 2020

  • ๐ŸŒŸ Add support for building PyPy wheels, across Manylinux, macOS, and Windows. (#185)
  • ๐ŸŒŸ Added the ability to build ARM64 (aarch64), ppc64le, and s390x wheels, using manylinux2014 and Travis CI. (#273)
  • โœจ You can now build macOS wheels on Appveyor. (#230)
  • ๐Ÿ›  Changed default macOS minimum target to 10.9, from 10.6. This allows the use of more modern C++ libraries, among other things. (#156)
  • ๐Ÿ›  Stop building universal binaries on macOS. We now only build x86_64 wheels on macOS. (#220)
  • โœจ Allow chaining of commands using && and || on Windows inside CIBW_BEFORE_BUILD and CIBW_TEST_COMMAND. (#293)
  • ๐Ÿ›  Improved error reporting for failed Cython builds due to stale .so files (#263)
  • ๐Ÿ›  Update CPython from 3.7.5 to 3.7.6 and from 3.8.0 to 3.8.2 on Mac/Windows
  • ๐Ÿ›  Improved error messages when a bad config breaks cibuildwheel's PATH variable. (#264)
  • โš ๏ธ Removed support for running cibuildwheel on Python 2.7. cibuildwheel will continue to build Python 2.7 wheels for a little while. (#265)

1.1.0

7 December 2019

  • ๐ŸŒŸ Add support for building manylinux2014 wheels. To use, set CIBW_MANYLINUX_X86_64_IMAGE and CIBW_MANYLINUX_I686_IMAGE to manylinux2014.
  • โœจ Add support for Linux on Appveyor (#204, #207)
  • โœจ Add CIBW_REPAIR_WHEEL_COMMAND env variable, for changing how auditwheel or delocate are invoked, or testing an equivalent on Windows. (#211)
  • ๐Ÿ“š Added some travis example configs - these are available in /examples. (#228)

1.0.0

10 November 2019

  • ๐ŸŒŸ Add support for building Python 3.8 wheels! (#180)
  • ๐ŸŒŸ Add support for building manylinux2010 wheels. cibuildwheel will now build using the manylinux2010 images by default. If your project is still manylinux1 compatible, you should get both manylinux1 and manylinux2010 wheels - you can upload both to PyPI. If you always require manylinux1 wheels, you can build using the old manylinux1 image using the manylinux image option. (#155)
  • ๐Ÿ“š Documentation is now on its own mini-site, rather than on the README (#169)
  • โœจ Add support for building Windows wheels on Travis CI. (#160)
  • ๐Ÿ›  If you set CIBW_TEST_COMMAND, your tests now run in a virtualenv. (#164)
  • ๐Ÿ›  Windows now uses Python as installed by nuget, rather than the versions installed by the various CI providers. (#180)
  • ๐Ÿ›  Update Python from 2.7.16 to 2.7.17 and 3.7.4 to 3.7.5 on macOS (#171)
  • โš ๏ธ Removed support for Python 3.4 (#168)

0.12.0

29 September 2019

  • โœจ Add CIBW_TEST_EXTRAS option, to allow testing using extra_require options. For example, set CIBW_TEST_EXTRAS=test,qt to make the wheel installed with pip install <wheel_file>[test,qt]
  • ๐Ÿ›  Update Python from 3.7.2 to 3.7.4 on macOS
  • ๐Ÿ›  Update OpenSSL patch to 1.0.2t on macOS

0.11.1

28 May 2019

  • ๐Ÿ› Fix missing file in the release tarball, that was causing problems with Windows builds (#141)

0.11.0

26 May 2019

  • ๐ŸŒŸ Add support for building on Azure pipelines! This lets you build all Linux, Mac and Windows wheels on one service, so it promises to be the easiest to set up! Check out the quickstart in the docs, or cibuildwheel-azure-example for an example project. (#126, #132)
  • ๐Ÿ›  Internal change - the end-to-end test projects format was updated, so we can more precisely assert what should be produced for each one. (#136, #137).

0.10.2

10 March 2019

  • ๐Ÿ›  Revert temporary fix in macOS, that was working around a bug in pip 19 (#129)
  • ๐Ÿ›  Update Python to 2.7.16 on macOS
  • ๐Ÿ›  Update OpenSSL patch to 1.0.2r on macOS

0.10.1

3 February 2019

  • ๐Ÿ› Fix build stalling on macOS (that was introduced in pip 19) (#122)
  • ๐Ÿ› Fix "AttributeError: 'Popen' object has no attribute 'args'" on Python 2.7 for Linux builds (#108)
  • ๐Ÿ›  Update Python from 3.6.7, 3.7.1 to 3.6.8, 3.7.2 on macOS
  • ๐Ÿ›  Update openssl patch from 1.0.2p to 1.0.2q on macOS
  • ๐Ÿ›  Sorting build options dict items when printing preamble (#114)

0.10.0

23 September 2018

  • ๐ŸŒŸ Add CIBW_BUILD option, for specifying which specific builds to perform (#101)
  • ๐ŸŒŸ Add support for building Mac and Linux on CircleCI (#91, #97)
  • ๐Ÿ›  Improved support for building universal wheels (#95)
  • ๐Ÿ›  Ensure log output is unbuffered and therefore in the correct order (#92)
  • ๐Ÿ›  Improved error reporting for errors that occur inside a package's setup.py (#88)
  • โš ๏ธ Removed support for Python 3.3 on Windows.

0.9.4

29 July 2018

  • ๐Ÿ›  CIBW_TEST_COMMAND now runs in a shell on Mac (as well as Linux) (#81)

0.9.3

10 July 2018

  • ๐Ÿ›  Update to Python 3.6.6 on macOS (#82)
  • โœจ Add support for building Python 3.7 wheels on Windows (#76)
  • โš ๏ธ Deprecated support for Python 3.3 on Windows.

0.9.2

1 July 2018

  • ๐Ÿ›  Update Python 3.7.0rc1 to 3.7.0 on macOS (#79)

0.9.1

18 June 2018

  • ๐Ÿ›  Removed the need to use {python} and {pip} in CIBW_BEFORE_BUILD statements, by ensuring the correct version is always on the path at python and pip instead. (#60)
  • ๐Ÿ›  We now patch the _ssl module on Python 3.4 and 3.5 so these versions can still make SSL web requests using TLS 1.2 while building. (#71)

0.9.0

18 June 2018

  • โœจ Add support for Python 3.7 (#73)

0.8.0

4 May 2018

  • โš ๏ธ Drop support for Python 3.3 on Linux (#67)
  • ๐Ÿ› Fix TLS by updating setuptools (#69)

0.7.1

2 April 2017

  • ๐Ÿ› macOS: Fix Pip bugs resulting from PyPI TLS 1.2 enforcement
  • ๐Ÿ› macOS: Fix brew Python3 version problems in the CI

0.7.0

7 January 2018

  • โœจ You can now specify a custom docker image using the CIBW_MANYLINUX1_X86_64_IMAGE and CIBW_MANYLINUX1_I686_IMAGE options. (#46)
  • ๐Ÿ› Fixed a bug where cibuildwheel would download and build a package from PyPI(!) instead of building the package on the local machine. (#51)

0.6.0

9 October 2017

  • โœจ On the Linux build, the host filesystem is now accessible via /host (#36)
  • ๐Ÿ› Fixed a bug where setup.py scripts would run the wrong version of Python when running subprocesses on Linux (#35)

0.5.1

10 September 2017

  • ๐Ÿ› Fixed a couple of bugs on Python 3.
  • โœจ Added experimental support for Mac builds on Bitrise.io

0.5.0

7 September 2017

  • โœจ CIBW_ENVIRONMENT added. You can now set environment variables for each build, even within the Docker container on Linux. This is a big one! (#21)
  • โœจ CIBW_BEFORE_BUILD now runs in a system shell on all platforms. You can now do things like CIBW_BEFORE_BUILD="cmd1 && cmd2". (#32)

0.4.1

14 August 2017

  • ๐Ÿ› Fixed a bug on Windows where subprocess' output was hidden (#23)
  • ๐Ÿ› Fixed a bug on AppVeyor where logs would appear in the wrong order due to output buffering (#24, thanks @YannickJadoul!)

0.4.0

23 July 2017

  • ๐Ÿ› Fixed a bug that was increasing the build time by building the wheel twice. This was a problem for large projects that have a long build time. If you're upgrading and you need the old behaviour, use CIBW_BEFORE_BUILD={pip} install ., or install exactly the dependencies you need in CIBW_BEFORE_BUILD. See #18.

0.3.0

27 June 2017

  • โš ๏ธ Removed Python 2.6 support on Linux (#12)

0.2.1

11 June 2017

  • ๐Ÿ›  Changed the build process to install the package before building the wheel - this allows direct dependencies to be installed first (#9, thanks @tgarc!)
  • โœจ Added Python 3 support for the main process, for systems where Python 3 is the default (#8, thanks @tgarc).

0.2.0

13 April 2017

  • โœจ Added CIBW_SKIP option, letting users explicitly skip a build
  • โœจ Added CIBW_BEFORE_BUILD option, letting users run a shell command before the build starts

0.1.3

31 March 2017

  • ๐ŸŒŸ First public release!

Contributing

For more info on how to contribute to cibuildwheel, see the docs.

Maintainers

Credits

cibuildwheel stands on the shoulders of giants.

Massive props also to-

See also

If you'd like to keep wheel building separate from the package itself, check out astrofrog/autowheel. It builds packages using cibuildwheel from source distributions on PyPI.

If cibuildwheel is too limited for your needs, consider matthew-brett/multibuild. multibuild is a toolbox for building a wheel on various platforms. It can do a lot more than this project - it's used to build SciPy!