1999-03-22 22:52:19 +08:00
|
|
|
"""distutils.core
|
|
|
|
|
|
|
|
The only module that needs to be imported to use the Distutils; provides
|
2000-04-04 09:40:52 +08:00
|
|
|
the 'setup' function (which is to be called from the setup script). Also
|
|
|
|
indirectly provides the Distribution and Command classes, although they are
|
|
|
|
really defined in distutils.dist and distutils.cmd."""
|
1999-03-22 22:52:19 +08:00
|
|
|
|
|
|
|
# created 1999/03/01, Greg Ward
|
|
|
|
|
2000-03-02 09:49:45 +08:00
|
|
|
__revision__ = "$Id$"
|
1999-03-22 22:52:19 +08:00
|
|
|
|
2000-04-04 09:40:52 +08:00
|
|
|
import sys
|
1999-08-30 02:20:32 +08:00
|
|
|
from types import *
|
1999-03-22 22:52:19 +08:00
|
|
|
from distutils.errors import *
|
2000-04-04 09:40:52 +08:00
|
|
|
from distutils.dist import Distribution
|
|
|
|
from distutils.cmd import Command
|
1999-03-22 22:52:19 +08:00
|
|
|
|
2000-02-18 08:26:23 +08:00
|
|
|
# This is a barebones help message generated displayed when the user
|
|
|
|
# runs the setup script with no arguments at all. More useful help
|
|
|
|
# is generated with various --help options: global help, list commands,
|
|
|
|
# and per-command help.
|
1999-12-13 00:51:44 +08:00
|
|
|
usage = """\
|
|
|
|
usage: %s [global_opts] cmd1 [cmd1_opts] [cmd2 [cmd2_opts] ...]
|
|
|
|
or: %s --help
|
2000-01-31 02:30:32 +08:00
|
|
|
or: %s --help-commands
|
1999-12-13 00:51:44 +08:00
|
|
|
or: %s cmd --help
|
2000-01-31 02:30:32 +08:00
|
|
|
""" % ((sys.argv[0],) * 4)
|
1999-03-22 22:52:19 +08:00
|
|
|
|
|
|
|
|
|
|
|
def setup (**attrs):
|
|
|
|
"""The gateway to the Distutils: do everything your setup script
|
|
|
|
needs to do, in a highly flexible and user-driven way. Briefly:
|
|
|
|
create a Distribution instance; parse the command-line, creating
|
|
|
|
and customizing instances of the command class for each command
|
|
|
|
found on the command-line; run each of those commands.
|
|
|
|
|
|
|
|
The Distribution instance might be an instance of a class
|
|
|
|
supplied via the 'distclass' keyword argument to 'setup'; if no
|
|
|
|
such class is supplied, then the 'Distribution' class (also in
|
|
|
|
this module) is instantiated. All other arguments to 'setup'
|
|
|
|
(except for 'cmdclass') are used to set attributes of the
|
|
|
|
Distribution instance.
|
|
|
|
|
|
|
|
The 'cmdclass' argument, if supplied, is a dictionary mapping
|
2000-02-18 08:26:23 +08:00
|
|
|
command names to command classes. Each command encountered on
|
|
|
|
the command line will be turned into a command class, which is in
|
|
|
|
turn instantiated; any class found in 'cmdclass' is used in place
|
|
|
|
of the default, which is (for command 'foo_bar') class 'foo_bar'
|
|
|
|
in module 'distutils.command.foo_bar'. The command class must
|
|
|
|
provide a 'user_options' attribute which is a list of option
|
|
|
|
specifiers for 'distutils.fancy_getopt'. Any command-line
|
|
|
|
options between the current and the next command are used to set
|
|
|
|
attributes of the current command object.
|
|
|
|
|
|
|
|
When the entire command-line has been successfully parsed, calls
|
|
|
|
the 'run()' method on each command object in turn. This method
|
|
|
|
will be driven entirely by the Distribution object (which each
|
|
|
|
command object has a reference to, thanks to its constructor),
|
|
|
|
and the command-specific options that became attributes of each
|
|
|
|
command object."""
|
1999-03-22 22:52:19 +08:00
|
|
|
|
|
|
|
# Determine the distribution class -- either caller-supplied or
|
|
|
|
# our Distribution (see below).
|
|
|
|
klass = attrs.get ('distclass')
|
|
|
|
if klass:
|
|
|
|
del attrs['distclass']
|
|
|
|
else:
|
|
|
|
klass = Distribution
|
|
|
|
|
|
|
|
# Create the Distribution instance, using the remaining arguments
|
|
|
|
# (ie. everything except distclass) to initialize it
|
|
|
|
dist = klass (attrs)
|
|
|
|
|
1999-09-08 10:41:09 +08:00
|
|
|
# If we had a config file, this is where we would parse it: override
|
|
|
|
# the client-supplied command options, but be overridden by the
|
|
|
|
# command line.
|
|
|
|
|
|
|
|
# Parse the command line; any command-line errors are the end-users
|
|
|
|
# fault, so turn them into SystemExit to suppress tracebacks.
|
1999-03-22 22:52:19 +08:00
|
|
|
try:
|
1999-12-13 00:51:44 +08:00
|
|
|
ok = dist.parse_command_line (sys.argv[1:])
|
1999-03-22 22:52:19 +08:00
|
|
|
except DistutilsArgError, msg:
|
1999-12-13 00:51:44 +08:00
|
|
|
sys.stderr.write (usage + "\n")
|
1999-12-16 09:19:05 +08:00
|
|
|
raise SystemExit, "error: %s" % msg
|
1999-03-22 22:52:19 +08:00
|
|
|
|
|
|
|
# And finally, run all the commands found on the command line.
|
1999-12-13 00:51:44 +08:00
|
|
|
if ok:
|
|
|
|
try:
|
|
|
|
dist.run_commands ()
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
raise SystemExit, "interrupted"
|
2000-03-27 05:48:43 +08:00
|
|
|
except (OSError, IOError), exc:
|
2000-02-26 08:49:40 +08:00
|
|
|
# arg, try to work with Python pre-1.5.2
|
|
|
|
if hasattr (exc, 'filename') and hasattr (exc, 'strerror'):
|
|
|
|
raise SystemExit, \
|
|
|
|
"error: %s: %s" % (exc.filename, exc.strerror)
|
|
|
|
else:
|
|
|
|
raise SystemExit, str (exc)
|
2000-04-09 11:49:20 +08:00
|
|
|
except (DistutilsExecError, DistutilsFileError), msg:
|
2000-03-27 05:48:43 +08:00
|
|
|
raise SystemExit, "error: " + str (msg)
|
1999-03-22 22:52:19 +08:00
|
|
|
|
|
|
|
# setup ()
|