Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /opt/alt/python27/lib64/python2.7/lib2to3/fixes/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python27/lib64/python2.7/lib2to3/fixes/fix_metaclass.py
"""Fixer for __metaclass__ = X -> (metaclass=X) methods.

   The various forms of classef (inherits nothing, inherits once, inherints
   many) don't parse the same in the CST so we look at ALL classes for
   a __metaclass__ and if we find one normalize the inherits to all be
   an arglist.

   For one-liner classes ('class X: pass') there is no indent/dedent so
   we normalize those into having a suite.

   Moving the __metaclass__ into the classdef can also cause the class
   body to be empty so there is some special casing for that as well.

   This fixer also tries very hard to keep original indenting and spacing
   in all those corner cases.

"""
# Author: Jack Diederich

# Local imports
from .. import fixer_base
from ..pygram import token
from ..fixer_util import Name, syms, Node, Leaf


def has_metaclass(parent):
    """ we have to check the cls_node without changing it.
        There are two possibilities:
          1)  clsdef => suite => simple_stmt => expr_stmt => Leaf('__meta')
          2)  clsdef => simple_stmt => expr_stmt => Leaf('__meta')
    """
    for node in parent.children:
        if node.type == syms.suite:
            return has_metaclass(node)
        elif node.type == syms.simple_stmt and node.children:
            expr_node = node.children[0]
            if expr_node.type == syms.expr_stmt and expr_node.children:
                left_side = expr_node.children[0]
                if isinstance(left_side, Leaf) and \
                        left_side.value == '__metaclass__':
                    return True
    return False


def fixup_parse_tree(cls_node):
    """ one-line classes don't get a suite in the parse tree so we add
        one to normalize the tree
    """
    for node in cls_node.children:
        if node.type == syms.suite:
            # already in the preferred format, do nothing
            return

    # !%@#! oneliners have no suite node, we have to fake one up
    for i, node in enumerate(cls_node.children):
        if node.type == token.COLON:
            break
    else:
        raise ValueError("No class suite and no ':'!")

    # move everything into a suite node
    suite = Node(syms.suite, [])
    while cls_node.children[i+1:]:
        move_node = cls_node.children[i+1]
        suite.append_child(move_node.clone())
        move_node.remove()
    cls_node.append_child(suite)
    node = suite


def fixup_simple_stmt(parent, i, stmt_node):
    """ if there is a semi-colon all the parts count as part of the same
        simple_stmt.  We just want the __metaclass__ part so we move
        everything after the semi-colon into its own simple_stmt node
    """
    for semi_ind, node in enumerate(stmt_node.children):
        if node.type == token.SEMI: # *sigh*
            break
    else:
        return

    node.remove() # kill the semicolon
    new_expr = Node(syms.expr_stmt, [])
    new_stmt = Node(syms.simple_stmt, [new_expr])
    while stmt_node.children[semi_ind:]:
        move_node = stmt_node.children[semi_ind]
        new_expr.append_child(move_node.clone())
        move_node.remove()
    parent.insert_child(i, new_stmt)
    new_leaf1 = new_stmt.children[0].children[0]
    old_leaf1 = stmt_node.children[0].children[0]
    new_leaf1.prefix = old_leaf1.prefix


def remove_trailing_newline(node):
    if node.children and node.children[-1].type == token.NEWLINE:
        node.children[-1].remove()


def find_metas(cls_node):
    # find the suite node (Mmm, sweet nodes)
    for node in cls_node.children:
        if node.type == syms.suite:
            break
    else:
        raise ValueError("No class suite!")

    # look for simple_stmt[ expr_stmt[ Leaf('__metaclass__') ] ]
    for i, simple_node in list(enumerate(node.children)):
        if simple_node.type == syms.simple_stmt and simple_node.children:
            expr_node = simple_node.children[0]
            if expr_node.type == syms.expr_stmt and expr_node.children:
                # Check if the expr_node is a simple assignment.
                left_node = expr_node.children[0]
                if isinstance(left_node, Leaf) and \
                        left_node.value == u'__metaclass__':
                    # We found an assignment to __metaclass__.
                    fixup_simple_stmt(node, i, simple_node)
                    remove_trailing_newline(simple_node)
                    yield (node, i, simple_node)


def fixup_indent(suite):
    """ If an INDENT is followed by a thing with a prefix then nuke the prefix
        Otherwise we get in trouble when removing __metaclass__ at suite start
    """
    kids = suite.children[::-1]
    # find the first indent
    while kids:
        node = kids.pop()
        if node.type == token.INDENT:
            break

    # find the first Leaf
    while kids:
        node = kids.pop()
        if isinstance(node, Leaf) and node.type != token.DEDENT:
            if node.prefix:
                node.prefix = u''
            return
        else:
            kids.extend(node.children[::-1])


