Cutelee 6.1.0
filtertag.cpp
1/*
2 This file is part of the Cutelee template system.
3
4 Copyright (c) 2009,2010 Stephen Kelly <steveire@gmail.com>
5
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either version
9 2.1 of the Licence, or (at your option) any later version.
10
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
15
16 You should have received a copy of the GNU Lesser General Public
17 License along with this library. If not, see <http://www.gnu.org/licenses/>.
18
19*/
20
21#include "filtertag.h"
22
23#include "../lib/exception.h"
24#include "filterexpression.h"
25#include "parser.h"
26#include "util.h"
27
28FilterNodeFactory::FilterNodeFactory() {}
29
31 Cutelee::Parser *p) const
32{
33#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
34 auto expr = tagContent.split(QLatin1Char(' '), QString::SkipEmptyParts);
35#else
36 auto expr = tagContent.split(QLatin1Char(' '), Qt::SkipEmptyParts);
37#endif
38
39 expr.removeFirst();
40
41 auto expression = expr.join(QChar::fromLatin1(' '));
42 FilterExpression fe(QStringLiteral("var|%1").arg(expression), p);
43
44 auto filters = fe.filters();
45 if (filters.contains(QStringLiteral("safe"))
46 || filters.contains(QStringLiteral("escape"))) {
48 TagSyntaxError, QStringLiteral("Use the \"autoescape\" tag instead."));
49 }
50
51 auto n = new FilterNode(fe, p);
52
53 auto filterNodes = p->parse(n, QStringLiteral("endfilter"));
54 p->removeNextToken();
55
56 n->setNodeList(filterNodes);
57 return n;
58}
59
60FilterNode::FilterNode(const FilterExpression &fe, QObject *parent)
61 : Node(parent), m_fe(fe)
62{
63}
64
65void FilterNode::setNodeList(const NodeList &filterList)
66{
67 m_filterList = filterList;
68}
69
71{
72 QString output;
73 QTextStream textStream(&output);
74 auto temp = stream->clone(&textStream);
75 m_filterList.render(temp.get(), c);
76 c->push();
77 c->insert(QStringLiteral("var"), output);
78 m_fe.resolve(stream, c);
79 c->pop();
80}
The Context class holds the context to render a Template with.
Definition context.h:119
void insert(const QString &name, QObject *object)
Definition context.cpp:145
An exception for use when implementing template tags.
Definition exception.h:85
A FilterExpression object represents a filter expression in a template.
A list of Nodes with some convenience API for rendering them.
Definition node.h:148
Base class for all nodes.
Definition node.h:78
The OutputStream class is used to render templates to a QTextStream.
virtual std::shared_ptr< OutputStream > clone(QTextStream *stream) const
The Parser class processes a string template into a tree of nodes.
Definition parser.h:49
NodeList parse(Node *parent, const QStringList &stopAt={})
Definition parser.cpp:180
void removeNextToken()
Definition parser.cpp:297
Node * getNode(const QString &tagContent, Parser *p) const override
Definition filtertag.cpp:30
void render(OutputStream *stream, Context *c) const override
Definition filtertag.cpp:70
QChar fromLatin1(char c)
void removeFirst()
QStringList split(const QString &sep, SplitBehavior behavior, Qt::CaseSensitivity cs) const const
SkipEmptyParts
Utility functions used throughout Cutelee.