diff options
author | Georg Brandl <georg@python.org> | 2010-10-14 07:29:08 (GMT) |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2010-10-14 07:29:08 (GMT) |
commit | cbeb9fa6177ce88fef04904295aa2defc9a7a467 (patch) | |
tree | a1e8e02b1e8efe1e3173933b54d7f170ef7691a6 /Lib/lib2to3/fixes | |
parent | fb3c84a8d9974a49c0008a1832a9c9a3d001c4b4 (diff) | |
download | cpython-cbeb9fa6177ce88fef04904295aa2defc9a7a467.zip cpython-cbeb9fa6177ce88fef04904295aa2defc9a7a467.tar.gz cpython-cbeb9fa6177ce88fef04904295aa2defc9a7a467.tar.bz2 |
#9964: fix lib2to3 fixer fix_operator when running under -OO.
Diffstat (limited to 'Lib/lib2to3/fixes')
-rw-r--r-- | Lib/lib2to3/fixes/fix_operator.py | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/Lib/lib2to3/fixes/fix_operator.py b/Lib/lib2to3/fixes/fix_operator.py index c393f1e..3ea36f5 100644 --- a/Lib/lib2to3/fixes/fix_operator.py +++ b/Lib/lib2to3/fixes/fix_operator.py @@ -10,11 +10,19 @@ operator.irepeat(obj, n) -> operator.imul(obj, n) """ import collections +from functools import wraps # Local imports from lib2to3 import fixer_base from lib2to3.fixer_util import Call, Name, String, touch_import +def useinstead(what): + """Make sure __doc__ is assigned even under -OO.""" + def deco(f): + f.__doc__ = what + return f + return deco + class FixOperator(fixer_base.BaseFix): @@ -36,34 +44,34 @@ class FixOperator(fixer_base.BaseFix): if method is not None: return method(node, results) + @useinstead("operator.contains(%s)") def _sequenceIncludes(self, node, results): - """operator.contains(%s)""" return self._handle_rename(node, results, "contains") + @useinstead("hasattr(%s, '__call__')") def _isCallable(self, node, results): - """hasattr(%s, '__call__')""" obj = results["obj"] args = [obj.clone(), String(", "), String("'__call__'")] return Call(Name("hasattr"), args, prefix=node.prefix) + @useinstead("operator.mul(%s)") def _repeat(self, node, results): - """operator.mul(%s)""" return self._handle_rename(node, results, "mul") + @useinstead("operator.imul(%s)") def _irepeat(self, node, results): - """operator.imul(%s)""" return self._handle_rename(node, results, "imul") + @useinstead("isinstance(%s, collections.Sequence)") def _isSequenceType(self, node, results): - """isinstance(%s, collections.Sequence)""" return self._handle_type2abc(node, results, "collections", "Sequence") + @useinstead("isinstance(%s, collections.Mapping)") def _isMappingType(self, node, results): - """isinstance(%s, collections.Mapping)""" return self._handle_type2abc(node, results, "collections", "Mapping") + @useinstead("isinstance(%s, numbers.Number)") def _isNumberType(self, node, results): - """isinstance(%s, numbers.Number)""" return self._handle_type2abc(node, results, "numbers", "Number") def _handle_rename(self, node, results, name): |