Commit 5f35cab5 authored by Denis Bilenko's avatar Denis Bilenko

setup.py: run cython if core.c is out of date

parent b1e8b4a5
...@@ -46,39 +46,57 @@ libraries = [] ...@@ -46,39 +46,57 @@ libraries = []
extra_objects = [] extra_objects = []
# hack: create a symlink from build/../core.so to gevent/core.so to prevent "ImportError: cannot import name core" failures
cmdclass = {} cmdclass = {}
try: class my_build_ext(build_ext.build_ext):
from distutils.command import build_ext
class my_build_ext(build_ext.build_ext): def compile_cython(self):
def build_extension(self, ext): sources = glob.glob('gevent/*.pyx') + sorted(glob.glob('gevent/*.pxi'))
result = build_ext.build_ext.build_extension(self, ext) if not sources:
try: print >> sys.stderr, 'Could not find gevent.core sources'
fullname = self.get_ext_fullname(ext.name) return
modpath = fullname.split('.') core_c_mtime = os.stat('gevent/core.c').st_mtime
filename = self.get_ext_filename(ext.name) changed = [filename for filename in sources if os.stat(filename).st_mtime >= core_c_mtime]
filename = os.path.split(filename)[-1] if changed:
if not self.inplace: print >> sys.stderr, 'Running cython (changed: %s)' % ', '.join(changed)
filename = os.path.join(*modpath[:-1] + [filename]) cython_result = os.system('cython gevent/core.pyx')
path_to_build_core_so = abspath(os.path.join(self.build_lib, filename)) if cython_result:
path_to_core_so = abspath(join('gevent', basename(path_to_build_core_so))) if os.system('cython -V 2> %s' % os.devnull):
if path_to_build_core_so != path_to_core_so: # there's no cython in the system
print >> sys.stderr, 'No cython found, cannot rebuild core.c'
return
sys.exit(1)
def build_extension(self, ext):
self.compile_cython()
result = build_ext.build_ext.build_extension(self, ext)
# hack: create a symlink from build/../core.so to gevent/core.so
# to prevent "ImportError: cannot import name core" failures
try:
fullname = self.get_ext_fullname(ext.name)
modpath = fullname.split('.')
filename = self.get_ext_filename(ext.name)
filename = os.path.split(filename)[-1]
if not self.inplace:
filename = os.path.join(*modpath[:-1] + [filename])
path_to_build_core_so = abspath(os.path.join(self.build_lib, filename))
path_to_core_so = abspath(join('gevent', basename(path_to_build_core_so)))
if path_to_build_core_so != path_to_core_so:
try:
os.unlink(path_to_core_so)
except OSError:
pass
if hasattr(os, 'symlink'):
print 'Linking %s to %s' % (path_to_build_core_so, path_to_core_so) print 'Linking %s to %s' % (path_to_build_core_so, path_to_core_so)
try: os.symlink(path_to_build_core_so, path_to_core_so)
os.unlink(path_to_core_so) else:
except OSError: print 'Copying %s to %s' % (path_to_build_core_so, path_to_core_so)
pass import shutil
if hasattr(os, 'symlink'): shutil.copyfile(path_to_build_core_so, path_to_core_so)
os.symlink(path_to_build_core_so, path_to_core_so) except Exception:
else: traceback.print_exc()
import shutil return result
shutil.copyfile(path_to_build_core_so, path_to_core_so)
except Exception: cmdclass = {'build_ext': my_build_ext}
traceback.print_exc()
return result
cmdclass = {'build_ext': my_build_ext}
except Exception:
traceback.print_exc()
def check_dir(path, must_exist): def check_dir(path, must_exist):
......
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