Skip to content

Commit

Permalink
Adding PyPy builds to Linux, using the manylinux2010-pypy_x86_64 image
Browse files Browse the repository at this point in the history
  • Loading branch information
YannickJadoul committed Oct 30, 2019
1 parent a6164f7 commit 2501c06
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 1 deletion.
5 changes: 4 additions & 1 deletion cibuildwheel/__main__.py
Original file line number Diff line number Diff line change
Expand Up @@ -147,15 +147,18 @@ def main():
if platform == 'linux':
manylinux_x86_64_image = os.environ.get('CIBW_MANYLINUX_X86_64_IMAGE', 'manylinux2010')
manylinux_i686_image = os.environ.get('CIBW_MANYLINUX_I686_IMAGE', 'manylinux2010')
manylinux_pypy_x86_64_image = os.environ.get('CIBW_MANYLINUX_PYPY_X86_64_IMAGE', 'manylinux2010')

default_manylinux_images_x86_64 = {'manylinux1': 'quay.io/pypa/manylinux1_x86_64',
'manylinux2010': 'quay.io/pypa/manylinux2010_x86_64'}
default_manylinux_images_i686 = {'manylinux1': 'quay.io/pypa/manylinux1_i686',
'manylinux2010': 'quay.io/pypa/manylinux2010_i686'}
default_manylinux_images_pypy_x86_64 = {'manylinux2010': 'pypywheels/manylinux2010-pypy_x86_64'}

build_options.update(
manylinux_images={'x86_64': default_manylinux_images_x86_64.get(manylinux_x86_64_image) or manylinux_x86_64_image,
'i686': default_manylinux_images_i686.get(manylinux_i686_image) or manylinux_i686_image},
'i686': default_manylinux_images_i686.get(manylinux_i686_image) or manylinux_i686_image,
'pypy_x86_64': default_manylinux_images_pypy_x86_64.get(manylinux_i686_image) or manylinux_pypy_x86_64_image},
)
elif platform == 'macos':
pass
Expand Down
3 changes: 3 additions & 0 deletions cibuildwheel/linux.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ def get_python_configurations(build_selector):
PythonConfiguration(identifier='cp35-manylinux_i686', path='/opt/python/cp35-cp35m'),
PythonConfiguration(identifier='cp36-manylinux_i686', path='/opt/python/cp36-cp36m'),
PythonConfiguration(identifier='cp37-manylinux_i686', path='/opt/python/cp37-cp37m'),
PythonConfiguration(identifier='pp271-manylinux_pypy_x86_64', path='/opt/python/pp271-pypy_41'),
PythonConfiguration(identifier='pp371-manylinux_pypy_x86_64', path='/opt/python/pp371-pypy3_71'),
]

# skip builds as required
Expand All @@ -44,6 +46,7 @@ def build(project_dir, output_dir, test_command, test_requires, test_extras, bef
platforms = [
('manylinux_x86_64', manylinux_images['x86_64']),
('manylinux_i686', manylinux_images['i686']),
('manylinux_pypy_x86_64', manylinux_images['pypy_x86_64']),
]

for platform_tag, docker_image in platforms:
Expand Down
4 changes: 4 additions & 0 deletions test/shared/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ def expected_wheels(package_name, package_version):
'{package_name}-{package_version}-cp35-cp35m-manylinux2010_i686.whl',
'{package_name}-{package_version}-cp36-cp36m-manylinux2010_i686.whl',
'{package_name}-{package_version}-cp37-cp37m-manylinux2010_i686.whl',
'{package_name}-{package_version}-pp271-pypy_41-manylinux1_x86_64.whl',
'{package_name}-{package_version}-pp371-pypy3_71-manylinux1_x86_64.whl',
'{package_name}-{package_version}-pp271-pypy_41-manylinux2010_x86_64.whl',
'{package_name}-{package_version}-pp371-pypy3_71-manylinux2010_x86_64.whl',
]
elif platform == 'windows':
templates = [
Expand Down

0 comments on commit 2501c06

Please sign in to comment.