SILENT KILLERPanel

Current Path: > > opt > alt > > python33 > lib64 > python3.3 > > lib2to3 > fixes


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt//python33/lib64/python3.3//lib2to3/fixes

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 47 bytes April 17 2024 16:58:20.
fix_apply.py File 1901 bytes April 17 2024 16:58:20.
fix_basestring.py File 320 bytes April 17 2024 16:58:20.
fix_buffer.py File 590 bytes April 17 2024 16:58:20.
fix_callable.py File 1151 bytes April 17 2024 16:58:20.
fix_dict.py File 3816 bytes April 17 2024 16:58:20.
fix_except.py File 3344 bytes April 17 2024 16:58:20.
fix_exec.py File 1001 bytes April 17 2024 16:58:20.
fix_execfile.py File 1990 bytes April 17 2024 16:58:20.
fix_exitfunc.py File 2497 bytes April 17 2024 16:58:20.
fix_filter.py File 2102 bytes April 17 2024 16:58:20.
fix_funcattrs.py File 644 bytes April 17 2024 16:58:20.
fix_future.py File 547 bytes April 17 2024 16:58:20.
fix_getcwdu.py File 451 bytes April 17 2024 16:58:20.
fix_has_key.py File 3222 bytes April 17 2024 16:58:20.
fix_idioms.py File 4876 bytes April 17 2024 16:58:20.
fix_import.py File 3256 bytes April 17 2024 16:58:20.
fix_imports.py File 5684 bytes April 17 2024 16:58:20.
fix_imports2.py File 289 bytes April 17 2024 16:58:20.
fix_input.py File 707 bytes April 17 2024 16:58:20.
fix_intern.py File 1402 bytes April 17 2024 16:58:20.
fix_isinstance.py File 1608 bytes April 17 2024 16:58:20.
fix_itertools.py File 1548 bytes April 17 2024 16:58:20.
fix_itertools_imports.py File 2086 bytes April 17 2024 16:58:20.
fix_long.py File 476 bytes April 17 2024 16:58:20.
fix_map.py File 3058 bytes April 17 2024 16:58:20.
fix_metaclass.py File 8201 bytes April 17 2024 16:58:20.
fix_methodattrs.py File 606 bytes April 17 2024 16:58:20.
fix_ne.py File 571 bytes April 17 2024 16:58:20.
fix_next.py File 3174 bytes April 17 2024 16:58:20.
fix_nonzero.py File 597 bytes April 17 2024 16:58:20.
fix_numliterals.py File 768 bytes April 17 2024 16:58:20.
fix_operator.py File 3471 bytes April 17 2024 16:58:20.
fix_paren.py File 1227 bytes April 17 2024 16:58:20.
fix_print.py File 2854 bytes April 17 2024 16:58:20.
fix_raise.py File 2926 bytes April 17 2024 16:58:20.
fix_raw_input.py File 454 bytes April 17 2024 16:58:20.
fix_reduce.py File 837 bytes April 17 2024 16:58:20.
fix_renames.py File 2221 bytes April 17 2024 16:58:20.
fix_repr.py File 613 bytes April 17 2024 16:58:20.
fix_set_literal.py File 1697 bytes April 17 2024 16:58:20.
fix_standarderror.py File 449 bytes April 17 2024 16:58:20.
fix_sys_exc.py File 1034 bytes April 17 2024 16:58:20.
fix_throw.py File 1582 bytes April 17 2024 16:58:20.
fix_tuple_params.py File 5565 bytes April 17 2024 16:58:20.
fix_types.py File 1797 bytes April 17 2024 16:58:20.
fix_unicode.py File 1256 bytes April 17 2024 16:58:20.
fix_urllib.py File 8384 bytes April 17 2024 16:58:20.
fix_ws_comma.py File 1090 bytes April 17 2024 16:58:20.
fix_xrange.py File 2694 bytes April 17 2024 16:58:20.
fix_xreadlines.py File 689 bytes April 17 2024 16:58:20.
fix_zip.py File 902 bytes April 17 2024 16:58:20.

Reading File: //opt/alt//python33/lib64/python3.3//lib2to3/fixes/fix_has_key.py

# Copyright 2006 Google, Inc. All Rights Reserved.
# Licensed to PSF under a Contributor Agreement.

"""Fixer for has_key().

Calls to .has_key() methods are expressed in terms of the 'in'
operator:

    d.has_key(k) -> k in d

CAVEATS:
1) While the primary target of this fixer is dict.has_key(), the
   fixer will change any has_key() method call, regardless of its
   class.

2) Cases like this will not be converted:

    m = d.has_key
    if m(k):
        ...

   Only *calls* to has_key() are converted. While it is possible to
   convert the above to something like

    m = d.__contains__
    if m(k):
        ...

   this is currently not done.
"""

# Local imports
from .. import pytree
from ..pgen2 import token
from .. import fixer_base
from ..fixer_util import Name, parenthesize


class FixHasKey(fixer_base.BaseFix):
    BM_compatible = True

    PATTERN = """
    anchor=power<
        before=any+
        trailer< '.' 'has_key' >
        trailer<
            '('
            ( not(arglist | argument<any '=' any>) arg=any
            | arglist<(not argument<any '=' any>) arg=any ','>
            )
            ')'
        >
        after=any*
    >
    |
    negation=not_test<
        'not'
        anchor=power<
            before=any+
            trailer< '.' 'has_key' >
            trailer<
                '('
                ( not(arglist | argument<any '=' any>) arg=any
                | arglist<(not argument<any '=' any>) arg=any ','>
                )
                ')'
            >
        >
    >
    """

    def transform(self, node, results):
        assert results
        syms = self.syms
        if (node.parent.type == syms.not_test and
            self.pattern.match(node.parent)):
            # Don't transform a node matching the first alternative of the
            # pattern when its parent matches the second alternative
            return None
        negation = results.get("negation")
        anchor = results["anchor"]
        prefix = node.prefix
        before = [n.clone() for n in results["before"]]
        arg = results["arg"].clone()
        after = results.get("after")
        if after:
            after = [n.clone() for n in after]
        if arg.type in (syms.comparison, syms.not_test, syms.and_test,
                        syms.or_test, syms.test, syms.lambdef, syms.argument):
            arg = parenthesize(arg)
        if len(before) == 1:
            before = before[0]
        else:
            before = pytree.Node(syms.power, before)
        before.prefix = " "
        n_op = Name("in", prefix=" ")
        if negation:
            n_not = Name("not", prefix=" ")
            n_op = pytree.Node(syms.comp_op, (n_not, n_op))
        new = pytree.Node(syms.comparison, (arg, n_op, before))
        if after:
            new = parenthesize(new)
            new = pytree.Node(syms.power, (new,) + tuple(after))
        if node.parent.type in (syms.comparison, syms.expr, syms.xor_expr,
                                syms.and_expr, syms.shift_expr,
                                syms.arith_expr, syms.term,
                                syms.factor, syms.power):
            new = parenthesize(new)
        new.prefix = prefix
        return new

SILENT KILLER Tool