SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > site-packages > astroid >


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/cloudlinux/venv/lib64/python3.11/site-packages/astroid/

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
brain Directory - -
interpreter Directory - -
nodes Directory - -
__init__.py File 5104 bytes April 17 2025 13:10:59.
__pkginfo__.py File 274 bytes April 17 2025 13:10:59.
_ast.py File 4146 bytes April 17 2025 13:10:59.
_backport_stdlib_names.py File 7016 bytes April 17 2025 13:10:59.
_cache.py File 786 bytes April 17 2025 13:10:59.
arguments.py File 12958 bytes April 17 2025 13:10:59.
astroid_manager.py File 572 bytes April 17 2025 13:10:59.
bases.py File 25594 bytes April 17 2025 13:10:59.
builder.py File 18788 bytes April 17 2025 13:10:59.
const.py File 1095 bytes April 17 2025 13:10:59.
constraint.py File 5043 bytes April 17 2025 13:10:59.
context.py File 5994 bytes April 17 2025 13:10:59.
decorators.py File 10090 bytes April 17 2025 13:10:59.
exceptions.py File 13089 bytes April 17 2025 13:10:59.
filter_statements.py File 9643 bytes April 17 2025 13:10:59.
helpers.py File 11336 bytes April 17 2025 13:10:59.
inference.py File 45121 bytes April 17 2025 13:10:59.
inference_tip.py File 2888 bytes April 17 2025 13:10:59.
manager.py File 17960 bytes April 17 2025 13:10:59.
mixins.py File 1182 bytes April 17 2025 13:10:59.
modutils.py File 23508 bytes April 17 2025 13:10:59.
node_classes.py File 1840 bytes April 17 2025 13:10:59.
objects.py File 12757 bytes April 17 2025 13:10:59.
protocols.py File 32976 bytes April 17 2025 13:10:59.
raw_building.py File 22875 bytes April 17 2025 13:10:59.
rebuilder.py File 79731 bytes April 17 2025 13:10:59.
scoped_nodes.py File 958 bytes April 17 2025 13:10:59.
test_utils.py File 2434 bytes April 17 2025 13:10:59.
transforms.py File 3271 bytes April 17 2025 13:10:59.
typing.py File 1983 bytes April 17 2025 13:10:59.
util.py File 4729 bytes April 17 2025 13:10:59.

Reading File: //opt/cloudlinux/venv/lib64/python3.11/site-packages/astroid//transforms.py

# Licensed under the LGPL: https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html
# For details: https://github.com/PyCQA/astroid/blob/main/LICENSE
# Copyright (c) https://github.com/PyCQA/astroid/blob/main/CONTRIBUTORS.txt

from __future__ import annotations

import collections
from typing import TYPE_CHECKING

from astroid.context import _invalidate_cache

if TYPE_CHECKING:
    from astroid import NodeNG


class TransformVisitor:
    """A visitor for handling transforms.

    The standard approach of using it is to call
    :meth:`~visit` with an *astroid* module and the class
    will take care of the rest, walking the tree and running the
    transforms for each encountered node.

    Based on its usage in AstroidManager.brain, it should not be reinstantiated.
    """

    def __init__(self):
        self.transforms = collections.defaultdict(list)

    def _transform(self, node: NodeNG) -> NodeNG:
        """Call matching transforms for the given node if any and return the
        transformed node.
        """
        cls = node.__class__

        transforms = self.transforms[cls]
        for transform_func, predicate in transforms:
            if predicate is None or predicate(node):
                ret = transform_func(node)
                # if the transformation function returns something, it's
                # expected to be a replacement for the node
                if ret is not None:
                    _invalidate_cache()
                    node = ret
                if ret.__class__ != cls:
                    # Can no longer apply the rest of the transforms.
                    break
        return node

    def _visit(self, node):
        if hasattr(node, "_astroid_fields"):
            for name in node._astroid_fields:
                value = getattr(node, name)
                visited = self._visit_generic(value)
                if visited != value:
                    setattr(node, name, visited)
        return self._transform(node)

    def _visit_generic(self, node):
        if isinstance(node, list):
            return [self._visit_generic(child) for child in node]
        if isinstance(node, tuple):
            return tuple(self._visit_generic(child) for child in node)
        if not node or isinstance(node, str):
            return node

        return self._visit(node)

    def register_transform(self, node_class, transform, predicate=None) -> None:
        """Register `transform(node)` function to be applied on the given
        astroid's `node_class` if `predicate` is None or returns true
        when called with the node as argument.

        The transform function may return a value which is then used to
        substitute the original node in the tree.
        """
        self.transforms[node_class].append((transform, predicate))

    def unregister_transform(self, node_class, transform, predicate=None) -> None:
        """Unregister the given transform."""
        self.transforms[node_class].remove((transform, predicate))

    def visit(self, module):
        """Walk the given astroid *tree* and transform each encountered node.

        Only the nodes which have transforms registered will actually
        be replaced or changed.
        """
        return self._visit(module)

SILENT KILLER Tool