| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  | """distutils.command.clean
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Implements the Distutils 'clean' command."""
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # contributed by Bastian Kleineidam <calvin@cs.uni-sb.de>, added 2000-03-18 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | __revision__ = "$Id$" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import os | 
					
						
							|  |  |  | from distutils.core import Command | 
					
						
							|  |  |  | from distutils.util import remove_tree | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class clean (Command): | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  |     description = "clean up output of 'build' command" | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  |     user_options = [ | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  |         ('build-base=', 'b', | 
					
						
							|  |  |  |          "base build directory (default: 'build.build-base')"), | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  |         ('build-lib=', None, | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  |          "build directory for all modules (default: 'build.build-lib')"), | 
					
						
							|  |  |  |         ('build-temp=', 't', | 
					
						
							|  |  |  |          "temporary build directory (default: 'build.build-temp')"), | 
					
						
							| 
									
										
										
										
											2000-05-13 02:30:15 +00:00
										 |  |  |         ('bdist-base=', None, | 
					
						
							| 
									
										
										
										
											2000-05-13 01:56:55 +00:00
										 |  |  |          "temporary directory for built distributions"), | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  |         ('all', 'a', | 
					
						
							|  |  |  |          "remove all build output, not just temporary by-products") | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def initialize_options(self): | 
					
						
							|  |  |  |         self.build_base = None | 
					
						
							|  |  |  |         self.build_lib = None | 
					
						
							|  |  |  |         self.build_temp = None | 
					
						
							| 
									
										
										
										
											2000-05-13 02:30:15 +00:00
										 |  |  |         self.bdist_base = None | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  |         self.all = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def finalize_options(self): | 
					
						
							|  |  |  |         self.set_undefined_options('build', | 
					
						
							| 
									
										
										
										
											2000-05-13 01:56:55 +00:00
										 |  |  |                                    ('build_base', 'build_base'), | 
					
						
							|  |  |  |                                    ('build_lib', 'build_lib'), | 
					
						
							| 
									
										
										
										
											2000-05-13 02:30:15 +00:00
										 |  |  |                                    ('build_temp', 'build_temp')) | 
					
						
							|  |  |  |         self.set_undefined_options('bdist', | 
					
						
							|  |  |  |                                    ('bdist_base', 'bdist_base')) | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def run(self): | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  |         # remove the build/temp.<plat> directory (unless it's already | 
					
						
							|  |  |  |         # gone) | 
					
						
							|  |  |  |         if os.path.exists (self.build_temp): | 
					
						
							|  |  |  |             remove_tree (self.build_temp, self.verbose, self.dry_run) | 
					
						
							| 
									
										
										
										
											2000-05-28 23:47:00 +00:00
										 |  |  |         else: | 
					
						
							|  |  |  |             self.warn ("'%s' does not exist -- can't clean it" % | 
					
						
							|  |  |  |                        self.build_temp) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              | 
					
						
							| 
									
										
										
										
											2000-03-18 15:37:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if self.all: | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  |             # remove the module build directory (unless already gone) | 
					
						
							|  |  |  |             if os.path.exists (self.build_lib): | 
					
						
							|  |  |  |                 remove_tree (self.build_lib, self.verbose, self.dry_run) | 
					
						
							| 
									
										
										
										
											2000-05-28 23:47:00 +00:00
										 |  |  |             else: | 
					
						
							|  |  |  |                 self.warn ("'%s' does not exist -- can't clean it" % | 
					
						
							|  |  |  |                            self.build_lib) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-05-13 01:56:55 +00:00
										 |  |  |             # remove the temporary directory used for creating built | 
					
						
							|  |  |  |             # distributions (default "build/bdist") -- eg. type of | 
					
						
							|  |  |  |             # built distribution will have its own subdirectory under | 
					
						
							|  |  |  |             # "build/bdist", but they'll be taken care of by | 
					
						
							|  |  |  |             # 'remove_tree()'. | 
					
						
							| 
									
										
										
										
											2000-05-13 02:30:15 +00:00
										 |  |  |             if os.path.exists (self.bdist_base): | 
					
						
							|  |  |  |                 remove_tree (self.bdist_base, self.verbose, self.dry_run) | 
					
						
							| 
									
										
										
										
											2000-05-28 23:47:00 +00:00
										 |  |  |             else: | 
					
						
							|  |  |  |                 self.warn ("'%s' does not exist -- can't clean it" % | 
					
						
							|  |  |  |                            self.bdist_base) | 
					
						
							| 
									
										
										
										
											2000-03-18 17:33:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # just for the heck of it, try to remove the base build directory: | 
					
						
							|  |  |  |         # we might have emptied it right now, but if not we don't care | 
					
						
							|  |  |  |         if not self.dry_run: | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 os.rmdir (self.build_base) | 
					
						
							|  |  |  |                 self.announce ("removing '%s'" % self.build_base) | 
					
						
							|  |  |  |             except OSError: | 
					
						
							|  |  |  |                 pass | 
					
						
							| 
									
										
										
										
											2000-05-25 01:10:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # class clean |