mirror of
https://github.com/python/cpython.git
synced 2025-07-23 11:15:24 +00:00

svn+ssh://pythondev@svn.python.org/python/trunk ................ r77898 | martin.v.loewis | 2010-02-01 02:15:39 +0100 (Mo, 01 Feb 2010) | 17 lines Merged revisions 77855-77856,77870 via svnmerge from svn+ssh://pythondev@svn.python.org/sandbox/trunk/2to3/lib2to3 ........ r77855 | benjamin.peterson | 2010-01-30 17:32:05 +0100 (Sa, 30 Jan 2010) | 1 line don't return node if it is not changed ........ r77856 | benjamin.peterson | 2010-01-30 17:35:29 +0100 (Sa, 30 Jan 2010) | 1 line return None to indicate no change ........ r77870 | benjamin.peterson | 2010-01-31 02:21:26 +0100 (So, 31 Jan 2010) | 1 line never return the original node given to transform() ........ ................
52 lines
1.8 KiB
Python
52 lines
1.8 KiB
Python
""" Fixer for imports of itertools.(imap|ifilter|izip|ifilterfalse) """
|
|
|
|
# Local imports
|
|
from lib2to3 import fixer_base
|
|
from lib2to3.fixer_util import BlankLine, syms, token
|
|
|
|
|
|
class FixItertoolsImports(fixer_base.BaseFix):
|
|
PATTERN = """
|
|
import_from< 'from' 'itertools' 'import' imports=any >
|
|
""" %(locals())
|
|
|
|
def transform(self, node, results):
|
|
imports = results['imports']
|
|
if imports.type == syms.import_as_name or not imports.children:
|
|
children = [imports]
|
|
else:
|
|
children = imports.children
|
|
for child in children[::2]:
|
|
if child.type == token.NAME:
|
|
member = child.value
|
|
name_node = child
|
|
else:
|
|
assert child.type == syms.import_as_name
|
|
name_node = child.children[0]
|
|
member_name = name_node.value
|
|
if member_name in ('imap', 'izip', 'ifilter'):
|
|
child.value = None
|
|
child.remove()
|
|
elif member_name == 'ifilterfalse':
|
|
node.changed()
|
|
name_node.value = 'filterfalse'
|
|
|
|
# Make sure the import statement is still sane
|
|
children = imports.children[:] or [imports]
|
|
remove_comma = True
|
|
for child in children:
|
|
if remove_comma and child.type == token.COMMA:
|
|
child.remove()
|
|
else:
|
|
remove_comma ^= True
|
|
|
|
if children[-1].type == token.COMMA:
|
|
children[-1].remove()
|
|
|
|
# If there are no imports left, just get rid of the entire statement
|
|
if not (imports.children or getattr(imports, 'value', None)) or \
|
|
imports.parent is None:
|
|
p = node.prefix
|
|
node = BlankLine()
|
|
node.prefix = p
|
|
return node
|