The 'bdist' command, for creating "built" (binary) distributions.
Initial revision is pretty limited; it only knows how to generate "dumb" binary distributions, i.e. a tarball on Unix and a zip file on Windows. Also, due to limitations in the installation code, it only knows how to distribute Python library code. But hey, it's a start.
This commit is contained in:
parent
1aab6e9645
commit
0f77f9569c
|
@ -0,0 +1,70 @@
|
||||||
|
"""distutils.command.bdist
|
||||||
|
|
||||||
|
Implements the Distutils 'bdist' command (create a built [binary]
|
||||||
|
distribution)."""
|
||||||
|
|
||||||
|
# created 2000/03/29, Greg Ward
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import os, string
|
||||||
|
from distutils.core import Command
|
||||||
|
|
||||||
|
|
||||||
|
class bdist (Command):
|
||||||
|
|
||||||
|
description = "create a built (binary) distribution"
|
||||||
|
|
||||||
|
user_options = [('formats=', 'f',
|
||||||
|
"formats for distribution (tar, ztar, gztar, zip, ... )"),
|
||||||
|
]
|
||||||
|
|
||||||
|
# This won't do in reality: will need to distinguish RPM-ish Linux,
|
||||||
|
# Debian-ish Linux, Solaris, FreeBSD, ..., Windows, Mac OS.
|
||||||
|
default_format = { 'posix': 'gztar',
|
||||||
|
'nt': 'zip', }
|
||||||
|
|
||||||
|
format_command = { 'gztar': 'bdist_dumb',
|
||||||
|
'zip': 'bdist_dumb', }
|
||||||
|
|
||||||
|
|
||||||
|
def initialize_options (self):
|
||||||
|
self.formats = None
|
||||||
|
|
||||||
|
# initialize_options()
|
||||||
|
|
||||||
|
|
||||||
|
def finalize_options (self):
|
||||||
|
if self.formats is None:
|
||||||
|
try:
|
||||||
|
self.formats = [self.default_format[os.name]]
|
||||||
|
except KeyError:
|
||||||
|
raise DistutilsPlatformError, \
|
||||||
|
"don't know how to create built distributions " + \
|
||||||
|
"on platform %s" % os.name
|
||||||
|
elif type (self.formats) is StringType:
|
||||||
|
self.formats = string.split (self.formats, ',')
|
||||||
|
|
||||||
|
|
||||||
|
# finalize_options()
|
||||||
|
|
||||||
|
|
||||||
|
def run (self):
|
||||||
|
|
||||||
|
for format in self.formats:
|
||||||
|
cmd_name = self.format_command[format]
|
||||||
|
sub_cmd = self.find_peer (cmd_name)
|
||||||
|
sub_cmd.set_option ('format', format)
|
||||||
|
|
||||||
|
# XXX blecchhh!! should formalize this: at least a
|
||||||
|
# 'forget_run()' (?) method, possibly complicate the
|
||||||
|
# 'have_run' dictionary to include some command state as well
|
||||||
|
# as the command name -- eg. in this case we might want
|
||||||
|
# ('bdist_dumb','zip') to be marked "have run", but not
|
||||||
|
# ('bdist_dumb','gztar').
|
||||||
|
self.distribution.have_run[cmd_name] = 0
|
||||||
|
self.run_peer (cmd_name)
|
||||||
|
|
||||||
|
# run()
|
||||||
|
|
||||||
|
# class bdist
|
Loading…
Reference in New Issue