$61 GRAYBYTE WORDPRESS FILE MANAGER $67

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/python37/lib/python3.7/site-packages/jinja2/

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

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
18 Apr 2024 12.35 AM
root / 996
0755
__pycache__
--
31 Aug 2024 6.49 AM
root / 996
0755
__init__.py
2.153 KB
10 Nov 2021 3.25 AM
root / 996
0644
_identifier.py
1.733 KB
18 Feb 2020 12.14 AM
root / 996
0644
async_utils.py
1.901 KB
10 Nov 2021 12.17 AM
root / 996
0644
bccache.py
12.373 KB
5 Oct 2021 3.41 AM
root / 996
0644
compiler.py
70.517 KB
9 Nov 2021 11.37 PM
root / 996
0644
constants.py
1.399 KB
6 Apr 2021 12.47 AM
root / 996
0644
debug.py
8.295 KB
10 Nov 2021 12.17 AM
root / 996
0644
defaults.py
1.237 KB
10 May 2021 8.52 PM
root / 996
0644
environment.py
59.554 KB
10 Nov 2021 1.10 AM
root / 996
0644
exceptions.py
4.952 KB
10 May 2021 8.52 PM
root / 996
0644
ext.py
31.369 KB
14 May 2021 8.01 AM
root / 996
0644
filters.py
51.376 KB
5 Oct 2021 3.41 AM
root / 996
0644
idtracking.py
10.47 KB
10 Aug 2021 8.34 PM
root / 996
0644
lexer.py
29.229 KB
5 Oct 2021 3.41 AM
root / 996
0644
loaders.py
22.221 KB
10 Nov 2021 3.21 AM
root / 996
0644
meta.py
4.293 KB
10 May 2021 8.52 PM
root / 996
0644
nativetypes.py
3.876 KB
10 Nov 2021 12.17 AM
root / 996
0644
nodes.py
33.74 KB
10 Nov 2021 12.18 AM
root / 996
0644
optimizer.py
1.611 KB
10 May 2021 8.52 PM
root / 996
0644
parser.py
38.835 KB
14 May 2021 8.01 AM
root / 996
0644
py.typed
0 KB
10 May 2021 8.52 PM
root / 996
0644
runtime.py
34.232 KB
10 Aug 2021 8.34 PM
root / 996
0644
sandbox.py
14.258 KB
10 May 2021 8.52 PM
root / 996
0644
tests.py
5.767 KB
11 Apr 2021 12.20 AM
root / 996
0644
utils.py
26.339 KB
5 Oct 2021 3.41 AM
root / 996
0644
visitor.py
3.488 KB
10 May 2021 8.52 PM
root / 996
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF