WimaPlanData.cc 3.48 KB
Newer Older
1 2
#include "WimaPlanData.h"

3
WimaPlanData::WimaPlanData(QObject *parent) : QObject(parent) {}
4 5

WimaPlanData::WimaPlanData(const WimaPlanData &other, QObject *parent)
6 7
    : QObject(parent) {
  *this = other;
8 9 10 11 12 13 14 15
}

/*!
 * \fn WimaPlanData &WimaPlanData::operator=(const WimaPlanData &other)
 *
 * Copies the data area list of \a other to the calling \c WimaPlanData object.
 * Returns a reference to the calling \c WimaPlanData object.
 */
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
WimaPlanData &WimaPlanData::operator=(const WimaPlanData &other) {
  // copy wima areas
  QList<const WimaAreaData *> areaList = other.areaList();
  _areaList.clear();
  for (int i = 0; i < areaList.size(); i++) {
    const WimaAreaData *areaData = areaList[i];
    // determine area type and append
    if (areaData->type() == WimaJoinedAreaData::typeString) {
      this->append(*qobject_cast<const WimaJoinedAreaData *>(areaData));
    } else if (areaData->type() == WimaServiceAreaData::typeString) {
      this->append(*qobject_cast<const WimaServiceAreaData *>(areaData));
    } else if (areaData->type() == WimaMeasurementAreaData::typeString) {
      this->append(*qobject_cast<const WimaMeasurementAreaData *>(areaData));
    } else if (areaData->type() == WimaCorridorData::typeString) {
      this->append(*qobject_cast<const WimaCorridorData *>(areaData));
31
    }
32
  }
33

34
  return *this;
35 36 37 38 39 40 41
}

/*!
 * \fn void WimaPlanData::append(const WimaAreaData &areaData)
 *
 * Adds a WimaAreaData item.
 */
42 43
void WimaPlanData::append(const WimaJoinedAreaData &areaData) {
  _joinedArea = areaData;
44

45 46 47
  if (!_areaList.contains(&_joinedArea)) {
    _areaList.append(&_joinedArea);
  }
48 49 50 51 52 53 54
}

/*!
 * \fn void WimaPlanData::append(const WimaServiceAreaData &areaData)
 *
 * Adds a WimaServiceAreaData item.
 */
55 56
void WimaPlanData::append(const WimaServiceAreaData &areaData) {
  _serviceArea = areaData;
57

58 59 60
  if (!_areaList.contains(&_serviceArea)) {
    _areaList.append(&_serviceArea);
  }
61 62 63 64 65 66 67
}

/*!
 * \fn void WimaPlanData::append(const WimaServiceAreaData &areaData)
 *
 * Adds a WimaCorridorData item.
 */
68 69
void WimaPlanData::append(const WimaCorridorData &areaData) {
  _corridor = areaData;
70

71 72 73
  if (!_areaList.contains(&_corridor)) {
    _areaList.append(&_corridor);
  }
74 75 76 77 78 79 80
}

/*!
 * \fn void WimaPlanData::append(const WimaServiceAreaData &areaData)
 *
 * Adds a WimaMeasurementAreaData item.
 */
81 82
void WimaPlanData::append(const WimaMeasurementAreaData &areaData) {
  _measurementArea = areaData;
83

84 85 86
  if (!_areaList.contains(&_measurementArea)) {
    _areaList.append(&_measurementArea);
  }
87 88 89 90 91 92 93
}

/*!
 * \fn void WimaPlanData::append(const WimaServiceAreaData &areaData)
 *
 * Clears all stored objects
 */
94
void WimaPlanData::clear() { _areaList.clear(); }
95

96 97
const QList<const WimaAreaData *> &WimaPlanData::areaList() const {
  return _areaList;
98 99
}

100 101 102 103 104
bool WimaPlanData::operator==(const WimaPlanData &other) const {
  return this->_joinedArea == other._joinedArea &&
         this->_measurementArea == other._measurementArea &&
         this->_corridor == other._corridor &&
         this->_serviceArea == other._serviceArea;
105
}
106 107
bool WimaPlanData::operator!=(const WimaPlanData &other) const {
  return !(*this == other);
108 109
}

110 111 112 113 114 115
/*!
 * \class WimaPlanData
 * \brief Class storing data generated by the \c WimaPlaner class.
 *
 * This class is designed to store data generated by the \c WimaPlaner class and
 * meant for data exchange between the \c WimaController and the \c WimaPlanner.
116 117
 * It stores a QList of \c WimaAreaData objects, called area data list,
 * containing the data of serveral \c WimaAreas generated by the \c WimaPlaner.
118 119 120
 *
 * \sa QList
 */