File indexing completed on 2024-04-28 03:40:43
0001 /************************************************************************************* 0002 * Copyright (C) 2009 by Aleix Pol <aleixpol@kde.org> * 0003 * * 0004 * This program is free software; you can redistribute it and/or * 0005 * modify it under the terms of the GNU General Public License * 0006 * as published by the Free Software Foundation; either version 2 * 0007 * of the License, or (at your option) any later version. * 0008 * * 0009 * This program is distributed in the hope that it will be useful, * 0010 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 0011 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 0012 * GNU General Public License for more details. * 0013 * * 0014 * You should have received a copy of the GNU General Public License * 0015 * along with this program; if not, write to the Free Software * 0016 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * 0017 *************************************************************************************/ 0018 0019 #ifndef LIST_H 0020 #define LIST_H 0021 0022 #include "object.h" 0023 #include "analitzaexport.h" 0024 0025 namespace Analitza 0026 { 0027 0028 /** 0029 * \class List 0030 * 0031 * \ingroup AnalitzaModule 0032 */ 0033 0034 class ANALITZA_EXPORT List : public Object 0035 { 0036 public: 0037 typedef QList<Object*>::iterator iterator; 0038 typedef QList<Object*>::const_iterator const_iterator; 0039 0040 List(const List& v); 0041 List(); 0042 ~List() override; 0043 0044 void appendBranch(Object* ); 0045 int size() const { return m_elements.size(); } 0046 0047 iterator erase(const iterator& it) { return m_elements.erase(it); } 0048 0049 iterator begin() { return m_elements.begin(); } 0050 iterator end() { return m_elements.end(); } 0051 const_iterator constBegin() const { return m_elements.constBegin(); } 0052 const_iterator constEnd() const { return m_elements.constEnd(); } 0053 0054 Object* at(int i) const { return m_elements.at(i); } 0055 void setAt(int i, Object* o) { m_elements[i]=o; } 0056 QList<Object*> values() const { return m_elements; } 0057 0058 virtual QVariant accept(AbstractExpressionVisitor* e) const override; 0059 virtual bool isZero() const override; 0060 0061 virtual bool matches(const Object* pattern, QMap< QString, const Object* >* found) const override; 0062 virtual List* copy() const override; 0063 bool operator==(const List& v) const; 0064 bool isEmpty() const { return m_elements.isEmpty(); } 0065 0066 private: 0067 QList<Object*> m_elements; 0068 }; 0069 0070 } 0071 #endif // VECTOR_H