blob: 38b169afd10eaabc15b8ddc2152017c0984921f2 [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
Neal Norwitz9d72bb42007-04-17 08:48:32 +00006import os
Greg Ward0f77f952000-03-31 02:55:12 +00007from distutils.core import Command
Tarek Ziadé36797272010-07-22 12:50:05 +00008from distutils.errors import *
9from distutils.util import get_platform
Greg Ward0f77f952000-03-31 02:55:12 +000010
11
Collin Winter5b7e9d72007-08-30 03:52:21 +000012def show_formats():
Greg Ward34593812000-06-24 01:23:37 +000013 """Print list of available formats (arguments to "--format" option).
14 """
Fred Drake21d45352001-12-06 21:01:19 +000015 from distutils.fancy_getopt import FancyGetopt
Collin Winter5b7e9d72007-08-30 03:52:21 +000016 formats = []
Greg Ward34593812000-06-24 01:23:37 +000017 for format in bdist.format_commands:
18 formats.append(("formats=" + format, None,
19 bdist.format_command[format][1]))
20 pretty_printer = FancyGetopt(formats)
21 pretty_printer.print_help("List of available distribution formats:")
22
23
Collin Winter5b7e9d72007-08-30 03:52:21 +000024class bdist(Command):
Greg Ward0f77f952000-03-31 02:55:12 +000025
26 description = "create a built (binary) distribution"
27
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000028 user_options = [('bdist-base=', 'b',
29 "temporary directory for creating built distributions"),
Greg Ward20283e52000-09-11 00:47:35 +000030 ('plat-name=', 'p',
31 "platform name to embed in generated filenames "
32 "(default: %s)" % get_platform()),
Greg Warde18dd8d2000-06-06 02:51:38 +000033 ('formats=', None,
Greg Ward2ff78872000-06-24 00:23:20 +000034 "formats for distribution (comma-separated list)"),
Greg Ward040dc0b2000-07-05 03:07:18 +000035 ('dist-dir=', 'd',
36 "directory to put final built distributions in "
37 "[default: dist]"),
Martin v. Löwis9668b932002-01-12 11:27:42 +000038 ('skip-build', None,
39 "skip rebuilding everything (for testing/debugging)"),
Greg Ward0f77f952000-03-31 02:55:12 +000040 ]
41
Martin v. Löwis9668b932002-01-12 11:27:42 +000042 boolean_options = ['skip-build']
43
Greg Ward34593812000-06-24 01:23:37 +000044 help_options = [
45 ('help-formats', None,
46 "lists available distribution formats", show_formats),
Greg Wardfa9ff762000-10-14 04:06:40 +000047 ]
Greg Ward34593812000-06-24 01:23:37 +000048
Gregory P. Smith52e399c2000-05-13 01:49:56 +000049 # The following commands do not take a format option from bdist
Tarek Ziadéf6370502009-04-05 22:57:21 +000050 no_format_option = ('bdist_rpm',)
Gregory P. Smith52e399c2000-05-13 01:49:56 +000051
Greg Ward0f77f952000-03-31 02:55:12 +000052 # This won't do in reality: will need to distinguish RPM-ish Linux,
53 # Debian-ish Linux, Solaris, FreeBSD, ..., Windows, Mac OS.
Tarek Ziadéf6370502009-04-05 22:57:21 +000054 default_format = {'posix': 'gztar',
Jesus Cead17833d2012-10-11 01:20:12 +020055 'nt': 'zip'}
Greg Ward0f77f952000-03-31 02:55:12 +000056
Greg Ward6f628bb2000-08-02 01:44:44 +000057 # Establish the preferred order (for the --help-formats option).
58 format_commands = ['rpm', 'gztar', 'bztar', 'ztar', 'tar',
Tarek Ziadéf6370502009-04-05 22:57:21 +000059 'wininst', 'zip', 'msi']
Greg Ward6f628bb2000-08-02 01:44:44 +000060
61 # And the real information.
Tarek Ziadéf6370502009-04-05 22:57:21 +000062 format_command = {'rpm': ('bdist_rpm', "RPM distribution"),
63 'gztar': ('bdist_dumb', "gzip'ed tar file"),
64 'bztar': ('bdist_dumb', "bzip2'ed tar file"),
65 'ztar': ('bdist_dumb', "compressed tar file"),
66 'tar': ('bdist_dumb', "tar file"),
67 'wininst': ('bdist_wininst',
68 "Windows executable installer"),
69 'zip': ('bdist_dumb', "ZIP file"),
70 'msi': ('bdist_msi', "Microsoft Installer")
Marc-André Lemburg0538f1f2002-04-17 20:30:10 +000071 }
Greg Ward0f77f952000-03-31 02:55:12 +000072
73
Collin Winter5b7e9d72007-08-30 03:52:21 +000074 def initialize_options(self):
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000075 self.bdist_base = None
Greg Ward20283e52000-09-11 00:47:35 +000076 self.plat_name = None
Greg Warde18dd8d2000-06-06 02:51:38 +000077 self.formats = None
Greg Ward040dc0b2000-07-05 03:07:18 +000078 self.dist_dir = None
Martin v. Löwis9668b932002-01-12 11:27:42 +000079 self.skip_build = 0
Greg Ward0f77f952000-03-31 02:55:12 +000080
Collin Winter5b7e9d72007-08-30 03:52:21 +000081 def finalize_options(self):
Greg Ward20283e52000-09-11 00:47:35 +000082 # have to finalize 'plat_name' before 'bdist_base'
83 if self.plat_name is None:
Christian Heimes5e696852008-04-09 08:37:03 +000084 if self.skip_build:
85 self.plat_name = get_platform()
86 else:
87 self.plat_name = self.get_finalized_command('build').plat_name
Greg Ward20283e52000-09-11 00:47:35 +000088
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000089 # 'bdist_base' -- parent of per-built-distribution-format
90 # temporary directories (eg. we'll probably have
91 # "build/bdist.<plat>/dumb", "build/bdist.<plat>/rpm", etc.)
92 if self.bdist_base is None:
Greg Ward4fb29e52000-05-27 17:27:23 +000093 build_base = self.get_finalized_command('build').build_base
Greg Wardbeb6d722000-09-16 16:04:59 +000094 self.bdist_base = os.path.join(build_base,
95 'bdist.' + self.plat_name)
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000096
Greg Warde18dd8d2000-06-06 02:51:38 +000097 self.ensure_string_list('formats')
98 if self.formats is None:
Greg Ward0f77f952000-03-31 02:55:12 +000099 try:
Greg Warde18dd8d2000-06-06 02:51:38 +0000100 self.formats = [self.default_format[os.name]]
Greg Ward0f77f952000-03-31 02:55:12 +0000101 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000102 raise DistutilsPlatformError(
103 "don't know how to create built distributions "
104 "on platform %s" % os.name)
Greg Ward040dc0b2000-07-05 03:07:18 +0000105
106 if self.dist_dir is None:
107 self.dist_dir = "dist"
Fred Drake21d45352001-12-06 21:01:19 +0000108
Collin Winter5b7e9d72007-08-30 03:52:21 +0000109 def run(self):
Greg Wardbeb6d722000-09-16 16:04:59 +0000110 # Figure out which sub-commands we need to run.
111 commands = []
Greg Warde18dd8d2000-06-06 02:51:38 +0000112 for format in self.formats:
Greg Warde18dd8d2000-06-06 02:51:38 +0000113 try:
Greg Wardbeb6d722000-09-16 16:04:59 +0000114 commands.append(self.format_command[format][0])
Greg Warde18dd8d2000-06-06 02:51:38 +0000115 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000116 raise DistutilsOptionError("invalid format '%s'" % format)
Greg Warde18dd8d2000-06-06 02:51:38 +0000117
Greg Wardbeb6d722000-09-16 16:04:59 +0000118 # Reinitialize and run each command.
119 for i in range(len(self.formats)):
120 cmd_name = commands[i]
Greg Warde18dd8d2000-06-06 02:51:38 +0000121 sub_cmd = self.reinitialize_command(cmd_name)
122 if cmd_name not in self.no_format_option:
Greg Wardbeb6d722000-09-16 16:04:59 +0000123 sub_cmd.format = self.formats[i]
124
Greg Wardbeb6d722000-09-16 16:04:59 +0000125 # If we're going to need to run this command again, tell it to
126 # keep its temporary files around so subsequent runs go faster.
127 if cmd_name in commands[i+1:]:
128 sub_cmd.keep_temp = 1
Greg Wardcb1f4c42000-09-30 18:27:54 +0000129 self.run_command(cmd_name)