summaryrefslogtreecommitdiffstats
path: root/Lib/lib2to3
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2010-10-14 07:29:08 (GMT)
committerGeorg Brandl <georg@python.org>2010-10-14 07:29:08 (GMT)
commitcbeb9fa6177ce88fef04904295aa2defc9a7a467 (patch)
treea1e8e02b1e8efe1e3173933b54d7f170ef7691a6 /Lib/lib2to3
parentfb3c84a8d9974a49c0008a1832a9c9a3d001c4b4 (diff)
downloadcpython-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')
-rw-r--r--Lib/lib2to3/fixes/fix_operator.py22
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):