Make the Grantlee::Node::render method const.
[grantlee:grantlee.git] / templates / defaulttags / for.h
1 /*
2   This file is part of the Grantlee 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 #ifndef FORNODE_H
22 #define FORNODE_H
23
24 #include "node.h"
25
26 using namespace Grantlee;
27
28
29 class ForNodeFactory : public AbstractNodeFactory
30 {
31   Q_OBJECT
32 public:
33   ForNodeFactory();
34
35   Node* getNode( const QString &tagContent, Parser *p ) const;
36
37 };
38
39
40 class ForNode : public Node
41 {
42   Q_OBJECT
43 public:
44   enum Reversed {
45     IsNotReversed,
46     IsReversed
47   };
48
49   ForNode( QStringList loopVars, FilterExpression fe, int reversed, QObject *parent = 0 );
50
51   void setLoopList( NodeList loopNodeList );
52   void setEmptyList( NodeList emptyList );
53
54   void render( OutputStream *stream, Context *c ) const;
55
56 private:
57   static void insertLoopVariables( Context *c, int listSize, int i );
58   void iterateHash( OutputStream *stream, Context* c, QVariantHash varHash, bool unpack );
59   void renderLoop( OutputStream *stream, Context *c ) const;
60   void handleHashItem( OutputStream *stream, Context *c, QString key, QVariant value, int listSize, int i, bool unpack );
61
62   QStringList m_loopVars;
63   FilterExpression m_filterExpression;
64   NodeList m_loopNodeList;
65   NodeList m_emptyNodeList;
66   int m_isReversed;
67 };
68
69
70 #endif
71