Commit eacbb250 authored by Jason Madden's avatar Jason Madden

We require headers from greenlet at build time so it is a setup_requires.

parent cc6b2dff
...@@ -31,7 +31,12 @@ Platform Support ...@@ -31,7 +31,12 @@ Platform Support
Build Changes Build Changes
------------- -------------
- Fix building from a source distribution (PyPI) without Cython installed. - Fix building from a source distribution (PyPI) without Cython
installed.
- greenlet is now required at build time. If it is not installed
before gevent is installed, gevent will be built twice when
installing from source.
Enhancements Enhancements
------------ ------------
......
...@@ -124,15 +124,21 @@ if not SKIP_LIBUV: ...@@ -124,15 +124,21 @@ if not SKIP_LIBUV:
# but manylinux1 has only 2.5, so we set SKIP_LIBUV in the script make-manylinux # but manylinux1 has only 2.5, so we set SKIP_LIBUV in the script make-manylinux
cffi_modules.append(LIBUV_CFFI_MODULE) cffi_modules.append(LIBUV_CFFI_MODULE)
install_requires = [ greenlet_requires = [
# We need to watch our greenlet version fairly carefully, # We need to watch our greenlet version fairly carefully,
# since we compile cython code that extends the greenlet object. # since we compile cython code that extends the greenlet object.
# Binary compatibility would break if the greenlet struct changes. # Binary compatibility would break if the greenlet struct changes.
'greenlet >= 0.4.13; platform_python_implementation=="CPython"', 'greenlet >= 0.4.13; platform_python_implementation=="CPython"',
] ]
setup_requires = [ install_requires = greenlet_requires + []
]
# We use headers from greenlet, so it needs to be installed before we can compile.
# XXX: This doesn't quite seem to work: pip tries to build the wheel, which
# fails because greenlet is not installed (it's in a .eggs/ directory in the
# build directory, but that directory doesn't have includes). Then it installs greenlet,
# and builds gevent again, which works.
setup_requires = greenlet_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
......
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