Commit 96435ee9 authored by Jason Madden's avatar Jason Madden

Packaging updates: use common_utility_include_dir for Cython, and don't...

Packaging updates: use common_utility_include_dir for Cython, and don't install/include generated .c/.h files in wheels
parent 36704768
...@@ -7,6 +7,7 @@ build/ ...@@ -7,6 +7,7 @@ build/
*.egg-info *.egg-info
gevent.*.[ch] gevent.*.[ch]
src/gevent/__pycache__ src/gevent/__pycache__
# Things generated by cython
src/gevent/_semaphore.c src/gevent/_semaphore.c
src/gevent/local.c src/gevent/local.c
src/gevent/greenlet.c src/gevent/greenlet.c
...@@ -25,6 +26,7 @@ src/gevent/libev/corecext.h ...@@ -25,6 +26,7 @@ src/gevent/libev/corecext.h
src/gevent/libev/_corecffi.c src/gevent/libev/_corecffi.c
src/gevent/libev/_corecffi.o src/gevent/libev/_corecffi.o
src/gevent/resolver/cares.c src/gevent/resolver/cares.c
src/gevent/_generated_include/*.h
# Cython annotations # Cython annotations
src/gevent/*.html src/gevent/*.html
......
...@@ -18,6 +18,10 @@ Platform and Packaging Updates ...@@ -18,6 +18,10 @@ Platform and Packaging Updates
tweaked with the intent of making it easier to use older debug tweaked with the intent of making it easier to use older debug
versions of Python. See :issue:`1461`. versions of Python. See :issue:`1461`.
- The binary wheels and installed package no longer include generated
C source files and headers. Also excluded are Cython .pxd files,
which were never documented. Please file an issue if you miss these.
Library and Dependency Updates Library and Dependency Updates
------------------------------ ------------------------------
......
...@@ -26,6 +26,7 @@ from _setuputils import dep_abspath ...@@ -26,6 +26,7 @@ from _setuputils import dep_abspath
from _setuputils import RUNNING_ON_CI from _setuputils import RUNNING_ON_CI
from _setuputils import RUNNING_FROM_CHECKOUT from _setuputils import RUNNING_FROM_CHECKOUT
from _setuputils import cythonize1 from _setuputils import cythonize1
from _setuputils import get_include_dirs
CARES_EMBED = should_embed('c-ares') CARES_EMBED = should_embed('c-ares')
...@@ -85,13 +86,18 @@ def configure_ares(bext, ext): ...@@ -85,13 +86,18 @@ def configure_ares(bext, ext):
os.chdir(cwd) os.chdir(cwd)
ARES = Extension(name='gevent.resolver.cares', ARES = Extension(
sources=['src/gevent/resolver/cares.pyx'], name='gevent.resolver.cares',
include_dirs=['src/gevent/resolver'] + [dep_abspath('c-ares')] if CARES_EMBED else [], sources=[
libraries=list(LIBRARIES), 'src/gevent/resolver/cares.pyx'
define_macros=list(DEFINE_MACROS), ],
depends=glob_many('src/gevent/resolver/dnshelper.c', include_dirs=get_include_dirs(*([dep_abspath('c-ares')] if CARES_EMBED else [])),
'src/gevent/resolver/cares_*.[ch]')) libraries=list(LIBRARIES),
define_macros=list(DEFINE_MACROS),
depends=glob_many(
'src/gevent/resolver/dnshelper.c',
'src/gevent/resolver/cares_*.[ch]')
)
ares_required = RUNNING_ON_CI and RUNNING_FROM_CHECKOUT ares_required = RUNNING_ON_CI and RUNNING_FROM_CHECKOUT
ARES.optional = not ares_required ARES.optional = not ares_required
......
...@@ -153,7 +153,7 @@ def make_universal_header(filename, *defines): ...@@ -153,7 +153,7 @@ def make_universal_header(filename, *defines):
break break
print(line, file=f) print(line, file=f)
def get_include_dirs(): def get_include_dirs(*extra_paths):
""" """
Return additional include directories that might be needed to Return additional include directories that might be needed to
compile extensions. Specifically, we need the greenlet.h header compile extensions. Specifically, we need the greenlet.h header
...@@ -161,7 +161,7 @@ def get_include_dirs(): ...@@ -161,7 +161,7 @@ def get_include_dirs():
""" """
# setuptools will put the normal include directory for Python.h on the # setuptools will put the normal include directory for Python.h on the
# include path automatically. We don't want to override that with # include path automatically. We don't want to override that with
# a different Python3h if we can avoid it: On older versions of Python, # a different Python.h if we can avoid it: On older versions of Python,
# that can cause issues with debug builds (see https://github.com/gevent/gevent/issues/1461) # that can cause issues with debug builds (see https://github.com/gevent/gevent/issues/1461)
# so order matters here. # so order matters here.
# #
...@@ -192,7 +192,7 @@ def get_include_dirs(): ...@@ -192,7 +192,7 @@ def get_include_dirs():
return [ return [
p p
for p in (dist_inc_dir, sys_inc_dir, dep_inc_dir) for p in (dist_inc_dir, sys_inc_dir, dep_inc_dir) + extra_paths
if os.path.exists(p) if os.path.exists(p)
] ]
...@@ -213,7 +213,11 @@ def system(cmd, cwd=None, env=None, **kwargs): ...@@ -213,7 +213,11 @@ def system(cmd, cwd=None, env=None, **kwargs):
sys.exit(1) sys.exit(1)
###
# Cython # Cython
###
COMMON_UTILITY_INCLUDE_DIR = "src/gevent/_generated_include"
# Based on code from # Based on code from
# http://cython.readthedocs.io/en/latest/src/reference/compilation.html#distributing-cython-modules # http://cython.readthedocs.io/en/latest/src/reference/compilation.html#distributing-cython-modules
...@@ -236,17 +240,49 @@ except ImportError: ...@@ -236,17 +240,49 @@ except ImportError:
cythonize = _dummy_cythonize cythonize = _dummy_cythonize
def cythonize1(ext): def cythonize1(ext):
# All the directories we have .pxd files
# and .h files that are included regardless of
# embed settings.
standard_include_paths = [
'src/gevent',
'src/gevent/libev',
'src/gevent/resolver',
# This is for generated include files; see below.
'.',
]
try: try:
new_ext = cythonize( new_ext = cythonize(
[ext], [ext],
include_path=['src/gevent', 'src/gevent/libev', 'src/gevent/resolver'], include_path=standard_include_paths,
annotate=True, annotate=True,
compiler_directives={ compiler_directives={
'language_level': '3str', 'language_level': '3str',
'always_allow_keywords': False, 'always_allow_keywords': False,
'infer_types': True, 'infer_types': True,
'nonecheck': False, 'nonecheck': False,
} },
# The common_utility_include_dir (not well documented)
# causes Cython to emit separate files for much of the
# static support code. Each of the modules then includes
# the static files they need. They have hash names based
# on digest of all the relevant compiler directives,
# including those set here and those set in the file. It's
# worth monitoring to be sure that we don't start to get
# divergent copies; make sure files declare the same
# options.
#
# The value used here must be listed in the above ``include_path``,
# and included in sdists. Files will be included based on this
# full path, so its parent directory, ``.``, must be on the runtime
# include path.
common_utility_include_dir=COMMON_UTILITY_INCLUDE_DIR,
# The ``cache`` argument is not well documented, but causes Cython to
# cache to disk some intermediate results. In the past, this was
# incompatible with ``common_utility_include_dir``, but not anymore.
# However, it seems to only function on posix (it spawns ``du``).
# It doesn't seem to buy us much speed, and results in a bunch of
# ResourceWarnings about unclosed files.
# cache="build/cycache",
)[0] )[0]
except ValueError: except ValueError:
# 'invalid literal for int() with base 10: '3str' # 'invalid literal for int() with base 10: '3str'
...@@ -262,8 +298,29 @@ def cythonize1(ext): ...@@ -262,8 +298,29 @@ def cythonize1(ext):
if hasattr(ext, optional_attr): if hasattr(ext, optional_attr):
setattr(new_ext, optional_attr, setattr(new_ext, optional_attr,
getattr(ext, optional_attr)) getattr(ext, optional_attr))
new_ext.extra_compile_args.extend(IGNORE_THIRD_PARTY_WARNINGS)
new_ext.include_dirs.extend(standard_include_paths)
return new_ext return new_ext
# A tuple of arguments to add to ``extra_compile_args``
# to ignore warnings from third-party code we can't do anything
# about.
IGNORE_THIRD_PARTY_WARNINGS = ()
if sys.platform == 'darwin':
# macos, or other platforms using clang
# (TODO: How to detect clang outside those platforms?)
IGNORE_THIRD_PARTY_WARNINGS += (
# If clang is old and doesn't support the warning, these
# are ignored, albeit not silently.
# The first two are all over the place from Cython.
'-Wno-unreachable-code',
'-Wno-deprecated-declarations',
# generic, started with some xcode update
'-Wno-incompatible-sysroot',
# libuv
'-Wno-tautological-compare',
'-Wno-implicit-function-declaration',
)
## Distutils extensions ## Distutils extensions
class BuildFailed(Exception): class BuildFailed(Exception):
...@@ -322,8 +379,10 @@ class ConfiguringBuildExt(build_ext): ...@@ -322,8 +379,10 @@ class ConfiguringBuildExt(build_ext):
class Extension(_Extension): class Extension(_Extension):
# This class exists currently mostly to make pylint # This class has a few functions:
# happy in terms of attributes we use. #
# 1. Make pylint happy in terms of attributes we use.
# 2. Add default arguments, often platform specific.
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
self.libraries = [] self.libraries = []
...@@ -366,6 +425,7 @@ class GeventClean(clean): ...@@ -366,6 +425,7 @@ class GeventClean(clean):
dirs_to_remove = [ dirs_to_remove = [
'htmlcov', 'htmlcov',
'.eggs', '.eggs',
COMMON_UTILITY_INCLUDE_DIR,
] ]
if self.all: if self.all:
dirs_to_remove += [ dirs_to_remove += [
......
...@@ -14,3 +14,5 @@ ignore = ...@@ -14,3 +14,5 @@ ignore =
src/gevent/*.html src/gevent/*.html
src/gevent/libev/corecext.h src/gevent/libev/corecext.h
src/gevent/libev/corecext.html src/gevent/libev/corecext.html
src/gevent/_generated_include/*.h
src/gevent/_generated_include
...@@ -325,7 +325,26 @@ def run_setup(ext_modules): ...@@ -325,7 +325,26 @@ def run_setup(ext_modules):
}, },
package_dir={'': 'src'}, package_dir={'': 'src'},
packages=find_packages('src'), packages=find_packages('src'),
include_package_data=True, # Using include_package_data causes our generated .c and .h
# files to be included in the installation. Those aren't needed
# at runtime (the .html files generated by Cython's annotation are
# much nicer to browse anyway, but we don't want to include those either), and downstream
# distributors have complained about them, so we don't want to include them.
# Nor do we want to include .pyx or .pxd files that aren't considered public;
# the only .pxd files that ever offered the required Cython annotations to produce
# stable APIs where in the libev cext backend. For ease of packaging, though, let's not
# include those either unless we get requests.
# include_package_data=True,
package_data={
# For any package
'': [
# Include files needed to run tests
'*.pem',
'*.crt',
'*.txt',
'*.key',
]
},
ext_modules=ext_modules, ext_modules=ext_modules,
cmdclass={ cmdclass={
'build_ext': ConfiguringBuildExt, 'build_ext': ConfiguringBuildExt,
......
...@@ -259,13 +259,16 @@ if not LIBUV_EMBED: ...@@ -259,13 +259,16 @@ if not LIBUV_EMBED:
LIBUV_INCLUDE_DIRS.append(parentdir) LIBUV_INCLUDE_DIRS.append(parentdir)
ffi.cdef(_cdef) ffi.cdef(_cdef)
ffi.set_source('gevent.libuv._corecffi', ffi.set_source(
_source, 'gevent.libuv._corecffi',
sources=LIBUV_SOURCES, _source,
depends=LIBUV_SOURCES, sources=LIBUV_SOURCES,
include_dirs=LIBUV_INCLUDE_DIRS, depends=LIBUV_SOURCES,
libraries=list(LIBUV_LIBRARIES), include_dirs=LIBUV_INCLUDE_DIRS,
define_macros=list(LIBUV_MACROS)) libraries=list(LIBUV_LIBRARIES),
define_macros=list(LIBUV_MACROS),
extra_compile_args=list(_setuputils.IGNORE_THIRD_PARTY_WARNINGS),
)
if __name__ == '__main__': if __name__ == '__main__':
# See notes in libev/_corecffi_build.py for how to test this. # See notes in libev/_corecffi_build.py for how to test this.
......
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