blob: 78231541ec286d04ff3ae3652c6bc4031fc3b6d3 [file] [log] [blame]
Greg Ward13ae1c81999-03-22 14:55:25 +00001"""distutils.command.build
2
3Implements the Distutils 'build' command."""
4
Andrew M. Kuchlingd448f662002-11-19 13:12:28 +00005# This module should be kept compatible with Python 1.5.2.
6
Greg Ward3ce77fd2000-03-02 01:49:45 +00007__revision__ = "$Id$"
Greg Ward13ae1c81999-03-22 14:55:25 +00008
Greg Ward42a3bf52000-03-01 01:26:45 +00009import sys, os
Greg Ward13ae1c81999-03-22 14:55:25 +000010from distutils.core import Command
Greg Ward42a3bf52000-03-01 01:26:45 +000011from distutils.util import get_platform
Greg Ward34593812000-06-24 01:23:37 +000012
13
14def show_compilers ():
15 from distutils.ccompiler import show_compilers
16 show_compilers()
17
Greg Ward13ae1c81999-03-22 14:55:25 +000018
Greg Ward1993f9a2000-02-18 00:13:53 +000019class build (Command):
Greg Ward13ae1c81999-03-22 14:55:25 +000020
Greg Ward37bc8152000-01-30 18:34:15 +000021 description = "build everything needed to install"
22
Greg Wardbbeceea2000-02-18 00:25:39 +000023 user_options = [
24 ('build-base=', 'b',
25 "base directory for build library"),
Greg Ward42a3bf52000-03-01 01:26:45 +000026 ('build-purelib=', None,
27 "build directory for platform-neutral distributions"),
28 ('build-platlib=', None,
29 "build directory for platform-specific distributions"),
30 ('build-lib=', None,
31 "build directory for all distribution (defaults to either " +
32 "build-purelib or build-platlib"),
Greg Ward8d5881a2000-05-25 01:19:18 +000033 ('build-scripts=', None,
34 "build directory for scripts"),
Greg Ward42a3bf52000-03-01 01:26:45 +000035 ('build-temp=', 't',
36 "temporary build directory"),
Gregory P. Smith9668b782000-05-12 00:33:14 +000037 ('compiler=', 'c',
38 "specify the compiler type"),
Greg Wardbbeceea2000-02-18 00:25:39 +000039 ('debug', 'g',
40 "compile extensions and libraries with debugging information"),
Greg Wardc41d6b32000-04-10 00:19:42 +000041 ('force', 'f',
Gregory P. Smith9668b782000-05-12 00:33:14 +000042 "forcibly build everything (ignore file timestamps)"),
Greg Wardbbeceea2000-02-18 00:25:39 +000043 ]
Greg Ward2ff78872000-06-24 00:23:20 +000044
Greg Ward99b032e2000-09-25 01:41:15 +000045 boolean_options = ['debug', 'force']
46
Greg Ward9d17a7a2000-06-07 03:00:06 +000047 help_options = [
48 ('help-compiler', None,
Greg Ward2ff78872000-06-24 00:23:20 +000049 "list available compilers", show_compilers),
Greg Wardfa9ff762000-10-14 04:06:40 +000050 ]
Greg Ward13ae1c81999-03-22 14:55:25 +000051
Greg Warde01149c2000-02-18 00:35:22 +000052 def initialize_options (self):
Greg Warde6ac2fc1999-09-29 12:38:18 +000053 self.build_base = 'build'
54 # these are decided only after 'build_base' has its final value
Greg Ward13ae1c81999-03-22 14:55:25 +000055 # (unless overridden by the user or client)
Greg Ward42a3bf52000-03-01 01:26:45 +000056 self.build_purelib = None
Greg Warde6ac2fc1999-09-29 12:38:18 +000057 self.build_platlib = None
Greg Ward42a3bf52000-03-01 01:26:45 +000058 self.build_lib = None
59 self.build_temp = None
Greg Ward8d5881a2000-05-25 01:19:18 +000060 self.build_scripts = None
Gregory P. Smith9668b782000-05-12 00:33:14 +000061 self.compiler = None
Greg Ward32462002000-02-09 02:19:49 +000062 self.debug = None
Greg Wardc41d6b32000-04-10 00:19:42 +000063 self.force = 0
Greg Ward13ae1c81999-03-22 14:55:25 +000064
Greg Warde01149c2000-02-18 00:35:22 +000065 def finalize_options (self):
Greg Ward42a3bf52000-03-01 01:26:45 +000066
Greg Ward53db8152000-09-16 02:06:45 +000067 plat_specifier = ".%s-%s" % (get_platform(), sys.version[0:3])
Greg Ward42900942000-09-16 01:54:46 +000068
Greg Ward42a3bf52000-03-01 01:26:45 +000069 # 'build_purelib' and 'build_platlib' just default to 'lib' and
70 # 'lib.<plat>' under the base build directory. We only use one of
71 # them for a given distribution, though --
72 if self.build_purelib is None:
Greg Wardcb1f4c42000-09-30 18:27:54 +000073 self.build_purelib = os.path.join(self.build_base, 'lib')
Greg Warde6ac2fc1999-09-29 12:38:18 +000074 if self.build_platlib is None:
Greg Wardcb1f4c42000-09-30 18:27:54 +000075 self.build_platlib = os.path.join(self.build_base,
76 'lib' + plat_specifier)
Greg Ward42a3bf52000-03-01 01:26:45 +000077
78 # 'build_lib' is the actual directory that we will use for this
79 # particular module distribution -- if user didn't supply it, pick
80 # one of 'build_purelib' or 'build_platlib'.
81 if self.build_lib is None:
82 if self.distribution.ext_modules:
83 self.build_lib = self.build_platlib
84 else:
85 self.build_lib = self.build_purelib
86
87 # 'build_temp' -- temporary directory for compiler turds,
88 # "build/temp.<plat>"
89 if self.build_temp is None:
Greg Wardcb1f4c42000-09-30 18:27:54 +000090 self.build_temp = os.path.join(self.build_base,
91 'temp' + plat_specifier)
Greg Ward8d5881a2000-05-25 01:19:18 +000092 if self.build_scripts is None:
Michael W. Hudson49bdaed2001-12-10 15:28:30 +000093 self.build_scripts = os.path.join(self.build_base,
94 'scripts-' + sys.version[0:3])
Greg Ward53db8152000-09-16 02:06:45 +000095
Greg Ward42a3bf52000-03-01 01:26:45 +000096 # finalize_options ()
Greg Ward13ae1c81999-03-22 14:55:25 +000097
98
99 def run (self):
100
Greg Ward64d855a2000-09-30 17:08:12 +0000101 # Run all relevant sub-commands. This will be some subset of:
102 # - build_py - pure Python modules
103 # - build_clib - standalone C libraries
104 # - build_ext - Python extensions
105 # - build_scripts - (Python) scripts
106 for cmd_name in self.get_sub_commands():
107 self.run_command(cmd_name)
Greg Ward13ae1c81999-03-22 14:55:25 +0000108
Greg Ward13ae1c81999-03-22 14:55:25 +0000109
Greg Ward64d855a2000-09-30 17:08:12 +0000110 # -- Predicates for the sub-command list ---------------------------
Greg Ward5f7c18e2000-02-05 02:24:16 +0000111
Greg Ward64d855a2000-09-30 17:08:12 +0000112 def has_pure_modules (self):
113 return self.distribution.has_pure_modules()
Greg Ward13ae1c81999-03-22 14:55:25 +0000114
Greg Ward64d855a2000-09-30 17:08:12 +0000115 def has_c_libraries (self):
116 return self.distribution.has_c_libraries()
117
118 def has_ext_modules (self):
119 return self.distribution.has_ext_modules()
120
121 def has_scripts (self):
122 return self.distribution.has_scripts()
123
124
125 sub_commands = [('build_py', has_pure_modules),
126 ('build_clib', has_c_libraries),
127 ('build_ext', has_ext_modules),
128 ('build_scripts', has_scripts),
129 ]
Greg Ward8d5881a2000-05-25 01:19:18 +0000130
Greg Wardfcd974e2000-05-25 01:10:04 +0000131# class build