File: //usr/local/CyberCP/lib/python3.10/site-packages/django/template/__pycache__/base.cpython-310.pyc
o
    �h��  �                   @   s<  d Z ddlZddlZddlZddlmZ ddlmZ ddlm	Z	 ddl
mZmZ ddl
mZ ddlmZmZmZ dd	lmZmZmZ dd
lmZ ddlmZmZ dd
lmZ dZdZdZ dZ!dZ"dZ#dZ$dZ%dZ&dZ'dZ(dZ)e�*d�Z+e�,d�Z-G dd� de�Z.G dd� de/�Z0G d d!� d!�Z1G d"d#� d#�Z2d$d%� Z3G d&d'� d'�Z4G d(d)� d)�Z5G d*d+� d+e5�Z6G d,d-� d-�Z7d.d/d0e�d1�e�d2�d3� Z8e8�9d4d5�Z8d6e8d7d8e�e�e�e�d9� Z:ee:ej;�Z<G d:d;� d;�Z=G d<d=� d=�Z>G d>d?� d?�Z?G d@dA� dAe@�ZAG dBdC� dCe?�ZBdDdE� ZCG dFdG� dGe?�ZDedH�ZEdLdJdK�ZFdS )Ma�  
This is the Django template system.
How it works:
The Lexer.tokenize() method converts a template string (i.e., a string
containing markup with custom template tags) to tokens, which can be either
plain text (TokenType.TEXT), variables (TokenType.VAR), or block statements
(TokenType.BLOCK).
The Parser() class takes a list of tokens in its constructor, and its parse()
method returns a compiled template -- which is, under the hood, a list of
Node objects.
Each Node is responsible for creating some sort of output -- e.g. simple text
(TextNode), variable values in a given context (VariableNode), results of basic
logic (IfNode), results of looping (ForNode), or anything else. The core Node
types are TextNode, VariableNode, IfNode and ForNode, but plugin modules can
define their own custom node types.
Each Node has a render() method, which takes a Context and returns a string of
the rendered node. For example, the render() method of a Variable Node returns
the variable's value as a string. The render() method of a ForNode returns the
rendered output of whatever was inside the loop, recursively.
The Template class is a convenient wrapper that takes care of template
compilation and rendering.
Usage:
The only thing you should ever use directly in this file is the Template class.
Create a compiled template object with a template_string, then call render()
with a context. In the compilation stage, the TemplateSyntaxError exception
will be raised if the template doesn't have proper syntax.
Sample code:
>>> from django import template
>>> s = '<html>{% if test %}<h1>{{ varvalue }}</h1>{% endif %}</html>'
>>> t = template.Template(s)
(t is now a compiled template, and its render() method can be called multiple
times with multiple contexts)
>>> c = template.Context({'test':True, 'varvalue': 'Hello'})
>>> t.render(c)
'<html><h1>Hello</h1></html>'
>>> c = template.Context({'test':False, 'varvalue': 'Hello'})
>>> t.render(c)
'<html></html>'
�    N)�Enum)�BaseContext)�localize)�conditional_escape�escape)�_lazy_re_compile)�SafeData�
SafeString�	mark_safe)�
get_text_list�smart_split�unescape_string_literal)�template_localtime)�gettext_lazy�
pgettext_lazy�   )�TemplateSyntaxError�|�:�.z{%z%}z{{z}}z{#z#}�{�}z<unknown source>z({%.*?%}|{{.*?}}|{#.*?#})zdjango.templatec                   @   s   e Zd ZdZdZdZdZdS )�	TokenTyper   r   �   �   N)�__name__�
__module__�__qualname__�TEXT�VAR�BLOCK�COMMENT� r"