Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 1 | """distutils.command.bdist |
| 2 | |
| 3 | Implements the Distutils 'bdist' command (create a built [binary] |
| 4 | distribution).""" |
| 5 | |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 6 | __revision__ = "$Id$" |
| 7 | |
Neal Norwitz | 9d72bb4 | 2007-04-17 08:48:32 +0000 | [diff] [blame] | 8 | import os |
Tarek Ziadé | 88e2c5d | 2009-12-21 01:49:00 +0000 | [diff] [blame] | 9 | |
Tarek Ziadé | 8b441d0 | 2010-01-29 11:46:31 +0000 | [diff] [blame] | 10 | from distutils.util import get_platform |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 11 | from distutils.core import Command |
Tarek Ziadé | 88e2c5d | 2009-12-21 01:49:00 +0000 | [diff] [blame] | 12 | from distutils.errors import DistutilsPlatformError, DistutilsOptionError |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 13 | |
| 14 | |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 15 | def show_formats(): |
Greg Ward | 3459381 | 2000-06-24 01:23:37 +0000 | [diff] [blame] | 16 | """Print list of available formats (arguments to "--format" option). |
| 17 | """ |
Fred Drake | 21d4535 | 2001-12-06 21:01:19 +0000 | [diff] [blame] | 18 | from distutils.fancy_getopt import FancyGetopt |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 19 | formats = [] |
Greg Ward | 3459381 | 2000-06-24 01:23:37 +0000 | [diff] [blame] | 20 | for format in bdist.format_commands: |
| 21 | formats.append(("formats=" + format, None, |
| 22 | bdist.format_command[format][1])) |
| 23 | pretty_printer = FancyGetopt(formats) |
| 24 | pretty_printer.print_help("List of available distribution formats:") |
| 25 | |
| 26 | |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 27 | class bdist(Command): |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 28 | |
| 29 | description = "create a built (binary) distribution" |
| 30 | |
Gregory P. Smith | c59d4e0 | 2000-05-13 03:08:28 +0000 | [diff] [blame] | 31 | user_options = [('bdist-base=', 'b', |
| 32 | "temporary directory for creating built distributions"), |
Greg Ward | 20283e5 | 2000-09-11 00:47:35 +0000 | [diff] [blame] | 33 | ('plat-name=', 'p', |
| 34 | "platform name to embed in generated filenames " |
| 35 | "(default: %s)" % get_platform()), |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 36 | ('formats=', None, |
Greg Ward | 2ff7887 | 2000-06-24 00:23:20 +0000 | [diff] [blame] | 37 | "formats for distribution (comma-separated list)"), |
Greg Ward | 040dc0b | 2000-07-05 03:07:18 +0000 | [diff] [blame] | 38 | ('dist-dir=', 'd', |
| 39 | "directory to put final built distributions in " |
| 40 | "[default: dist]"), |
Martin v. Löwis | 9668b93 | 2002-01-12 11:27:42 +0000 | [diff] [blame] | 41 | ('skip-build', None, |
| 42 | "skip rebuilding everything (for testing/debugging)"), |
Tarek Ziadé | 05b3034 | 2009-10-02 23:56:02 +0000 | [diff] [blame] | 43 | ('owner=', 'u', |
| 44 | "Owner name used when creating a tar file" |
| 45 | " [default: current user]"), |
| 46 | ('group=', 'g', |
| 47 | "Group name used when creating a tar file" |
| 48 | " [default: current group]"), |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 49 | ] |
| 50 | |
Martin v. Löwis | 9668b93 | 2002-01-12 11:27:42 +0000 | [diff] [blame] | 51 | boolean_options = ['skip-build'] |
| 52 | |
Greg Ward | 3459381 | 2000-06-24 01:23:37 +0000 | [diff] [blame] | 53 | help_options = [ |
| 54 | ('help-formats', None, |
| 55 | "lists available distribution formats", show_formats), |
Greg Ward | fa9ff76 | 2000-10-14 04:06:40 +0000 | [diff] [blame] | 56 | ] |
Greg Ward | 3459381 | 2000-06-24 01:23:37 +0000 | [diff] [blame] | 57 | |
Gregory P. Smith | 52e399c | 2000-05-13 01:49:56 +0000 | [diff] [blame] | 58 | # The following commands do not take a format option from bdist |
Tarek Ziadé | f637050 | 2009-04-05 22:57:21 +0000 | [diff] [blame] | 59 | no_format_option = ('bdist_rpm',) |
Gregory P. Smith | 52e399c | 2000-05-13 01:49:56 +0000 | [diff] [blame] | 60 | |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 61 | # This won't do in reality: will need to distinguish RPM-ish Linux, |
| 62 | # Debian-ish Linux, Solaris, FreeBSD, ..., Windows, Mac OS. |
Tarek Ziadé | f637050 | 2009-04-05 22:57:21 +0000 | [diff] [blame] | 63 | default_format = {'posix': 'gztar', |
| 64 | 'nt': 'zip', |
| 65 | 'os2': 'zip'} |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 66 | |
Greg Ward | 6f628bb | 2000-08-02 01:44:44 +0000 | [diff] [blame] | 67 | # Establish the preferred order (for the --help-formats option). |
| 68 | format_commands = ['rpm', 'gztar', 'bztar', 'ztar', 'tar', |
Tarek Ziadé | f637050 | 2009-04-05 22:57:21 +0000 | [diff] [blame] | 69 | 'wininst', 'zip', 'msi'] |
Greg Ward | 6f628bb | 2000-08-02 01:44:44 +0000 | [diff] [blame] | 70 | |
| 71 | # And the real information. |
Tarek Ziadé | f637050 | 2009-04-05 22:57:21 +0000 | [diff] [blame] | 72 | format_command = {'rpm': ('bdist_rpm', "RPM distribution"), |
| 73 | 'gztar': ('bdist_dumb', "gzip'ed tar file"), |
| 74 | 'bztar': ('bdist_dumb', "bzip2'ed tar file"), |
| 75 | 'ztar': ('bdist_dumb', "compressed tar file"), |
| 76 | 'tar': ('bdist_dumb', "tar file"), |
| 77 | 'wininst': ('bdist_wininst', |
| 78 | "Windows executable installer"), |
| 79 | 'zip': ('bdist_dumb', "ZIP file"), |
| 80 | 'msi': ('bdist_msi', "Microsoft Installer") |
Marc-André Lemburg | 0538f1f | 2002-04-17 20:30:10 +0000 | [diff] [blame] | 81 | } |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 82 | |
| 83 | |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 84 | def initialize_options(self): |
Gregory P. Smith | c59d4e0 | 2000-05-13 03:08:28 +0000 | [diff] [blame] | 85 | self.bdist_base = None |
Greg Ward | 20283e5 | 2000-09-11 00:47:35 +0000 | [diff] [blame] | 86 | self.plat_name = None |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 87 | self.formats = None |
Greg Ward | 040dc0b | 2000-07-05 03:07:18 +0000 | [diff] [blame] | 88 | self.dist_dir = None |
Martin v. Löwis | 9668b93 | 2002-01-12 11:27:42 +0000 | [diff] [blame] | 89 | self.skip_build = 0 |
Tarek Ziadé | 05b3034 | 2009-10-02 23:56:02 +0000 | [diff] [blame] | 90 | self.group = None |
| 91 | self.owner = None |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 92 | |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 93 | def finalize_options(self): |
Greg Ward | 20283e5 | 2000-09-11 00:47:35 +0000 | [diff] [blame] | 94 | # have to finalize 'plat_name' before 'bdist_base' |
| 95 | if self.plat_name is None: |
Christian Heimes | 5e69685 | 2008-04-09 08:37:03 +0000 | [diff] [blame] | 96 | if self.skip_build: |
| 97 | self.plat_name = get_platform() |
| 98 | else: |
| 99 | self.plat_name = self.get_finalized_command('build').plat_name |
Greg Ward | 20283e5 | 2000-09-11 00:47:35 +0000 | [diff] [blame] | 100 | |
Gregory P. Smith | c59d4e0 | 2000-05-13 03:08:28 +0000 | [diff] [blame] | 101 | # 'bdist_base' -- parent of per-built-distribution-format |
| 102 | # temporary directories (eg. we'll probably have |
| 103 | # "build/bdist.<plat>/dumb", "build/bdist.<plat>/rpm", etc.) |
| 104 | if self.bdist_base is None: |
Greg Ward | 4fb29e5 | 2000-05-27 17:27:23 +0000 | [diff] [blame] | 105 | build_base = self.get_finalized_command('build').build_base |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 106 | self.bdist_base = os.path.join(build_base, |
| 107 | 'bdist.' + self.plat_name) |
Gregory P. Smith | c59d4e0 | 2000-05-13 03:08:28 +0000 | [diff] [blame] | 108 | |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 109 | self.ensure_string_list('formats') |
| 110 | if self.formats is None: |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 111 | try: |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 112 | self.formats = [self.default_format[os.name]] |
Greg Ward | 0f77f95 | 2000-03-31 02:55:12 +0000 | [diff] [blame] | 113 | except KeyError: |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 114 | raise DistutilsPlatformError( |
| 115 | "don't know how to create built distributions " |
| 116 | "on platform %s" % os.name) |
Greg Ward | 040dc0b | 2000-07-05 03:07:18 +0000 | [diff] [blame] | 117 | |
| 118 | if self.dist_dir is None: |
| 119 | self.dist_dir = "dist" |
Fred Drake | 21d4535 | 2001-12-06 21:01:19 +0000 | [diff] [blame] | 120 | |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 121 | def run(self): |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 122 | # Figure out which sub-commands we need to run. |
| 123 | commands = [] |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 124 | for format in self.formats: |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 125 | try: |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 126 | commands.append(self.format_command[format][0]) |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 127 | except KeyError: |
Collin Winter | 5b7e9d7 | 2007-08-30 03:52:21 +0000 | [diff] [blame] | 128 | raise DistutilsOptionError("invalid format '%s'" % format) |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 129 | |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 130 | # Reinitialize and run each command. |
| 131 | for i in range(len(self.formats)): |
| 132 | cmd_name = commands[i] |
Greg Ward | e18dd8d | 2000-06-06 02:51:38 +0000 | [diff] [blame] | 133 | sub_cmd = self.reinitialize_command(cmd_name) |
| 134 | if cmd_name not in self.no_format_option: |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 135 | sub_cmd.format = self.formats[i] |
| 136 | |
Tarek Ziadé | 05b3034 | 2009-10-02 23:56:02 +0000 | [diff] [blame] | 137 | # passing the owner and group names for tar archiving |
| 138 | if cmd_name == 'bdist_dumb': |
| 139 | sub_cmd.owner = self.owner |
| 140 | sub_cmd.group = self.group |
| 141 | |
Greg Ward | beb6d72 | 2000-09-16 16:04:59 +0000 | [diff] [blame] | 142 | # If we're going to need to run this command again, tell it to |
| 143 | # keep its temporary files around so subsequent runs go faster. |
| 144 | if cmd_name in commands[i+1:]: |
| 145 | sub_cmd.keep_temp = 1 |
Greg Ward | cb1f4c4 | 2000-09-30 18:27:54 +0000 | [diff] [blame] | 146 | self.run_command(cmd_name) |