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 01:56:55 +00:00
|
|
|
('build-bdist=', None,
|
|
|
|
"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 01:56:55 +00:00
|
|
|
self.build_bdist = None
|
2000-03-18 15:37:26 +00:00
|
|
|
self.all = None
|
|
|
|
|
|
|
|
def finalize_options(self):
|
2000-03-18 17:33:18 +00:00
|
|
|
if self.build_lib and not os.path.exists (self.build_lib):
|
|
|
|
self.warn ("'%s' does not exist -- can't clean it" %
|
|
|
|
self.build_lib)
|
|
|
|
if self.build_temp and not os.path.exists (self.build_temp):
|
|
|
|
self.warn ("'%s' does not exist -- can't clean it" %
|
|
|
|
self.build_temp)
|
|
|
|
|
2000-03-18 15:37:26 +00:00
|
|
|
self.set_undefined_options('build',
|
2000-05-13 01:56:55 +00:00
|
|
|
('build_base', 'build_base'),
|
|
|
|
('build_lib', 'build_lib'),
|
|
|
|
('build_temp', 'build_temp'),
|
|
|
|
('build_bdist', 'build_bdist'))
|
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-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-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:20:43 +00:00
|
|
|
if os.path.exists (self.build_bdist):
|
2000-05-13 01:56:55 +00:00
|
|
|
remove_tree (self.build_bdist, self.verbose, self.dry_run)
|
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
|