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/optimizer.py

"""The optimizer tries to constant fold expressions and modify the AST
in place so that it should be faster to evaluate.

Because the AST does not contain all the scoping information and the
compiler has to find that out, we cannot do all the optimizations we
want. For example, loop unrolling doesn't work because unrolled loops
would have a different scope. The solution would be a second syntax tree
that stored the scoping rules.
"""
import typing as t

from . import nodes
from .visitor import NodeTransformer

if t.TYPE_CHECKING:
    from .environment import Environment


def optimize(node: nodes.Node, environment: "Environment") -> nodes.Node:
    """The context hint can be used to perform an static optimization
    based on the context given."""
    optimizer = Optimizer(environment)
    return t.cast(nodes.Node, optimizer.visit(node))


class Optimizer(NodeTransformer):
    def __init__(self, environment: "t.Optional[Environment]") -> None:
        self.environment = environment

    def generic_visit(
        self, node: nodes.Node, *args: t.Any, **kwargs: t.Any
    ) -> nodes.Node:
        node = super().generic_visit(node, *args, **kwargs)

        # Do constant folding. Some other nodes besides Expr have
        # as_const, but folding them causes errors later on.
        if isinstance(node, nodes.Expr):
            try:
                return nodes.Const.from_untrusted(
                    node.as_const(args[0] if args else None),
                    lineno=node.lineno,
                    environment=self.environment,
                )
            except nodes.Impossible:
                pass

        return node

SILENT KILLER Tool