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