SILENT KILLERPanel

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


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/jinja2

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 2205 bytes April 17 2025 13:10:59.
_identifier.py File 1775 bytes April 17 2025 13:10:59.
async_utils.py File 1947 bytes April 17 2025 13:10:59.
bccache.py File 12670 bytes April 17 2025 13:10:59.
compiler.py File 72209 bytes April 17 2025 13:10:59.
constants.py File 1433 bytes April 17 2025 13:10:59.
debug.py File 8494 bytes April 17 2025 13:10:59.
defaults.py File 1267 bytes April 17 2025 13:10:59.
environment.py File 60983 bytes April 17 2025 13:10:59.
exceptions.py File 5071 bytes April 17 2025 13:10:59.
ext.py File 32122 bytes April 17 2025 13:10:59.
filters.py File 52609 bytes April 17 2025 13:10:59.
idtracking.py File 10721 bytes April 17 2025 13:10:59.
lexer.py File 29930 bytes April 17 2025 13:10:59.
loaders.py File 22754 bytes April 17 2025 13:10:59.
meta.py File 4396 bytes April 17 2025 13:10:59.
nativetypes.py File 3969 bytes April 17 2025 13:10:59.
nodes.py File 34550 bytes April 17 2025 13:10:59.
optimizer.py File 1650 bytes April 17 2025 13:10:59.
parser.py File 39767 bytes April 17 2025 13:10:59.
py.typed File 0 bytes April 17 2025 13:10:59.
runtime.py File 35054 bytes April 17 2025 13:10:59.
sandbox.py File 14600 bytes April 17 2025 13:10:59.
tests.py File 5905 bytes April 17 2025 13:10:59.
utils.py File 26971 bytes April 17 2025 13:10:59.
visitor.py File 3572 bytes April 17 2025 13:10:59.

Reading File: //opt/cloudlinux/venv/lib64/python3.11//site-packages/jinja2/visitor.py

"""API for traversing the AST nodes. Implemented by the compiler and
meta introspection.
"""
import typing as t

from .nodes import Node

if t.TYPE_CHECKING:
    import typing_extensions as te

    class VisitCallable(te.Protocol):
        def __call__(self, node: Node, *args: t.Any, **kwargs: t.Any) -> t.Any:
            ...


class NodeVisitor:
    """Walks the abstract syntax tree and call visitor functions for every
    node found.  The visitor functions may return values which will be
    forwarded by the `visit` method.

    Per default the visitor functions for the nodes are ``'visit_'`` +
    class name of the node.  So a `TryFinally` node visit function would
    be `visit_TryFinally`.  This behavior can be changed by overriding
    the `get_visitor` function.  If no visitor function exists for a node
    (return value `None`) the `generic_visit` visitor is used instead.
    """

    def get_visitor(self, node: Node) -> "t.Optional[VisitCallable]":
        """Return the visitor function for this node or `None` if no visitor
        exists for this node.  In that case the generic visit function is
        used instead.
        """
        return getattr(self, f"visit_{type(node).__name__}", None)  # type: ignore

    def visit(self, node: Node, *args: t.Any, **kwargs: t.Any) -> t.Any:
        """Visit a node."""
        f = self.get_visitor(node)

        if f is not None:
            return f(node, *args, **kwargs)

        return self.generic_visit(node, *args, **kwargs)

    def generic_visit(self, node: Node, *args: t.Any, **kwargs: t.Any) -> t.Any:
        """Called if no explicit visitor function exists for a node."""
        for node in node.iter_child_nodes():
            self.visit(node, *args, **kwargs)


class NodeTransformer(NodeVisitor):
    """Walks the abstract syntax tree and allows modifications of nodes.

    The `NodeTransformer` will walk the AST and use the return value of the
    visitor functions to replace or remove the old node.  If the return
    value of the visitor function is `None` the node will be removed
    from the previous location otherwise it's replaced with the return
    value.  The return value may be the original node in which case no
    replacement takes place.
    """

    def generic_visit(self, node: Node, *args: t.Any, **kwargs: t.Any) -> Node:
        for field, old_value in node.iter_fields():
            if isinstance(old_value, list):
                new_values = []
                for value in old_value:
                    if isinstance(value, Node):
                        value = self.visit(value, *args, **kwargs)
                        if value is None:
                            continue
                        elif not isinstance(value, Node):
                            new_values.extend(value)
                            continue
                    new_values.append(value)
                old_value[:] = new_values
            elif isinstance(old_value, Node):
                new_node = self.visit(old_value, *args, **kwargs)
                if new_node is None:
                    delattr(node, field)
                else:
                    setattr(node, field, new_node)
        return node

    def visit_list(self, node: Node, *args: t.Any, **kwargs: t.Any) -> t.List[Node]:
        """As transformers may return lists in some places this method
        can be used to enforce a list as return value.
        """
        rv = self.visit(node, *args, **kwargs)

        if not isinstance(rv, list):
            return [rv]

        return rv

SILENT KILLER Tool