GeopsyCore/SignalGroup.h
Go to the documentation of this file.
00001 /***************************************************************************
00002 **
00003 **  This file is part of GeopsyCore.
00004 **
00005 **  This library is free software; you can redistribute it and/or
00006 **  modify it under the terms of the GNU Lesser General Public
00007 **  License as published by the Free Software Foundation; either
00008 **  version 2.1 of the License, or (at your option) any later version.
00009 **
00010 **  This file is distributed in the hope that it will be useful, but WITHOUT
00011 **  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00012 **  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
00013 **  License for more details.
00014 **
00015 **  You should have received a copy of the GNU Lesser General Public
00016 **  License along with this library; if not, write to the Free Software
00017 **  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
00018 **
00019 **  See http://www.geopsy.org for more information.
00020 **
00021 **  Created : 2006-03-20
00022 **  Authors :
00023 **    Marc Wathelet
00024 **    Marc Wathelet (LGIT, Grenoble, France)
00025 **
00026 ***************************************************************************/
00027 
00028 #ifndef SIGNALGROUP_H
00029 #define SIGNALGROUP_H
00030 
00031 #include <QGpCoreTools.h>
00032 
00033 #include "AbstractSignalGroup.h"
00034 #include "SubSignalPool.h"
00035 #include "GeopsyCoreDLLExport.h"
00036 
00037 namespace GeopsyCore {
00038 
00039   class GEOPSYCORE_EXPORT SignalGroup: public AbstractSignalGroup
00040   {
00041     TRANSLATIONS("SignalGroup")
00042   public:
00043     SignalGroup(AbstractSignalGroup * parent=0);
00044     virtual ~SignalGroup();
00045 
00046     virtual const QString& xml_tagName() const {return xmlSignalGroupTag;}
00047     static const QString xmlSignalGroupTag;
00048     virtual bool xml_inherits(const QString& tagName) const;
00049 
00050     virtual void setName(const QString &n);
00051     virtual int signalCount() const {return _signals.count();}
00052     virtual bool hasOwnSignal() const {return true;}
00053     virtual bool directlyContains(const Signal * sig) const {return _signals.contains(sig);}
00054     virtual SubSignalPool subPool() const {return _signals;}
00055 
00056     virtual bool convertIds(const QHash<int, Signal *>& ids);
00057     bool hasIds() const {return _ids;}
00058 
00059     virtual void removeSignal(Signal * sig);
00060     virtual void setSignals(const SubSignalPool& subPool);
00061     virtual void addSignals(const SubSignalPool& subPool);
00062 
00063     void openV12(int dbVersion, const QDir& dbPath);
00064   protected:
00065     virtual void xml_writeProperties(XML_WRITEPROPERTIES_ARGS) const;
00066     virtual bool xml_setProperty(XML_SETPROPERTY_ARGS);
00067     virtual XMLMember xml_member(XML_MEMBER_ARGS);
00068   private:
00069     SubSignalPool _signals;
00070     QVector<int> * _ids;
00071   };
00072 
00073 } // namespace GeopsyCore
00074 
00075 #endif // SIGNALGROUP_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines