Commit e2aef582 authored by Jason Madden's avatar Jason Madden Committed by GitHub

Merge pull request #1174 from gevent/cffi-win

Use environment markers to install CFFI on windows so the libuv backend can really be default
parents 38b9f54f 7fdfbc3b
...@@ -7,7 +7,8 @@ ...@@ -7,7 +7,8 @@
1.3b2 (unreleased) 1.3b2 (unreleased)
================== ==================
- Nothing changed yet. - On Windows, CFFI is now a dependency so that the libuv backend
really can be used by default.
1.3b1 (2018-04-13) 1.3b1 (2018-04-13)
......
...@@ -118,20 +118,14 @@ install: ...@@ -118,20 +118,14 @@ install:
# Upgrade to the latest version of pip to avoid it displaying warnings # Upgrade to the latest version of pip to avoid it displaying warnings
# about it being out of date. # about it being out of date.
- "%CMD_IN_ENV% pip install --disable-pip-version-check --user --upgrade pip" - "%CMD_IN_ENV% %PYEXE% -m pip install --disable-pip-version-check --user --upgrade pip"
# Install the build dependencies of the project. If some dependencies contain # Install the build dependencies of the project. If some dependencies contain
# compiled extensions and are not provided as pre-built wheel packages, # compiled extensions and are not provided as pre-built wheel packages,
# pip will build them from source using the MSVC compiler matching the # pip will build them from source using the MSVC compiler matching the
# target Python version and architecture # target Python version and architecture
# Note that psutil won't build under PyPy on Windows. - "%CMD_IN_ENV% %PYEXE% -m pip install -U -r ci-requirements.txt"
- "%CMD_IN_ENV% pip install -U cython zope.interface zope.event"
- "%CMD_IN_ENV% pip install -U setuptools wheel greenlet cffi dnspython idna requests"
- ps:
if ("${env:PYTHON_ID}" -ne "pypy") {
pip install psutil | Out-Null;
}
- ps: "if(Test-Path(\"${env:PYTHON}\\bin\")) {ls ${env:PYTHON}\\bin;}" - ps: "if(Test-Path(\"${env:PYTHON}\\bin\")) {ls ${env:PYTHON}\\bin;}"
- ps: "if(Test-Path(\"${env:PYTHON}\\Scripts\")) {ls ${env:PYTHON}\\Scripts;}" - ps: "if(Test-Path(\"${env:PYTHON}\\Scripts\")) {ls ${env:PYTHON}\\Scripts;}"
...@@ -148,7 +142,7 @@ build_script: ...@@ -148,7 +142,7 @@ build_script:
# into a variable, using python to glob. # into a variable, using python to glob.
- "%PYEXE% -c \"import glob; print(glob.glob('dist/*whl')[0])\" > whl.txt" - "%PYEXE% -c \"import glob; print(glob.glob('dist/*whl')[0])\" > whl.txt"
- set /p PYWHL=<whl.txt - set /p PYWHL=<whl.txt
- pip install %PYWHL% - "%PYEXE% -m pip install %PYWHL%"
test_script: test_script:
# Run the project tests # Run the project tests
......
...@@ -12,26 +12,23 @@ greenlet>=0.4.13 ; platform_python_implementation == "CPython" ...@@ -12,26 +12,23 @@ greenlet>=0.4.13 ; platform_python_implementation == "CPython"
pylint>=1.8.0 pylint>=1.8.0
# pyyaml is included here and doesn't install on travis with 3.7a3 # pyyaml is included here and doesn't install on travis with 3.7a3
prospector[with_pyroma] ; python_version < '3.7' prospector[with_pyroma] ; python_version < '3.7'
coverage>=4.0 # We don't run coverage on Windows, and pypy can't build it there
coveralls>=1.0 # anyway (coveralls -> cryptopgraphy -> openssl)
coverage>=4.0 ; sys_platform != 'win32'
coveralls>=1.0 ; sys_platform != 'win32'
# See version requirements in setup.py # See version requirements in setup.py
cffi >= 1.11.5 ; platform_python_implementation == "CPython" cffi >= 1.11.5 ; platform_python_implementation == "CPython"
futures futures
dnspython dnspython
idna idna
# Makes tests faster # Makes tests faster
psutil # Fails to build on PyPy on Windows.
psutil ; platform_python_implementation == "CPython" or sys_platform != "win32"
# benchmarks use this # benchmarks use this
perf perf
# examples, called from tests, use this
requests
# Events # Events
zope.event zope.event
zope.interface zope.interface
# Tests
requests
# For viewing README.rst (restview --long-description),
# CONTRIBUTING.rst, etc.
# https://github.com/mgedmin/restview
restview
-r rtd-requirements.txt
-r ci-requirements.txt -r ci-requirements.txt
-r rtd-requirements.txt
-e . -e .
...@@ -190,7 +190,21 @@ greenlet_requires = [ ...@@ -190,7 +190,21 @@ greenlet_requires = [
'greenlet >= 0.4.13; platform_python_implementation=="CPython"', 'greenlet >= 0.4.13; platform_python_implementation=="CPython"',
] ]
install_requires = greenlet_requires + [] # Note that we don't add cffi to install_requires, it's
# optional. We tend to build and distribute wheels with the CFFI
# modules built and they can be imported if CFFI is installed.
# We need cffi 1.4.0 for new style callbacks;
# we need cffi 1.11.3 (on CPython 3) to avoid test errors.
# The exception is on Windows, where we want the libuv backend we distribute
# to be the default, and that requires cffi; but don't try to install it
# on PyPy or it messes up the build
cffi_requires = [
"cffi >= 1.11.5 ; sys_platform == 'win32' and platform_python_implementation == 'CPython'",
]
install_requires = greenlet_requires + cffi_requires
# We use headers from greenlet, so it needs to be installed before we # We use headers from greenlet, so it needs to be installed before we
# can compile. If it isn't already installed before we start # can compile. If it isn't already installed before we start
...@@ -204,7 +218,7 @@ install_requires = greenlet_requires + [] ...@@ -204,7 +218,7 @@ install_requires = greenlet_requires + []
# to install the headers at all, AFAICS, we don't need to bother with # to install the headers at all, AFAICS, we don't need to bother with
# the buggy setup_requires.) # the buggy setup_requires.)
setup_requires = [] setup_requires = cffi_requires + []
if PYPY: if PYPY:
# These use greenlet/greenlet.h, which doesn't exist on PyPy # These use greenlet/greenlet.h, which doesn't exist on PyPy
...@@ -249,18 +263,6 @@ for mod in _to_cythonize: ...@@ -249,18 +263,6 @@ for mod in _to_cythonize:
EXT_MODULES.append(cythonize1(mod)) EXT_MODULES.append(cythonize1(mod))
del _to_cythonize del _to_cythonize
try:
cffi = __import__('cffi')
except ImportError:
pass
else:
# Note that we don't add cffi to install_requires, it's
# optional. We tend to build and distribute wheels with the CFFI
# modules built and they can be imported if CFFI is installed.
# We need cffi 1.4.0 for new style callbacks;
# we need cffi 1.11.3 (on CPython 3) to avoid test errors
# install_requires.append('cffi >= 1.4.0')
pass
if IGNORE_CFFI and not PYPY: if IGNORE_CFFI and not PYPY:
# Allow distributors to turn off CFFI builds # Allow distributors to turn off CFFI builds
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment