PATH:
usr
/
lib64
/
python3.6
/
lib2to3
/
fixes
# Copyright 2006 Google, Inc. All Rights Reserved. # Licensed to PSF under a Contributor Agreement. """Fixer for apply(). This converts apply(func, v, k) into (func)(*v, **k).""" # Local imports from .. import pytree from ..pgen2 import token from .. import fixer_base from ..fixer_util import Call, Comma, parenthesize class FixApply(fixer_base.BaseFix): BM_compatible = True PATTERN = """ power< 'apply' trailer< '(' arglist< (not argument<NAME '=' any>) func=any ',' (not argument<NAME '=' any>) args=any [',' (not argument<NAME '=' any>) kwds=any] [','] > ')' > > """ def transform(self, node, results): syms = self.syms assert results func = results["func"] args = results["args"] kwds = results.get("kwds") # I feel like we should be able to express this logic in the # PATTERN above but I don't know how to do it so... if args: if args.type == self.syms.star_expr: return # Make no change. if (args.type == self.syms.argument and args.children[0].value == '**'): return # Make no change. if kwds and (kwds.type == self.syms.argument and kwds.children[0].value == '**'): return # Make no change. prefix = node.prefix func = func.clone() if (func.type not in (token.NAME, syms.atom) and (func.type != syms.power or func.children[-2].type == token.DOUBLESTAR)): # Need to parenthesize func = parenthesize(func) func.prefix = "" args = args.clone() args.prefix = "" if kwds is not None: kwds = kwds.clone() kwds.prefix = "" l_newargs = [pytree.Leaf(token.STAR, "*"), args] if kwds is not None: l_newargs.extend([Comma(), pytree.Leaf(token.DOUBLESTAR, "**"), kwds]) l_newargs[-2].prefix = " " # that's the ** token # XXX Sometimes we could be cleverer, e.g. apply(f, (x, y) + t) # can be translated into f(x, y, *t) instead of f(*(x, y) + t) #new = pytree.Node(syms.power, (func, ArgList(l_newargs))) return Call(func, l_newargs, prefix=prefix)
[-] fix_urllib.py
[edit]
[-] fix_standarderror.py
[edit]
[-] fix_imports.py
[edit]
[-] fix_getcwdu.py
[edit]
[-] fix_nonzero.py
[edit]
[-] fix_itertools.py
[edit]
[-] fix_xrange.py
[edit]
[-] fix_metaclass.py
[edit]
[-] fix_methodattrs.py
[edit]
[+]
..
[-] fix_ne.py
[edit]
[-] fix_repr.py
[edit]
[-] fix_zip.py
[edit]
[-] fix_exec.py
[edit]
[-] fix_print.py
[edit]
[-] fix_paren.py
[edit]
[-] fix_imports2.py
[edit]
[-] fix_apply.py
[edit]
[-] fix_ws_comma.py
[edit]
[-] fix_dict.py
[edit]
[-] fix_buffer.py
[edit]
[-] fix_intern.py
[edit]
[-] fix_next.py
[edit]
[-] fix_itertools_imports.py
[edit]
[-] fix_throw.py
[edit]
[+]
__pycache__
[-] fix_long.py
[edit]
[-] fix_raw_input.py
[edit]
[-] fix_future.py
[edit]
[-] fix_exitfunc.py
[edit]
[-] fix_renames.py
[edit]
[-] fix_input.py
[edit]
[-] fix_reduce.py
[edit]
[-] fix_operator.py
[edit]
[-] fix_numliterals.py
[edit]
[-] fix_isinstance.py
[edit]
[-] fix_basestring.py
[edit]
[-] fix_filter.py
[edit]
[-] fix_raise.py
[edit]
[-] fix_types.py
[edit]
[-] fix_funcattrs.py
[edit]
[-] fix_set_literal.py
[edit]
[-] __init__.py
[edit]
[-] fix_execfile.py
[edit]
[-] fix_unicode.py
[edit]
[-] fix_reload.py
[edit]
[-] fix_import.py
[edit]
[-] fix_sys_exc.py
[edit]
[-] fix_asserts.py
[edit]
[-] fix_map.py
[edit]
[-] fix_tuple_params.py
[edit]
[-] fix_xreadlines.py
[edit]
[-] fix_except.py
[edit]
[-] fix_has_key.py
[edit]
[-] fix_idioms.py
[edit]