summaryrefslogtreecommitdiffstats
path: root/Lib/distutils
diff options
context:
space:
mode:
authorTarek Ziadé <ziade.tarek@gmail.com>2009-02-07 00:05:39 (GMT)
committerTarek Ziadé <ziade.tarek@gmail.com>2009-02-07 00:05:39 (GMT)
commit8be8765a2e90bf0b93ce9a1f3cfe8cea61943000 (patch)
treec3c36002520918af3acce3563be6f823a59f529d /Lib/distutils
parent363161a418225a70ac68a0e11526ead0314c68d5 (diff)
downloadcpython-8be8765a2e90bf0b93ce9a1f3cfe8cea61943000.zip
cpython-8be8765a2e90bf0b93ce9a1f3cfe8cea61943000.tar.gz
cpython-8be8765a2e90bf0b93ce9a1f3cfe8cea61943000.tar.bz2
#3986 replacing string and types call (like in the Py3k branch), and put exec_msg call at the right place
Diffstat (limited to 'Lib/distutils')
-rw-r--r--Lib/distutils/cmd.py30
-rw-r--r--Lib/distutils/tests/test_cmd.py49
2 files changed, 55 insertions, 24 deletions
diff --git a/Lib/distutils/cmd.py b/Lib/distutils/cmd.py
index 2d6cfb1..1351f44 100644
--- a/Lib/distutils/cmd.py
+++ b/Lib/distutils/cmd.py
@@ -6,7 +6,7 @@ in the distutils.command package.
__revision__ = "$Id$"
-import sys, os, string, re
+import sys, os, re
from distutils.errors import DistutilsOptionError
from distutils import util, dir_util, file_util, archive_util, dep_util
from distutils import log
@@ -156,19 +156,19 @@ class Command:
"abstract method -- subclass %s must override" % self.__class__
- def dump_options (self, header=None, indent=""):
+ def dump_options(self, header=None, indent=""):
from distutils.fancy_getopt import longopt_xlate
if header is None:
header = "command options for '%s':" % self.get_command_name()
- print indent + header
+ self.announce(indent + header, level=log.INFO)
indent = indent + " "
for (option, _, _) in self.user_options:
- option = string.translate(option, longopt_xlate)
+ option = option.translate(longopt_xlate)
if option[-1] == "=":
option = option[:-1]
value = getattr(self, option)
- print indent + "%s = %s" % (option, value)
-
+ self.announce(indent + "%s = %s" % (option, value),
+ level=log.INFO)
def run (self):
"""A command's raison d'etre: carry out the action it exists to
@@ -405,8 +405,8 @@ class Command:
base_name, format, root_dir, base_dir, dry_run=self.dry_run)
- def make_file (self, infiles, outfile, func, args,
- exec_msg=None, skip_msg=None, level=1):
+ def make_file(self, infiles, outfile, func, args,
+ exec_msg=None, skip_msg=None, level=1):
"""Special case of 'execute()' for operations that process one or
more input files and generate one output file. Works just like
'execute()', except the operation is skipped and a different
@@ -415,24 +415,24 @@ class Command:
and it is true, then the command is unconditionally run -- does no
timestamp checks.
"""
- if exec_msg is None:
- exec_msg = "generating %s from %s" % \
- (outfile, string.join(infiles, ', '))
if skip_msg is None:
skip_msg = "skipping %s (inputs unchanged)" % outfile
-
# Allow 'infiles' to be a single string
- if type(infiles) is StringType:
+ if isinstance(infiles, str):
infiles = (infiles,)
- elif type(infiles) not in (ListType, TupleType):
+ elif not isinstance(infiles, (list, tuple)):
raise TypeError, \
"'infiles' must be a string, or a list or tuple of strings"
+ if exec_msg is None:
+ exec_msg = "generating %s from %s" % \
+ (outfile, ', '.join(infiles))
+
# If 'outfile' must be regenerated (either because it doesn't
# exist, is out-of-date, or the 'force' flag is true) then
# perform the action that presumably regenerates it
- if self.force or dep_util.newer_group (infiles, outfile):
+ if self.force or dep_util.newer_group(infiles, outfile):
self.execute(func, args, exec_msg, level)
# Otherwise, print the "skip" message
diff --git a/Lib/distutils/tests/test_cmd.py b/Lib/distutils/tests/test_cmd.py
index 19079c0..a252c35 100644
--- a/Lib/distutils/tests/test_cmd.py
+++ b/Lib/distutils/tests/test_cmd.py
@@ -5,23 +5,23 @@ from distutils.cmd import Command
from distutils.dist import Distribution
from distutils.errors import DistutilsOptionError
-class CommandTestCase(unittest.TestCase):
-
- def test_ensure_string_list(self):
-
- class MyCmd(Command):
+class MyCmd(Command):
+ def initialize_options(self):
+ pass
- def initialize_options(self):
- pass
+class CommandTestCase(unittest.TestCase):
+ def setUp(self):
dist = Distribution()
- cmd = MyCmd(dist)
+ self.cmd = MyCmd(dist)
+
+ def test_ensure_string_list(self):
+ cmd = self.cmd
cmd.not_string_list = ['one', 2, 'three']
cmd.yes_string_list = ['one', 'two', 'three']
cmd.not_string_list2 = object()
cmd.yes_string_list2 = 'ok'
-
cmd.ensure_string_list('yes_string_list')
cmd.ensure_string_list('yes_string_list2')
@@ -31,6 +31,37 @@ class CommandTestCase(unittest.TestCase):
self.assertRaises(DistutilsOptionError,
cmd.ensure_string_list, 'not_string_list2')
+ def test_make_file(self):
+
+ cmd = self.cmd
+
+ # making sure it raises when infiles is not a string or a list/tuple
+ self.assertRaises(TypeError, cmd.make_file,
+ infiles=1, outfile='', func='func', args=())
+
+ # making sure execute gets called properly
+ def _execute(func, args, exec_msg, level):
+ self.assertEquals(exec_msg, 'generating out from in')
+ cmd.force = True
+ cmd.execute = _execute
+ cmd.make_file(infiles='in', outfile='out', func='func', args=())
+
+ def test_dump_options(self):
+
+ msgs = []
+ def _announce(msg, level):
+ msgs.append(msg)
+ cmd = self.cmd
+ cmd.announce = _announce
+ cmd.option1 = 1
+ cmd.option2 = 1
+ cmd.user_options = [('option1', '', ''), ('option2', '', '')]
+ cmd.dump_options()
+
+ wanted = ["command options for 'MyCmd':", ' option1 = 1',
+ ' option2 = 1']
+ self.assertEquals(msgs, wanted)
+
def test_suite():
return unittest.makeSuite(CommandTestCase)