Cutelee
6.1.0
templates
defaulttags
load.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 "load.h"
22
23
#include "../lib/exception.h"
24
#include "parser.h"
25
26
LoadNodeFactory::LoadNodeFactory() {}
27
28
Node
*
LoadNodeFactory::getNode
(
const
QString
&tagContent,
Parser
*p)
const
29
{
30
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
31
auto
expr = tagContent.split(QLatin1Char(
' '
), QString::SkipEmptyParts);
32
#else
33
auto
expr = tagContent.split(QLatin1Char(
' '
), Qt::SkipEmptyParts);
34
#endif
35
36
if
(expr.size() <= 1) {
37
throw
Cutelee::Exception
(
38
TagSyntaxError,
39
QStringLiteral(
"%1 expects at least one argument"
).arg(expr.first()));
40
}
41
42
expr.takeAt(0);
43
44
for
(
auto
&i : expr) {
45
p->loadLib(i);
46
}
47
48
return
new
LoadNode
(p);
49
}
50
51
LoadNode::LoadNode(QObject *parent) :
Node
(parent) {}
52
53
void
LoadNode::render
(
OutputStream
*stream,
Context
*c)
const
54
{
55
Q_UNUSED(stream)
56
Q_UNUSED(c)
57
}
Cutelee::Context
The Context class holds the context to render a Template with.
Definition:
context.h:119
Cutelee::Exception
An exception for use when implementing template tags.
Definition:
exception.h:85
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::Parser
The Parser class processes a string template into a tree of nodes.
Definition:
parser.h:49
LoadNodeFactory::getNode
Node * getNode(const QString &tagContent, Parser *p) const override
Definition:
load.cpp:28
LoadNode
Definition:
load.h:37
LoadNode::render
void render(OutputStream *stream, Context *c) const override
Definition:
load.cpp:53
QString
Definition:
operatorcasttests.cpp:24
Generated by
1.9.1