Jinja2 расширение компиляции после включает
В Jinja2, возможно ли иметь Node
из рендера АСТ в конце концов include
заявления завершены?
Это ключевой элемент решения большой головоломки.
Пример кода:
x.py
from jinja2 import nodes, Environment, FileSystemLoader
from jinja2.ext import Extension
class XExtension(Extension):
tags = set(['x', 'get_x'])
def __init__(self, environment):
super(XExtension, self).__init__(environment)
environment.extend(
x = 0,
)
def parse(self, parser):
tag = parser.stream.next()
return getattr(self, "_%s" % str(tag))(parser, tag)
def _get_x(self, parser, tag):
""" Return the output """
return nodes.Const(self.environment.x)
def _x(self, parser, tag):
""" Add an x """
self.environment.x += 1
return nodes.Const('<!-- Adding an X -->')
env = Environment(
loader = FileSystemLoader('.'),
extensions = [XExtension],
)
template = env.get_template('x.html')
print template.render()
x.html
Xx {% x %} Xx {% x %}
{% include "y.html" %}
Xs xes: {% get_x %}
y.html
Yx {% x %}
Ys xes: {% get_x %}
Выход
Xx <!-- Adding an X --> Xx <!-- Adding an X -->
Yx <!-- Adding an X -->
Ys xes:3
Xs xes 2
Как может быть возможно иметь Xs xes
посчитать X в y.html
Какое поведение я желаю и ожидаю?
Другими словами, есть ли способ отложить анализ или выравнивание текста, возвращенного из _get_x()
в x.html
?
Большое спасибо за чтение.
С уважением,
Брайан
1 ответ
Jinja2 выполняет потоковую передачу данных шаблона. Шаблон является оцененной инструкцией для инструкции в поток строк меньшего размера, который объединяется в фактическую строку Юникода render()
метод. Однако вы также можете получить поток, позвонив в generate()
вместо render()
,
С некоторой внутриполосной сигнализацией и постобработкой потока можно, вероятно, реализовать что-то подобное, но это противоречит тому, как был разработан Jinja2, поэтому он может ужасно сломаться и полностью не поддерживается.