| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | """distutils.core
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The only module that needs to be imported to use the Distutils; provides | 
					
						
							| 
									
										
										
										
											2000-04-04 01:40:52 +00:00
										 |  |  | the 'setup' function (which is to be called from the setup script).  Also | 
					
						
							|  |  |  | indirectly provides the Distribution and Command classes, although they are | 
					
						
							|  |  |  | really defined in distutils.dist and distutils.cmd."""
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # created 1999/03/01, Greg Ward | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-03-02 01:49:45 +00:00
										 |  |  | __revision__ = "$Id$" | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-04-22 03:20:49 +00:00
										 |  |  | import sys, os | 
					
						
							| 
									
										
										
										
											1999-08-29 18:20:32 +00:00
										 |  |  | from types import * | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | from distutils.errors import * | 
					
						
							| 
									
										
										
										
											2000-05-31 01:11:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Mainly import these so setup scripts can "from distutils.core import" them. | 
					
						
							| 
									
										
										
										
											2000-04-04 01:40:52 +00:00
										 |  |  | from distutils.dist import Distribution | 
					
						
							|  |  |  | from distutils.cmd import Command | 
					
						
							| 
									
										
										
										
											2000-05-31 01:11:20 +00:00
										 |  |  | from distutils.extension import Extension | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-02-18 00:26:23 +00:00
										 |  |  | # This is a barebones help message generated displayed when the user | 
					
						
							|  |  |  | # runs the setup script with no arguments at all.  More useful help | 
					
						
							|  |  |  | # is generated with various --help options: global help, list commands, | 
					
						
							|  |  |  | # and per-command help. | 
					
						
							| 
									
										
										
										
											1999-12-12 16:51:44 +00:00
										 |  |  | usage = """\
 | 
					
						
							|  |  |  | usage: %s [global_opts] cmd1 [cmd1_opts] [cmd2 [cmd2_opts] ...] | 
					
						
							| 
									
										
										
										
											2000-05-23 01:43:08 +00:00
										 |  |  |    or: %s --help [cmd1 cmd2 ...] | 
					
						
							| 
									
										
										
										
											2000-01-30 18:30:32 +00:00
										 |  |  |    or: %s --help-commands | 
					
						
							| 
									
										
										
										
											1999-12-12 16:51:44 +00:00
										 |  |  |    or: %s cmd --help | 
					
						
							| 
									
										
										
										
											2000-05-23 01:43:08 +00:00
										 |  |  | """ % ((os.path.basename(sys.argv[0]),) * 4)
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-26 00:54:52 +00:00
										 |  |  | # If DISTUTILS_DEBUG is anything other than the empty string, we run in | 
					
						
							|  |  |  | # debug mode. | 
					
						
							|  |  |  | DEBUG = os.environ.get('DISTUTILS_DEBUG') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | def setup (**attrs): | 
					
						
							|  |  |  |     """The gateway to the Distutils: do everything your setup script
 | 
					
						
							|  |  |  |        needs to do, in a highly flexible and user-driven way.  Briefly: | 
					
						
							|  |  |  |        create a Distribution instance; parse the command-line, creating | 
					
						
							|  |  |  |        and customizing instances of the command class for each command | 
					
						
							|  |  |  |        found on the command-line; run each of those commands. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        The Distribution instance might be an instance of a class | 
					
						
							|  |  |  |        supplied via the 'distclass' keyword argument to 'setup'; if no | 
					
						
							|  |  |  |        such class is supplied, then the 'Distribution' class (also in | 
					
						
							|  |  |  |        this module) is instantiated.  All other arguments to 'setup' | 
					
						
							|  |  |  |        (except for 'cmdclass') are used to set attributes of the | 
					
						
							|  |  |  |        Distribution instance. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        The 'cmdclass' argument, if supplied, is a dictionary mapping | 
					
						
							| 
									
										
										
										
											2000-02-18 00:26:23 +00:00
										 |  |  |        command names to command classes.  Each command encountered on | 
					
						
							|  |  |  |        the command line will be turned into a command class, which is in | 
					
						
							|  |  |  |        turn instantiated; any class found in 'cmdclass' is used in place | 
					
						
							|  |  |  |        of the default, which is (for command 'foo_bar') class 'foo_bar' | 
					
						
							|  |  |  |        in module 'distutils.command.foo_bar'.  The command class must | 
					
						
							|  |  |  |        provide a 'user_options' attribute which is a list of option | 
					
						
							|  |  |  |        specifiers for 'distutils.fancy_getopt'.  Any command-line | 
					
						
							|  |  |  |        options between the current and the next command are used to set | 
					
						
							|  |  |  |        attributes of the current command object. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        When the entire command-line has been successfully parsed, calls | 
					
						
							|  |  |  |        the 'run()' method on each command object in turn.  This method | 
					
						
							|  |  |  |        will be driven entirely by the Distribution object (which each | 
					
						
							|  |  |  |        command object has a reference to, thanks to its constructor), | 
					
						
							|  |  |  |        and the command-specific options that became attributes of each | 
					
						
							|  |  |  |        command object."""
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-23 03:54:16 +00:00
										 |  |  |     from pprint import pprint               # for debugging output | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  |     # Determine the distribution class -- either caller-supplied or | 
					
						
							|  |  |  |     # our Distribution (see below). | 
					
						
							|  |  |  |     klass = attrs.get ('distclass') | 
					
						
							|  |  |  |     if klass: | 
					
						
							|  |  |  |         del attrs['distclass'] | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         klass = Distribution | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the Distribution instance, using the remaining arguments | 
					
						
							|  |  |  |     # (ie. everything except distclass) to initialize it | 
					
						
							|  |  |  |     dist = klass (attrs) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-12 00:42:19 +00:00
										 |  |  |     # Find and parse the config file(s): they will override options from | 
					
						
							|  |  |  |     # the setup script, but be overridden by the command line. | 
					
						
							|  |  |  |     dist.parse_config_files() | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2000-05-23 03:54:16 +00:00
										 |  |  |     print "options (after parsing config files):" | 
					
						
							|  |  |  |     pprint (dist.command_options) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-12 00:42:19 +00:00
										 |  |  |     # Parse the command line; any command-line errors are the end user's | 
					
						
							| 
									
										
										
										
											1999-09-08 02:41:09 +00:00
										 |  |  |     # fault, so turn them into SystemExit to suppress tracebacks. | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  |     try: | 
					
						
							| 
									
										
										
										
											1999-12-12 16:51:44 +00:00
										 |  |  |         ok = dist.parse_command_line (sys.argv[1:]) | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  |     except DistutilsArgError, msg: | 
					
						
							| 
									
										
										
										
											1999-12-12 16:51:44 +00:00
										 |  |  |         sys.stderr.write (usage + "\n") | 
					
						
							| 
									
										
										
										
											1999-12-16 01:19:05 +00:00
										 |  |  |         raise SystemExit, "error: %s" % msg | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-23 03:54:16 +00:00
										 |  |  |     print "options (after parsing command line):" | 
					
						
							|  |  |  |     pprint (dist.command_options) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  |     # And finally, run all the commands found on the command line. | 
					
						
							| 
									
										
										
										
											1999-12-12 16:51:44 +00:00
										 |  |  |     if ok: | 
					
						
							|  |  |  |         try: | 
					
						
							|  |  |  |             dist.run_commands () | 
					
						
							|  |  |  |         except KeyboardInterrupt: | 
					
						
							|  |  |  |             raise SystemExit, "interrupted" | 
					
						
							| 
									
										
										
										
											2000-04-22 03:20:49 +00:00
										 |  |  |         except (IOError, os.error), exc: | 
					
						
							|  |  |  |             # check for Python 1.5.2-style {IO,OS}Error exception objects | 
					
						
							| 
									
										
										
										
											2000-02-26 00:49:40 +00:00
										 |  |  |             if hasattr (exc, 'filename') and hasattr (exc, 'strerror'): | 
					
						
							| 
									
										
										
										
											2000-04-22 03:20:49 +00:00
										 |  |  |                 if exc.filename: | 
					
						
							| 
									
										
										
										
											2000-05-26 00:54:52 +00:00
										 |  |  |                     error = "error: %s: %s" % (exc.filename, exc.strerror) | 
					
						
							| 
									
										
										
										
											2000-04-22 03:20:49 +00:00
										 |  |  |                 else: | 
					
						
							|  |  |  |                     # two-argument functions in posix module don't | 
					
						
							|  |  |  |                     # include the filename in the exception object! | 
					
						
							| 
									
										
										
										
											2000-05-26 00:54:52 +00:00
										 |  |  |                     error = "error: %s" % exc.strerror | 
					
						
							| 
									
										
										
										
											2000-02-26 00:49:40 +00:00
										 |  |  |             else: | 
					
						
							| 
									
										
										
										
											2000-05-26 00:54:52 +00:00
										 |  |  |                 error = "error: " + str(exc[-1]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if DEBUG: | 
					
						
							|  |  |  |                 sys.stderr.write(error + "\n") | 
					
						
							|  |  |  |                 raise | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 raise SystemExit, error | 
					
						
							|  |  |  |              | 
					
						
							| 
									
										
										
										
											2000-04-22 03:11:17 +00:00
										 |  |  |         except (DistutilsExecError, | 
					
						
							|  |  |  |                 DistutilsFileError, | 
					
						
							| 
									
										
										
										
											2000-05-30 02:04:29 +00:00
										 |  |  |                 DistutilsOptionError, | 
					
						
							|  |  |  |                 CCompilerError), msg: | 
					
						
							| 
									
										
										
										
											2000-05-26 00:54:52 +00:00
										 |  |  |             if DEBUG: | 
					
						
							|  |  |  |                 raise | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 raise SystemExit, "error: " + str(msg) | 
					
						
							| 
									
										
										
										
											1999-03-22 14:52:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # setup () |