SILENT KILLERPanel

Current Path: > > opt > alt > python37 > lib > python3.7 > 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/alt/python37/lib/python3.7/site-packages/jinja2/

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 2205 bytes November 09 2021 20:25:25.
_identifier.py File 1775 bytes February 17 2020 17:14:56.
async_utils.py File 1947 bytes November 09 2021 17:17:58.
bccache.py File 12670 bytes October 04 2021 20:41:58.
compiler.py File 72209 bytes November 09 2021 16:37:43.
constants.py File 1433 bytes April 05 2021 17:47:37.
debug.py File 8494 bytes November 09 2021 17:17:58.
defaults.py File 1267 bytes May 10 2021 13:52:40.
environment.py File 60983 bytes November 09 2021 18:10:36.
exceptions.py File 5071 bytes May 10 2021 13:52:40.
ext.py File 32122 bytes May 14 2021 01:01:18.
filters.py File 52609 bytes October 04 2021 20:41:58.
idtracking.py File 10721 bytes August 10 2021 13:34:22.
lexer.py File 29930 bytes October 04 2021 20:41:58.
loaders.py File 22754 bytes November 09 2021 20:21:27.
meta.py File 4396 bytes May 10 2021 13:52:40.
nativetypes.py File 3969 bytes November 09 2021 17:17:58.
nodes.py File 34550 bytes November 09 2021 17:18:01.
optimizer.py File 1650 bytes May 10 2021 13:52:40.
parser.py File 39767 bytes May 14 2021 01:01:13.
py.typed File 0 bytes May 10 2021 13:52:40.
runtime.py File 35054 bytes August 10 2021 13:34:22.
sandbox.py File 14600 bytes May 10 2021 13:52:40.
tests.py File 5905 bytes April 10 2021 17:20:38.
utils.py File 26971 bytes October 04 2021 20:41:58.
visitor.py File 3572 bytes May 10 2021 13:52:40.

Reading File: //opt/alt/python37/lib/python3.7/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