blob: 2c81f3a9c06138e6d5166469b2a4f7a66b06234a [file] [log] [blame]
Greg Ward0f77f952000-03-31 02:55:12 +00001"""distutils.command.bdist
2
3Implements the Distutils 'bdist' command (create a built [binary]
4distribution)."""
5
Greg Ward0f77f952000-03-31 02:55:12 +00006__revision__ = "$Id$"
7
Neal Norwitz9d72bb42007-04-17 08:48:32 +00008import os
Greg Ward0f77f952000-03-31 02:55:12 +00009from distutils.core import Command
Greg Ward02296ce2000-03-31 05:08:50 +000010from distutils.errors import *
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000011from distutils.util import get_platform
Greg Ward0f77f952000-03-31 02:55:12 +000012
13
Collin Winter5b7e9d72007-08-30 03:52:21 +000014def show_formats():
Greg Ward34593812000-06-24 01:23:37 +000015 """Print list of available formats (arguments to "--format" option).
16 """
Fred Drake21d45352001-12-06 21:01:19 +000017 from distutils.fancy_getopt import FancyGetopt
Collin Winter5b7e9d72007-08-30 03:52:21 +000018 formats = []
Greg Ward34593812000-06-24 01:23:37 +000019 for format in bdist.format_commands:
20 formats.append(("formats=" + format, None,
21 bdist.format_command[format][1]))
22 pretty_printer = FancyGetopt(formats)
23 pretty_printer.print_help("List of available distribution formats:")
24
25
Collin Winter5b7e9d72007-08-30 03:52:21 +000026class bdist(Command):
Greg Ward0f77f952000-03-31 02:55:12 +000027
28 description = "create a built (binary) distribution"
29
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000030 user_options = [('bdist-base=', 'b',
31 "temporary directory for creating built distributions"),
Greg Ward20283e52000-09-11 00:47:35 +000032 ('plat-name=', 'p',
33 "platform name to embed in generated filenames "
34 "(default: %s)" % get_platform()),
Greg Warde18dd8d2000-06-06 02:51:38 +000035 ('formats=', None,
Greg Ward2ff78872000-06-24 00:23:20 +000036 "formats for distribution (comma-separated list)"),
Greg Ward040dc0b2000-07-05 03:07:18 +000037 ('dist-dir=', 'd',
38 "directory to put final built distributions in "
39 "[default: dist]"),
Martin v. Löwis9668b932002-01-12 11:27:42 +000040 ('skip-build', None,
41 "skip rebuilding everything (for testing/debugging)"),
Tarek Ziadé05b30342009-10-02 23:56:02 +000042 ('owner=', 'u',
43 "Owner name used when creating a tar file"
44 " [default: current user]"),
45 ('group=', 'g',
46 "Group name used when creating a tar file"
47 " [default: current group]"),
Greg Ward0f77f952000-03-31 02:55:12 +000048 ]
49
Martin v. Löwis9668b932002-01-12 11:27:42 +000050 boolean_options = ['skip-build']
51
Greg Ward34593812000-06-24 01:23:37 +000052 help_options = [
53 ('help-formats', None,
54 "lists available distribution formats", show_formats),
Greg Wardfa9ff762000-10-14 04:06:40 +000055 ]
Greg Ward34593812000-06-24 01:23:37 +000056
Gregory P. Smith52e399c2000-05-13 01:49:56 +000057 # The following commands do not take a format option from bdist
Tarek Ziadéf6370502009-04-05 22:57:21 +000058 no_format_option = ('bdist_rpm',)
Gregory P. Smith52e399c2000-05-13 01:49:56 +000059
Greg Ward0f77f952000-03-31 02:55:12 +000060 # This won't do in reality: will need to distinguish RPM-ish Linux,
61 # Debian-ish Linux, Solaris, FreeBSD, ..., Windows, Mac OS.
Tarek Ziadéf6370502009-04-05 22:57:21 +000062 default_format = {'posix': 'gztar',
63 'nt': 'zip',
64 'os2': 'zip'}
Greg Ward0f77f952000-03-31 02:55:12 +000065
Greg Ward6f628bb2000-08-02 01:44:44 +000066 # Establish the preferred order (for the --help-formats option).
67 format_commands = ['rpm', 'gztar', 'bztar', 'ztar', 'tar',
Tarek Ziadéf6370502009-04-05 22:57:21 +000068 'wininst', 'zip', 'msi']
Greg Ward6f628bb2000-08-02 01:44:44 +000069
70 # And the real information.
Tarek Ziadéf6370502009-04-05 22:57:21 +000071 format_command = {'rpm': ('bdist_rpm', "RPM distribution"),
72 'gztar': ('bdist_dumb', "gzip'ed tar file"),
73 'bztar': ('bdist_dumb', "bzip2'ed tar file"),
74 'ztar': ('bdist_dumb', "compressed tar file"),
75 'tar': ('bdist_dumb', "tar file"),
76 'wininst': ('bdist_wininst',
77 "Windows executable installer"),
78 'zip': ('bdist_dumb', "ZIP file"),
79 'msi': ('bdist_msi', "Microsoft Installer")
Marc-André Lemburg0538f1f2002-04-17 20:30:10 +000080 }
Greg Ward0f77f952000-03-31 02:55:12 +000081
82
Collin Winter5b7e9d72007-08-30 03:52:21 +000083 def initialize_options(self):
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000084 self.bdist_base = None
Greg Ward20283e52000-09-11 00:47:35 +000085 self.plat_name = None
Greg Warde18dd8d2000-06-06 02:51:38 +000086 self.formats = None
Greg Ward040dc0b2000-07-05 03:07:18 +000087 self.dist_dir = None
Martin v. Löwis9668b932002-01-12 11:27:42 +000088 self.skip_build = 0
Tarek Ziadé05b30342009-10-02 23:56:02 +000089 self.group = None
90 self.owner = None
Greg Ward0f77f952000-03-31 02:55:12 +000091
Collin Winter5b7e9d72007-08-30 03:52:21 +000092 def finalize_options(self):
Greg Ward20283e52000-09-11 00:47:35 +000093 # have to finalize 'plat_name' before 'bdist_base'
94 if self.plat_name is None:
Christian Heimes5e696852008-04-09 08:37:03 +000095 if self.skip_build:
96 self.plat_name = get_platform()
97 else:
98 self.plat_name = self.get_finalized_command('build').plat_name
Greg Ward20283e52000-09-11 00:47:35 +000099
Gregory P. Smithc59d4e02000-05-13 03:08:28 +0000100 # 'bdist_base' -- parent of per-built-distribution-format
101 # temporary directories (eg. we'll probably have
102 # "build/bdist.<plat>/dumb", "build/bdist.<plat>/rpm", etc.)
103 if self.bdist_base is None:
Greg Ward4fb29e52000-05-27 17:27:23 +0000104 build_base = self.get_finalized_command('build').build_base
Greg Wardbeb6d722000-09-16 16:04:59 +0000105 self.bdist_base = os.path.join(build_base,
106 'bdist.' + self.plat_name)
Gregory P. Smithc59d4e02000-05-13 03:08:28 +0000107
Greg Warde18dd8d2000-06-06 02:51:38 +0000108 self.ensure_string_list('formats')
109 if self.formats is None:
Greg Ward0f77f952000-03-31 02:55:12 +0000110 try:
Greg Warde18dd8d2000-06-06 02:51:38 +0000111 self.formats = [self.default_format[os.name]]
Greg Ward0f77f952000-03-31 02:55:12 +0000112 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000113 raise DistutilsPlatformError(
114 "don't know how to create built distributions "
115 "on platform %s" % os.name)
Greg Ward040dc0b2000-07-05 03:07:18 +0000116
117 if self.dist_dir is None:
118 self.dist_dir = "dist"
Fred Drake21d45352001-12-06 21:01:19 +0000119
Collin Winter5b7e9d72007-08-30 03:52:21 +0000120 def run(self):
Greg Wardbeb6d722000-09-16 16:04:59 +0000121 # Figure out which sub-commands we need to run.
122 commands = []
Greg Warde18dd8d2000-06-06 02:51:38 +0000123 for format in self.formats:
Greg Warde18dd8d2000-06-06 02:51:38 +0000124 try:
Greg Wardbeb6d722000-09-16 16:04:59 +0000125 commands.append(self.format_command[format][0])
Greg Warde18dd8d2000-06-06 02:51:38 +0000126 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000127 raise DistutilsOptionError("invalid format '%s'" % format)
Greg Warde18dd8d2000-06-06 02:51:38 +0000128
Greg Wardbeb6d722000-09-16 16:04:59 +0000129 # Reinitialize and run each command.
130 for i in range(len(self.formats)):
131 cmd_name = commands[i]
Greg Warde18dd8d2000-06-06 02:51:38 +0000132 sub_cmd = self.reinitialize_command(cmd_name)
133 if cmd_name not in self.no_format_option:
Greg Wardbeb6d722000-09-16 16:04:59 +0000134 sub_cmd.format = self.formats[i]
135
Tarek Ziadé05b30342009-10-02 23:56:02 +0000136 # passing the owner and group names for tar archiving
137 if cmd_name == 'bdist_dumb':
138 sub_cmd.owner = self.owner
139 sub_cmd.group = self.group
140
Greg Wardbeb6d722000-09-16 16:04:59 +0000141 # If we're going to need to run this command again, tell it to
142 # keep its temporary files around so subsequent runs go faster.
143 if cmd_name in commands[i+1:]:
144 sub_cmd.keep_temp = 1
Greg Wardcb1f4c42000-09-30 18:27:54 +0000145 self.run_command(cmd_name)