我正在开发一个包含Cython扩展的包。
根据https://github.com/pypa/pip/issues/1958,我将使用setup_requires
,推迟Cython
的进口。我想出的最好的解决方案是在setup()
中调用setup.py
两次
... # initial imports
setup(setup_requires=['cython'])
from Cython.Build import cythonize
bar = Extension('foo.bar', sources = ['bar.pyx'])
setup(name = 'foo',
... # parameters
ext_modules = cythonize([bar]),
... # more parameters
)
然而,我有一种感觉,setup()
的名字意味着它只会被命名一次。像我一样叫几次会安全吗?
我不能只是分发车轮,因为包也将提供给Linux用户。
编辑
此外,我认为这个问题比处理编译器依赖关系更为普遍。一个人可能想进口一些包裹(例如。( sphinx
或pweave
)对其包的描述进行预处理。
发布于 2017-09-08 15:27:09
简单的答案是:No。调用安装程序后,它将解析命令行参数并开始工作。
至于Cython
依赖关系,setup_requires
在这里无能为力。它可能会尝试下载Cython
而不安装。正如SpotlightKid评论的那样:
distutils也不会试图成为编译器,也不会将gcc安装为依赖项。
根据setuptools工具
如果使用distutils扩展,则需要此参数(setup_requires),
因此,不适用于像Cython
这样的软件包。
我认为在调用Cython
之前,用户应该负责安装setup.py
。如果您想提供更友好的错误消息,请尝试使用
try:
from Cython.Build import cythonize
except ImportError:
# Kindly ask the user to install Cython
下列员额可能会有所帮助:
发布于 2018-05-22 12:41:15
我有一个不同的场景,需要多次运行setup()
:在我的例子中,我是从相同的源构建两个包。第一个包是一个基于Fabric
的命令行工具,第二个包只是库(API、工具等)。对于这样一个小项目,将项目分成两个存储库似乎太不切实际了,因为CLI部分实际上只是一个包装器。使用不同的参数多次运行setup()
会导致构建在各种错误(主要是缺少文件)上崩溃。我的解决方案是将每个setup()
作为不同的Process
运行。
from setuptools import setup, find_packages
from multiprocessing import Process
if __name__ == '__main__':
setups = [
{
'name': 'cli-tool',
'description': 'Some description...',
'packages': find_packages(),
'entry_points': {
'console_scripts': [
'cli-tool = fabfile:main'
]
},
'...': 'etc. needed for setup() ...'
},
{
'name': 'cli-tool-lib',
'packages': find_packages(exclude=('fabfile',)),
'...': 'etc.'
}
]
for s in setups:
name = s['name']
print("Building '{}'.".format(name))
p = Process(target=setup, kwargs=s)
p.start()
p.join()
print("Building of '{}' done.\n".format(name))
https://stackoverflow.com/questions/46118102
复制相似问题