我在setup.py脚本中添加了自定义distutils命令:
from distutils.command.build_py import build_py
cmdclass = {}
cmdclass['build_qt'] = BuildQt
cmdclass['build_py'] = build_py
setup(..., cmdclass=cmdclass, ...)
有没有办法让它在运行时运行::
python setup.py build
这首先打电话
python setup.py build_qt
自动?
答案 0 :(得分:14)
您可以覆盖build
:
from distutils.command.build import build
class my_build(build):
def run(self):
self.run_command("build_qt")
build.run(self)
cmdclass['build'] = my_build
答案 1 :(得分:0)
为了添加您自己的命令,您可以继承默认的build
- 命令并扩展其子命令:
class _build(build):
sub_commands = [('build_qt', None)] + build.sub_commands
...
setup(..., cmdclass={'build': _build, ...})
文档(distutils.cmd.Command):
# 'sub_commands' formalizes the notion of a "family" of commands,
# eg. "install" as the parent with sub-commands "install_lib",
# "install_headers", etc. The parent of a family of commands
# defines 'sub_commands' as a class attribute; it's a list of
# (command_name : string, predicate : unbound_method | string | None)
# tuples, where 'predicate' is a method of the parent command that
# determines whether the corresponding command is applicable in the
# current situation. (Eg. we "install_headers" is only applicable if
# we have any C header files to install.) If 'predicate' is None,
# that command is always applicable.
#
# 'sub_commands' is usually defined at the *end* of a class, because
# predicates can be unbound methods, so they must already have been
# defined. The canonical example is the "install" command.
sub_commands = []