OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
python3.7
/
lib2to3
/
fixes
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 06:58:00 AM
rwxr-xr-x
📄
__init__.py
47 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📁
__pycache__
-
05/09/2024 06:58:00 AM
rwxr-xr-x
📄
fix_apply.py
2.37 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_asserts.py
984 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_basestring.py
320 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_buffer.py
590 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_dict.py
3.67 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_except.py
3.27 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_exec.py
979 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_execfile.py
2 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_exitfunc.py
2.44 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_filter.py
2.59 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_funcattrs.py
644 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_future.py
547 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_getcwdu.py
451 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_has_key.py
3.12 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_idioms.py
4.76 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_import.py
3.18 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_imports.py
5.55 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_imports2.py
289 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_input.py
708 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_intern.py
1.21 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_isinstance.py
1.57 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_itertools.py
1.51 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_itertools_imports.py
2.04 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_long.py
476 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_map.py
3.55 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_metaclass.py
8 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_methodattrs.py
606 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_ne.py
571 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_next.py
3.1 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_nonzero.py
591 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_numliterals.py
768 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_operator.py
3.35 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_paren.py
1.2 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_print.py
2.78 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_raise.py
2.86 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_raw_input.py
454 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_reduce.py
837 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_reload.py
1.14 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_renames.py
2.17 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_repr.py
613 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_set_literal.py
1.66 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_standarderror.py
449 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_sys_exc.py
1.01 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_throw.py
1.54 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_tuple_params.py
5.43 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_types.py
1.73 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_unicode.py
1.23 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_urllib.py
8.16 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_ws_comma.py
1.06 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_xrange.py
2.63 KB
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_xreadlines.py
689 bytes
10/28/2019 04:30:34 PM
rw-r--r--
📄
fix_zip.py
1.26 KB
10/28/2019 04:30:34 PM
rw-r--r--
Editing: fix_apply.py
Close
# 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)