Cutelee
6.1.0
templates
defaulttags
spaceless.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 "spaceless.h"
22
23
#include <QtCore/QRegularExpression>
24
25
#include "parser.h"
26
#include "
util.h
"
27
28
SpacelessNodeFactory::SpacelessNodeFactory() {}
29
30
Node
*
SpacelessNodeFactory::getNode
(
const
QString
&tagContent,
Parser
*p)
const
31
{
32
Q_UNUSED(tagContent)
33
auto
n =
new
SpacelessNode
(p);
34
auto
list = p->
parse
(n, QStringLiteral(
"endspaceless"
));
35
n->setList(list);
36
p->
removeNextToken
();
37
return
n;
38
}
39
40
SpacelessNode::SpacelessNode(QObject *parent) :
Node
(parent) {}
41
42
void
SpacelessNode::setList(
const
NodeList
&nodeList) { m_nodeList = nodeList; }
43
44
QString
SpacelessNode::stripSpacesBetweenTags(
const
QString
&input)
45
{
46
auto
stripped = input;
47
48
static
const
QRegularExpression re(QStringLiteral(
">\\s+<"
));
49
stripped.replace(re, QStringLiteral(
"><"
));
50
return
stripped;
51
}
52
53
void
SpacelessNode::render
(
OutputStream
*stream,
Context
*c)
const
54
{
55
QString
output;
56
QTextStream textStream(&output);
57
auto
temp = stream->
clone
(&textStream);
58
m_nodeList.
render
(temp.get(), c);
59
(*stream) <<
markSafe
(stripSpacesBetweenTags(output.trimmed()));
60
}
Cutelee::Context
The Context class holds the context to render a Template with.
Definition
context.h:119
Cutelee::NodeList
A list of Nodes with some convenience API for rendering them.
Definition
node.h:148
Cutelee::NodeList::render
void render(OutputStream *stream, Context *c) const
Definition
node.cpp:177
Cutelee::Node
Base class for all nodes.
Definition
node.h:78
Cutelee::OutputStream
The OutputStream class is used to render templates to a QTextStream.
Definition
outputstream.h:81
Cutelee::OutputStream::clone
virtual std::shared_ptr< OutputStream > clone(QTextStream *stream) const
Definition
outputstream.cpp:71
Cutelee::Parser
The Parser class processes a string template into a tree of nodes.
Definition
parser.h:49
Cutelee::Parser::parse
NodeList parse(Node *parent, const QStringList &stopAt={})
Definition
parser.cpp:180
Cutelee::Parser::removeNextToken
void removeNextToken()
Definition
parser.cpp:297
QString
Definition
operatorcasttests.cpp:24
SpacelessNodeFactory::getNode
Node * getNode(const QString &tagContent, Parser *p) const override
Definition
spaceless.cpp:30
SpacelessNode
Definition
spaceless.h:38
SpacelessNode::render
void render(OutputStream *stream, Context *c) const override
Definition
spaceless.cpp:53
Cutelee::markSafe
Cutelee::SafeString markSafe(const Cutelee::SafeString &input)
Definition
util.cpp:90
util.h
Utility functions used throughout Cutelee.
Generated by
1.9.8