class FixMetaclass(fixer_base.BaseFix):
    BM_compatible = True

    PATTERN = """
    classdef<any*>
    """

    def transform(self, node, results):
        if not has_metaclass(node):
            return

        fixup_parse_tree(node)

        # find metaclasses, keep the last one
        last_metaclass = None
        for suite, i, stmt in find_metas(node):
            last_metaclass = stmt
            stmt.remove()

        text_type = node.children[0].type # always Leaf(nnn, 'class')

        # figure out what kind of classdef we have
        if len(node.children) == 7:
            # Node(classdef, ['class', 'name', '(', arglist, ')', ':', suite])
            #                 0        1       2    3        4    5    6
            if node.children[3].type == syms.arglist:
                arglist = node.children[3]
            # Node(classdef, ['class', 'name', '(', 'Parent', ')', ':', suite])
            else:
                parent = node.children[3].clone()
                arglist = Node(syms.arglist, [parent])
                node.set_child(3, arglist)
        elif len(node.children) == 6:
            # Node(classdef, ['class', 'name', '(',  ')', ':', suite])
            #                 0        1       2     3    4    5
            arglist = Node(syms.arglist, [])
            node.insert_child(3, arglist)
        elif len(node.children) == 4:
            # Node(classdef, ['class', 'name', ':', suite])
            #                 0        1       2    3
            arglist = Node(syms.arglist, [])
            node.insert_child(2, Leaf(token.RPAR, u')'))
            node.insert_child(2, arglist)
            node.insert_child(2, Leaf(token.LPAR, u'('))
        else:
            raise ValueError("Unexpected class definition")

        # now stick the metaclass in the arglist
        meta_txt = last_metaclass.children[0].children[0]
        meta_txt.value = 'metaclass'
        orig_meta_prefix = meta_txt.prefix

        if arglist.children:
            arglist.append_child(Leaf(token.COMMA, u','))
            meta_txt.prefix = u' '
        else:
            meta_txt.prefix = u''

        # compact the expression "metaclass = Meta" -> "metaclass=Meta"
        expr_stmt = last_metaclass.children[0]
        assert expr_stmt.type == syms.expr_stmt
        expr_stmt.children[1].prefix = u''
        expr_stmt.children[2].prefix = u''

        arglist.append_child(last_metaclass)

        fixup_indent(suite)

        # check for empty suite
        if not suite.children:
            # one-liner that was just __metaclass_
            suite.remove()
            pass_leaf = Leaf(text_type, u'pass')
            pass_leaf.prefix = orig_meta_prefix
            node.append_child(pass_leaf)
            node.append_child(Leaf(token.NEWLINE, u'\n'))

        elif len(suite.children) > 1 and \
                 (suite.children[-2].type == token.INDENT and
                  suite.children[-1].type == token.DEDENT):
            # there was only one line in the class body and it was __metaclass__
            pass_leaf = Leaf(text_type, u'pass')
            suite.insert_child(-1, pass_leaf)
            suite.insert_child(-1, Leaf(token.NEWLINE, u'\n'))
