/*
* The Mana World
* Copyright 2004 The Mana World Development Team
*
* This file is part of The Mana World.
*
* The Mana World 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.
*
* The Mana World 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 The Mana World; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* $Id$
*/
#include "itemdb.h"
#include <libxml/tree.h>
#include "iteminfo.h"
#include "resourcemanager.h"
#include "../log.h"
#include "../utils/dtor.h"
#include "../utils/xml.h"
namespace
{
ItemDB::ItemInfos mItemInfos;
ItemInfo mUnknown;
bool mLoaded = false;
}
void ItemDB::load()
{
if (mLoaded)
return;
logger->log("Initializing item database...");
mUnknown.setName("Unknown item");
ResourceManager *resman = ResourceManager::getInstance();
int size;
char *data = (char*)resman->loadFile("items.xml", size);
if (!data) {
logger->error("ItemDB: Could not find items.xml!");
}
xmlDocPtr doc = xmlParseMemory(data, size);
free(data);
if (!doc)
{
logger->error("ItemDB: Error while parsing item database (items.xml)!");
}
xmlNodePtr rootNode = xmlDocGetRootElement(doc);
if (!rootNode || !xmlStrEqual(rootNode->name, BAD_CAST "items"))
{
logger->error("ItemDB: items.xml is not a valid database file!");
}
for_each_xml_child_node(node, rootNode)
{
if (!xmlStrEqual(node->name, BAD_CAST "item")) {
continue;
}
int id = XML::getProperty(node, "id", 0);
int art = XML::getProperty(node, "art", 0);
int type = XML::getProperty(node, "type", 0);
int weight = XML::getProperty(node, "weight", 0);
int slot = XML::getProperty(node, "slot", 0);
std::string name = XML::getProperty(node, "name", "");
std::string image = XML::getProperty(node, "image", "");
std::string description = XML::getProperty(node, "description", "");
std::string effect = XML::getProperty(node, "effect", "");
if (id && name != "")
{
ItemInfo *itemInfo = new ItemInfo();
itemInfo->setImage(image);
itemInfo->setArt(art);
itemInfo->setName(name);
itemInfo->setDescription(description);
itemInfo->setEffect(effect);
itemInfo->setType(type);
itemInfo->setWeight(weight);
itemInfo->setSlot(slot);
mItemInfos[id] = itemInfo;
}
if (id == 0)
{
logger->log("ItemDB: An item has no ID in items.xml!");
}
#define CHECK_PARAM(param, error_value) \
if (param == error_value) \
logger->log("ItemDB: Missing" #param " parameter for item %i! %s", \
id, name.c_str())
CHECK_PARAM(name, "");
CHECK_PARAM(image, "");
// CHECK_PARAM(art, 0);
// CHECK_PARAM(description, "");
// CHECK_PARAM(effect, "");
// CHECK_PARAM(type, 0);
CHECK_PARAM(weight, 0);
// CHECK_PARAM(slot, 0);
#undef CHECK_PARAM
}
xmlFreeDoc(doc);
mLoaded = true;
}
void ItemDB::unload()
{
for (ItemInfoIterator i = mItemInfos.begin(); i != mItemInfos.end(); i++)
{
delete i->second;
}
mItemInfos.clear();
mLoaded = false;
}
const ItemInfo&
ItemDB::get(int id)
{
ItemInfoIterator i = mItemInfos.find(id);
return (i != mItemInfos.end()) ? *(i->second) : mUnknown;
}