Крюк для добавления команд для создания distutils?

Я добавил пользовательскую команду distutils в setup.py script:

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

автоматически?

Ответ 1

Вы можете переопределить 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

Ответ 2

Чтобы добавить свою собственную команду, вы можете подклассифицировать команду 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 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 = []