/* * Copyright 2007-2009 Ben Boeckel * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ // Header include #include "MapWildList.h" // Sigmod includes #include "Macros.h" #include "Map.h" #include "MapWildListEncounter.h" // Qt includes #include using namespace Sigmod; MapWildList::MapWildList(const MapWildList& wildList) : Object(wildList.parent(), wildList.id()), m_encounters(this) { *this = wildList; } MapWildList::MapWildList(const Map* parent, const int id) : Object(parent, id), m_name(""), m_encounters(this) { } MapWildList::MapWildList(const MapWildList& wildList, const Map* parent, const int id) : Object(parent, id), m_encounters(this) { *this = wildList; } MapWildList::MapWildList(const QDomElement& xml, const Map* parent, const int id) : Object(parent, id), m_encounters(this) { initXmlImport(xml, id); load(xml); } void MapWildList::validate() { testBegin(); if (m_name.isEmpty()) emit(error("Name is empty")); if (!m_encounters.count()) emit(error("There are no encounters")); QSet idChecker; m_encounters.validate(); for (int i = 0; i < m_encounters.count(); ++i) { MapWildListEncounter* encounter = m_encounters.at(i); testSubclassValue(encounter, encounter->id(), "ID value", &idChecker); } testEnd(); } void MapWildList::load(const QDomElement& xml) { clear(); loadValue(xml.firstChildElement("name"), &m_name); m_encounters.importXml(xml, "MapWildListEncounter"); } QDomElement MapWildList::save() const { QDomElement xml = initXmlExport(); xml.appendChild(saveValue("name", m_name)); m_encounters.exportXml(&xml); return xml; } SETTER(MapWildList, QString&, Name, name) GETTER(MapWildList, QString, name) const MapWildList::Encounters& MapWildList::encounters() const { return m_encounters; } MapWildList::Encounters& MapWildList::encounters() { return m_encounters; } CHECK(MapWildList, QString&, name) MapWildList& MapWildList::operator=(const MapWildList& rhs) { if (this == &rhs) return *this; clear(); m_name = rhs.m_name; m_encounters = rhs.m_encounters; return *this; } void MapWildList::clear() { m_encounters.clear(); Object::clear(); }