Name
Size
Permissions
Options
__init__.py
0.046 KB
-rw-r--r--
__init__.pyc
0.143 KB
-rw-r--r--
__init__.pyo
0.143 KB
-rw-r--r--
fix_apply.py
2.376 KB
-rw-r--r--
fix_apply.pyc
2.073 KB
-rw-r--r--
fix_apply.pyo
2.041 KB
-rw-r--r--
fix_asserts.py
0.961 KB
-rw-r--r--
fix_asserts.pyc
1.563 KB
-rw-r--r--
fix_asserts.pyo
1.563 KB
-rw-r--r--
fix_basestring.py
0.313 KB
-rw-r--r--
fix_basestring.pyc
0.826 KB
-rw-r--r--
fix_basestring.pyo
0.826 KB
-rw-r--r--
fix_buffer.py
0.577 KB
-rw-r--r--
fix_buffer.pyc
0.979 KB
-rw-r--r--
fix_buffer.pyo
0.979 KB
-rw-r--r--
fix_dict.py
3.734 KB
-rw-r--r--
fix_dict.pyc
3.731 KB
-rw-r--r--
fix_dict.pyo
3.609 KB
-rw-r--r--
fix_except.py
3.273 KB
-rw-r--r--
fix_except.pyc
2.989 KB
-rw-r--r--
fix_except.pyo
2.989 KB
-rw-r--r--
fix_exec.py
0.979 KB
-rw-r--r--
fix_exec.pyc
1.437 KB
-rw-r--r--
fix_exec.pyo
1.404 KB
-rw-r--r--
fix_execfile.py
2.008 KB
-rw-r--r--
fix_execfile.pyc
2.097 KB
-rw-r--r--
fix_execfile.pyo
2.064 KB
-rw-r--r--
fix_exitfunc.py
2.444 KB
-rw-r--r--
fix_exitfunc.pyc
2.756 KB
-rw-r--r--
fix_exitfunc.pyo
2.756 KB
-rw-r--r--
fix_filter.py
2.058 KB
-rw-r--r--
fix_filter.pyc
2.255 KB
-rw-r--r--
fix_filter.pyo
2.255 KB
-rw-r--r--
fix_funcattrs.py
0.63 KB
-rw-r--r--
fix_funcattrs.pyc
1.14 KB
-rw-r--r--
fix_funcattrs.pyo
1.14 KB
-rw-r--r--
fix_future.py
0.534 KB
-rw-r--r--
fix_future.pyc
0.949 KB
-rw-r--r--
fix_future.pyo
0.949 KB
-rw-r--r--
fix_getcwdu.py
0.441 KB
-rw-r--r--
fix_getcwdu.pyc
0.956 KB
-rw-r--r--
fix_getcwdu.pyo
0.956 KB
-rw-r--r--
fix_has_key.py
3.151 KB
-rw-r--r--
fix_has_key.pyc
3.161 KB
-rw-r--r--
fix_has_key.pyo
3.129 KB
-rw-r--r--
fix_idioms.py
4.774 KB
-rw-r--r--
fix_idioms.pyc
4.52 KB
-rw-r--r--
fix_idioms.pyo
4.418 KB
-rw-r--r--
fix_import.py
3.184 KB
-rw-r--r--
fix_import.pyc
3.253 KB
-rw-r--r--
fix_import.pyo
3.253 KB
-rw-r--r--
fix_imports.py
5.56 KB
-rw-r--r--
fix_imports.pyc
5.381 KB
-rw-r--r--
fix_imports.pyo
5.381 KB
-rw-r--r--
fix_imports2.py
0.282 KB
-rw-r--r--
fix_imports2.pyc
0.645 KB
-rw-r--r--
fix_imports2.pyo
0.645 KB
-rw-r--r--
fix_input.py
0.693 KB
-rw-r--r--
fix_input.pyc
1.159 KB
-rw-r--r--
fix_input.pyo
1.159 KB
-rw-r--r--
fix_intern.py
1.822 KB
-rw-r--r--
fix_intern.pyc
1.793 KB
-rw-r--r--
fix_intern.pyo
1.793 KB
-rw-r--r--
fix_isinstance.py
1.571 KB
-rw-r--r--
fix_isinstance.pyc
1.847 KB
-rw-r--r--
fix_isinstance.pyo
1.847 KB
-rw-r--r--
fix_itertools.py
1.514 KB
-rw-r--r--
fix_itertools.pyc
1.801 KB
-rw-r--r--
fix_itertools.pyo
1.801 KB
-rw-r--r--
fix_itertools_imports.py
2.045 KB
-rw-r--r--
fix_itertools_imports.pyc
2.021 KB
-rw-r--r--
fix_itertools_imports.pyo
1.977 KB
-rw-r--r--
fix_long.py
0.466 KB
-rw-r--r--
fix_long.pyc
0.873 KB
-rw-r--r--
fix_long.pyo
0.873 KB
-rw-r--r--
fix_map.py
2.99 KB
-rw-r--r--
fix_map.pyc
3.021 KB
-rw-r--r--
fix_map.pyo
3.021 KB
-rw-r--r--
fix_metaclass.py
8.023 KB
-rw-r--r--
fix_metaclass.pyc
6.564 KB
-rw-r--r--
fix_metaclass.pyo
6.516 KB
-rw-r--r--
fix_methodattrs.py
0.601 KB
-rw-r--r--
fix_methodattrs.pyc
1.163 KB
-rw-r--r--
fix_methodattrs.pyo
1.163 KB
-rw-r--r--
fix_ne.py
0.56 KB
-rw-r--r--
fix_ne.pyc
1.028 KB
-rw-r--r--
fix_ne.pyo
1.028 KB
-rw-r--r--
fix_next.py
3.106 KB
-rw-r--r--
fix_next.pyc
3.573 KB
-rw-r--r--
fix_next.pyo
3.541 KB
-rw-r--r--
fix_nonzero.py
0.584 KB
-rw-r--r--
fix_nonzero.pyc
1.112 KB
-rw-r--r--
fix_nonzero.pyo
1.112 KB
-rw-r--r--
fix_numliterals.py
0.755 KB
-rw-r--r--
fix_numliterals.pyc
1.286 KB
-rw-r--r--
fix_numliterals.pyo
1.286 KB
-rw-r--r--
fix_operator.py
3.391 KB
-rw-r--r--
fix_operator.pyc
5.22 KB
-rw-r--r--
fix_operator.pyo
5.22 KB
-rw-r--r--
fix_paren.py
1.199 KB
-rw-r--r--
fix_paren.pyc
1.559 KB
-rw-r--r--
fix_paren.pyo
1.559 KB
-rw-r--r--
fix_print.py
2.798 KB
-rw-r--r--
fix_print.pyc
2.729 KB
-rw-r--r--
fix_print.pyo
2.635 KB
-rw-r--r--
fix_raise.py
2.865 KB
-rw-r--r--
fix_raise.pyc
2.491 KB
-rw-r--r--
fix_raise.pyo
2.491 KB
-rw-r--r--
fix_raw_input.py
0.444 KB
-rw-r--r--
fix_raw_input.pyc
0.966 KB
-rw-r--r--
fix_raw_input.pyo
0.966 KB
-rw-r--r--
fix_reduce.py
0.819 KB
-rw-r--r--
fix_reduce.pyc
1.284 KB
-rw-r--r--
fix_reduce.pyo
1.284 KB
-rw-r--r--
fix_renames.py
2.166 KB
-rw-r--r--
fix_renames.pyc
2.502 KB
-rw-r--r--
fix_renames.pyo
2.502 KB
-rw-r--r--
fix_repr.py
0.6 KB
-rw-r--r--
fix_repr.pyc
1.044 KB
-rw-r--r--
fix_repr.pyo
1.044 KB
-rw-r--r--
fix_set_literal.py
1.659 KB
-rw-r--r--
fix_set_literal.pyc
2.008 KB
-rw-r--r--
fix_set_literal.pyo
2.008 KB
-rw-r--r--
fix_standarderror.py
0.439 KB
-rw-r--r--
fix_standarderror.pyc
0.885 KB
-rw-r--r--
fix_standarderror.pyo
0.885 KB
-rw-r--r--
fix_sys_exc.py
1.015 KB
-rw-r--r--
fix_sys_exc.pyc
1.731 KB
-rw-r--r--
fix_sys_exc.pyo
1.731 KB
-rw-r--r--
fix_throw.py
1.549 KB
-rw-r--r--
fix_throw.pyc
2.001 KB
-rw-r--r--
fix_throw.pyo
2.001 KB
-rw-r--r--
fix_tuple_params.py
5.446 KB
-rw-r--r--
fix_tuple_params.pyc
5.457 KB
-rw-r--r--
fix_tuple_params.pyo
5.457 KB
-rw-r--r--
fix_types.py
1.767 KB
-rw-r--r--
fix_types.pyc
2.196 KB
-rw-r--r--
fix_types.pyo
2.196 KB
-rw-r--r--
fix_unicode.py
1.239 KB
-rw-r--r--
fix_unicode.pyc
1.742 KB
-rw-r--r--
fix_unicode.pyo
1.742 KB
-rw-r--r--
fix_urllib.py
8.188 KB
-rw-r--r--
fix_urllib.pyc
7.106 KB
-rw-r--r--
fix_urllib.pyo
7.106 KB
-rw-r--r--
fix_ws_comma.py
1.069 KB
-rw-r--r--
fix_ws_comma.pyc
1.401 KB
-rw-r--r--
fix_ws_comma.pyo
1.401 KB
-rw-r--r--
fix_xrange.py
2.636 KB
-rw-r--r--
fix_xrange.pyc
3.116 KB
-rw-r--r--
fix_xrange.pyo
3.116 KB
-rw-r--r--
fix_xreadlines.py
0.674 KB
-rw-r--r--
fix_xreadlines.pyc
1.177 KB
-rw-r--r--
fix_xreadlines.pyo
1.177 KB
-rw-r--r--
fix_zip.py
0.883 KB
-rw-r--r--
fix_zip.pyc
1.366 KB
-rw-r--r--
fix_zip.pyo
1.366 KB
-rw-r--r--