diff options
Diffstat (limited to 'src/resources/db')
-rw-r--r-- | src/resources/db/itemdb.cpp | 9 | ||||
-rw-r--r-- | src/resources/db/itemdb.h | 7 | ||||
-rw-r--r-- | src/resources/db/statdb.cpp | 97 | ||||
-rw-r--r-- | src/resources/db/statdb.h | 47 |
4 files changed, 146 insertions, 14 deletions
diff --git a/src/resources/db/itemdb.cpp b/src/resources/db/itemdb.cpp index 0421d7d88..323412e08 100644 --- a/src/resources/db/itemdb.cpp +++ b/src/resources/db/itemdb.cpp @@ -37,6 +37,7 @@ #include "resources/db/itemdbstat.h" #include "resources/db/itemfielddb.h" +#include "resources/db/statdb.h" #include "net/serverfeatures.h" @@ -77,13 +78,6 @@ static void loadOrderSprite(ItemInfo *const itemInfo, static int parseSpriteName(const std::string &name); static int parseDirectionName(const std::string &name); -static std::vector<ItemDB::Stat> extraStats; - -void ItemDB::setStatsList(const std::vector<ItemDB::Stat> &stats) -{ - extraStats = stats; -} - static ItemDbTypeT itemTypeFromString(const std::string &name) { const size_t sz = sizeof(itemTypeMap) / sizeof(itemTypeMap[0]); @@ -519,6 +513,7 @@ void ItemDB::loadXmlFile(const std::string &fileName, std::string effect; readFields(effect, node, requiredFields); readFields(effect, node, addFields); + const std::vector<Stat> &extraStats = StatDb::getExtraStats(); FOR_EACH (std::vector<Stat>::const_iterator, it, extraStats) { std::string value = XML::getProperty( diff --git a/src/resources/db/itemdb.h b/src/resources/db/itemdb.h index cc94145ab..3a992b90c 100644 --- a/src/resources/db/itemdb.h +++ b/src/resources/db/itemdb.h @@ -33,11 +33,6 @@ class ItemInfo; -namespace ItemDB -{ - struct Stat; -} - /** * Item information database. */ @@ -77,8 +72,6 @@ namespace ItemDB #endif int getTagId(const std::string &tagName) A_WARN_UNUSED; - - void setStatsList(const std::vector<Stat> &stats); } // namespace ItemDB #endif // RESOURCES_DB_ITEMDB_H diff --git a/src/resources/db/statdb.cpp b/src/resources/db/statdb.cpp new file mode 100644 index 000000000..2fc2d592c --- /dev/null +++ b/src/resources/db/statdb.cpp @@ -0,0 +1,97 @@ +/* + * The ManaPlus Client + * Copyright (C) 2016 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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 2 of the License, or + * 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 <http://www.gnu.org/licenses/>. + */ + +#include "resources/db/statdb.h" + +#include "configuration.h" + +#include "utils/checkutils.h" +#include "utils/dtor.h" + +#include "resources/beingcommon.h" + +#include "resources/item/itemfieldtype.h" + +#include "debug.h" + +namespace +{ + bool mLoaded = false; + static std::vector<ItemDB::Stat> extraStats; +} // namespace + +void StatDb::setStatsList(const std::vector<ItemDB::Stat> &stats) +{ + extraStats = stats; +} + +const std::vector<ItemDB::Stat> &StatDb::getExtraStats() +{ + return extraStats; +} + +void StatDb::load() +{ + if (mLoaded) + unload(); + + logger->log1("Initializing stat database..."); + + loadXmlFile(paths.getStringValue("statFile"), SkipError_false); + loadXmlFile(paths.getStringValue("statPatchFile"), SkipError_true); + loadXmlDir("statPatchDir", loadXmlFile); + mLoaded = true; +} + +void StatDb::loadXmlFile(const std::string &fileName, + const SkipError skipError) +{ + XML::Document doc(fileName, + UseResman_true, + skipError); + const XmlNodePtrConst rootNode = doc.rootNode(); + + if (!rootNode || !xmlNameEqual(rootNode, "stats")) + { + logger->log("StatDb: Error while loading %s!", + fileName.c_str()); + return; + } + + for_each_xml_child_node(node, rootNode) + { + if (xmlNameEqual(node, "include")) + { + const std::string name = XML::getProperty(node, "name", ""); + if (!name.empty()) + loadXmlFile(name, skipError); + continue; + } + + + } +} + +void StatDb::unload() +{ + logger->log1("Unloading stat database..."); + + mLoaded = false; +} diff --git a/src/resources/db/statdb.h b/src/resources/db/statdb.h new file mode 100644 index 000000000..860235439 --- /dev/null +++ b/src/resources/db/statdb.h @@ -0,0 +1,47 @@ +/* + * The ManaPlus Client + * Copyright (C) 2016 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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 2 of the License, or + * 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 <http://www.gnu.org/licenses/>. + */ + +#ifndef RESOURCES_DB_STATDB_H +#define RESOURCES_DB_STATDB_H + +#include "enums/simpletypes/skiperror.h" + +#include "resources/db/itemdbstat.h" + +#include <string> +#include <vector> + +#include "localconsts.h" + +namespace StatDb +{ + void load(); + + void unload(); + + void loadXmlFile(const std::string &fileName, + const SkipError skipError); + + void setStatsList(const std::vector<ItemDB::Stat> &stats); + + const std::vector<ItemDB::Stat> &getExtraStats(); +} // namespace StatDb + +#endif // RESOURCES_DB_STATDB_H |