blob: 6814a1c38200d177c35e13e067ebe0f65a38ff5c [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)"),
Andrew Kuchling5e2d4562013-11-15 13:01:52 -050040 ('owner=', 'u',
41 "Owner name used when creating a tar file"
42 " [default: current user]"),
43 ('group=', 'g',
44 "Group name used when creating a tar file"
45 " [default: current group]"),
Greg Ward0f77f952000-03-31 02:55:12 +000046 ]
47
Martin v. Löwis9668b932002-01-12 11:27:42 +000048 boolean_options = ['skip-build']
49
Greg Ward34593812000-06-24 01:23:37 +000050 help_options = [
51 ('help-formats', None,
52 "lists available distribution formats", show_formats),
Greg Wardfa9ff762000-10-14 04:06:40 +000053 ]
Greg Ward34593812000-06-24 01:23:37 +000054
Gregory P. Smith52e399c2000-05-13 01:49:56 +000055 # The following commands do not take a format option from bdist
Tarek Ziadéf6370502009-04-05 22:57:21 +000056 no_format_option = ('bdist_rpm',)
Gregory P. Smith52e399c2000-05-13 01:49:56 +000057
Greg Ward0f77f952000-03-31 02:55:12 +000058 # This won't do in reality: will need to distinguish RPM-ish Linux,
59 # Debian-ish Linux, Solaris, FreeBSD, ..., Windows, Mac OS.
Tarek Ziadéf6370502009-04-05 22:57:21 +000060 default_format = {'posix': 'gztar',
Jesus Cead17833d2012-10-11 01:20:12 +020061 'nt': 'zip'}
Greg Ward0f77f952000-03-31 02:55:12 +000062
Greg Ward6f628bb2000-08-02 01:44:44 +000063 # Establish the preferred order (for the --help-formats option).
64 format_commands = ['rpm', 'gztar', 'bztar', 'ztar', 'tar',
Tarek Ziadéf6370502009-04-05 22:57:21 +000065 'wininst', 'zip', 'msi']
Greg Ward6f628bb2000-08-02 01:44:44 +000066
67 # And the real information.
Tarek Ziadéf6370502009-04-05 22:57:21 +000068 format_command = {'rpm': ('bdist_rpm', "RPM distribution"),
69 'gztar': ('bdist_dumb', "gzip'ed tar file"),
70 'bztar': ('bdist_dumb', "bzip2'ed tar file"),
71 'ztar': ('bdist_dumb', "compressed tar file"),
72 'tar': ('bdist_dumb', "tar file"),
73 'wininst': ('bdist_wininst',
74 "Windows executable installer"),
75 'zip': ('bdist_dumb', "ZIP file"),
76 'msi': ('bdist_msi', "Microsoft Installer")
Marc-André Lemburg0538f1f2002-04-17 20:30:10 +000077 }
Greg Ward0f77f952000-03-31 02:55:12 +000078
79
Collin Winter5b7e9d72007-08-30 03:52:21 +000080 def initialize_options(self):
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000081 self.bdist_base = None
Greg Ward20283e52000-09-11 00:47:35 +000082 self.plat_name = None
Greg Warde18dd8d2000-06-06 02:51:38 +000083 self.formats = None
Greg Ward040dc0b2000-07-05 03:07:18 +000084 self.dist_dir = None
Martin v. Löwis9668b932002-01-12 11:27:42 +000085 self.skip_build = 0
Andrew Kuchling5e2d4562013-11-15 13:01:52 -050086 self.group = None
87 self.owner = None
Greg Ward0f77f952000-03-31 02:55:12 +000088
Collin Winter5b7e9d72007-08-30 03:52:21 +000089 def finalize_options(self):
Greg Ward20283e52000-09-11 00:47:35 +000090 # have to finalize 'plat_name' before 'bdist_base'
91 if self.plat_name is None:
Christian Heimes5e696852008-04-09 08:37:03 +000092 if self.skip_build:
93 self.plat_name = get_platform()
94 else:
95 self.plat_name = self.get_finalized_command('build').plat_name
Greg Ward20283e52000-09-11 00:47:35 +000096
Gregory P. Smithc59d4e02000-05-13 03:08:28 +000097 # 'bdist_base' -- parent of per-built-distribution-format
98 # temporary directories (eg. we'll probably have
99 # "build/bdist.<plat>/dumb", "build/bdist.<plat>/rpm", etc.)
100 if self.bdist_base is None:
Greg Ward4fb29e52000-05-27 17:27:23 +0000101 build_base = self.get_finalized_command('build').build_base
Greg Wardbeb6d722000-09-16 16:04:59 +0000102 self.bdist_base = os.path.join(build_base,
103 'bdist.' + self.plat_name)
Gregory P. Smithc59d4e02000-05-13 03:08:28 +0000104
Greg Warde18dd8d2000-06-06 02:51:38 +0000105 self.ensure_string_list('formats')
106 if self.formats is None:
Greg Ward0f77f952000-03-31 02:55:12 +0000107 try:
Greg Warde18dd8d2000-06-06 02:51:38 +0000108 self.formats = [self.default_format[os.name]]
Greg Ward0f77f952000-03-31 02:55:12 +0000109 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000110 raise DistutilsPlatformError(
111 "don't know how to create built distributions "
112 "on platform %s" % os.name)
Greg Ward040dc0b2000-07-05 03:07:18 +0000113
114 if self.dist_dir is None:
115 self.dist_dir = "dist"
Fred Drake21d45352001-12-06 21:01:19 +0000116
Collin Winter5b7e9d72007-08-30 03:52:21 +0000117 def run(self):
Greg Wardbeb6d722000-09-16 16:04:59 +0000118 # Figure out which sub-commands we need to run.
119 commands = []
Greg Warde18dd8d2000-06-06 02:51:38 +0000120 for format in self.formats:
Greg Warde18dd8d2000-06-06 02:51:38 +0000121 try:
Greg Wardbeb6d722000-09-16 16:04:59 +0000122 commands.append(self.format_command[format][0])
Greg Warde18dd8d2000-06-06 02:51:38 +0000123 except KeyError:
Collin Winter5b7e9d72007-08-30 03:52:21 +0000124 raise DistutilsOptionError("invalid format '%s'" % format)
Greg Warde18dd8d2000-06-06 02:51:38 +0000125
Greg Wardbeb6d722000-09-16 16:04:59 +0000126 # Reinitialize and run each command.
127 for i in range(len(self.formats)):
128 cmd_name = commands[i]
Greg Warde18dd8d2000-06-06 02:51:38 +0000129 sub_cmd = self.reinitialize_command(cmd_name)
130 if cmd_name not in self.no_format_option:
Greg Wardbeb6d722000-09-16 16:04:59 +0000131 sub_cmd.format = self.formats[i]
132
Andrew Kuchling5e2d4562013-11-15 13:01:52 -0500133 # passing the owner and group names for tar archiving
134 if cmd_name == 'bdist_dumb':
135 sub_cmd.owner = self.owner
136 sub_cmd.group = self.group
137
Greg Wardbeb6d722000-09-16 16:04:59 +0000138 # If we're going to need to run this command again, tell it to
139 # keep its temporary files around so subsequent runs go faster.
140 if cmd_name in commands[i+1:]:
141 sub_cmd.keep_temp = 1
Greg Wardcb1f4c42000-09-30 18:27:54 +0000142 self.run_command(cmd_name)