summaryrefslogblamecommitdiff
path: root/src/resources/itemmanager.cpp
blob: 63c0b0365f011b2c7258d67ddf9da13163d30013 (plain) (tree)





















                                                                             
 

                        

                        
                     
                            
 

                   

                          






                                                   
                          
 

                                      
 




                                                             
                                                                 
     
 

                                               
 
             
     
                                                                                      
     
 



                                                                               




































                                                                       
         
                                                                         
         
                       
         
                                                                           
         
 




                                                                                 
                       


                                                                               
           









                                                                                       
                        


                                                                                
           














                                                                                  
     
 
                    



                           
                                                                             
     
                         
     
                       
 
                    

 

                                
 

                                             
                                                          
 
/*
 *  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 "itemmanager.h"

#include <libxml/tree.h>

#include "iteminfo.h"
#include "resourcemanager.h"

#include "../log.h"

#include "../utils/dtor.h"

#define READ_PROP(node, prop, name, target, cast) \
        prop = xmlGetProp(node, BAD_CAST name); \
        if (prop) { \
            target = cast((const char*)prop); \
            xmlFree(prop); \
        }

ItemManager::ItemManager()
{
    mUnknown = new ItemInfo();
    mUnknown->setName("Unknown item");

    ResourceManager *resman = ResourceManager::getInstance();
    int size;
    char *data = (char*)resman->loadFile("items.xml", size);

    if (!data) {
        logger->error("Item Manager: Could not find items.xml!");
    }

    xmlDocPtr doc = xmlParseMemory(data, size);
    free(data);

    if (!doc)
    {
        logger->error("Item Manager: Error while parsing item database (items.xml)!");
    }

    xmlNodePtr node = xmlDocGetRootElement(doc);
    if (!node || !xmlStrEqual(node->name, BAD_CAST "items"))
    {
        logger->error("Item Manager: items.xml is not a valid database file!");
    }

    for (node = node->xmlChildrenNode; node != NULL; node = node->next)
    {
        int id = 0, image = 0, art = 0, type = 0, weight = 0, slot = 0;
        std::string name = "", description = "", effect = "";

        if (!xmlStrEqual(node->name, BAD_CAST "item")) {
            continue;
        }

        xmlChar *prop = NULL;
        READ_PROP(node, prop, "id", id, atoi);
        READ_PROP(node, prop, "image", image, atoi);
        READ_PROP(node, prop, "art", art, atoi);
        READ_PROP(node, prop, "name", name, );
        READ_PROP(node, prop, "description", description, );
        READ_PROP(node, prop, "effect", effect, );
        READ_PROP(node, prop, "type", type, atoi);
        READ_PROP(node, prop, "weight", weight, atoi);
        READ_PROP(node, prop, "slot", slot, atoi);

        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("Item Manager: An item has no ID in items.xml!");
        }
        if (name == "")
        {
            logger->log("Item Manager: An item has no name in items.xml!");
        }

        if (image == 0)
        {
            logger->log("Item Manager: Missing image parameter for item: %i. %s",
                    id, name.c_str());
        }
        /*if (art == 0)
        {
            logger->log("Item Manager: Missing art parameter for item: %i. %s",
                    id, name.c_str());
        }*/
        if (description == "")
        {
            logger->log("Item Manager: Missing description parameter for item: %i. %s",
                    id, name.c_str());
        }
        if (effect == "")
        {
            logger->log("Item Manager: Missing effect parameter for item: %i. %s",
                    id, name.c_str());
        }
        /*if (type == 0)
        {
            logger->log("Item Manager: Missing type parameter for item: %i. %s",
                    id, name.c_str());
        }*/
        if (weight == 0)
        {
            logger->log("Item Manager: Missing weight parameter for item: %i. %s",
                    id, name.c_str());
        }
        if (slot == 0)
        {
            logger->log("Item Manager: Missing image parameter for item: %i. %s",
                    id, name.c_str());
        }

        /*logger->log("Item: %i %i %i %s %s %i %i %i", id,
          getImage(id), getArt(id), getName(id).c_str(),
          getDescription(id).c_str(), getType(id), getWeight(id),
          getSlot(id));*/
    }

    xmlFreeDoc(doc);
}

ItemManager::~ItemManager()
{
    for (ItemInfoIterator i = mItemInfos.begin(); i != mItemInfos.end(); i++)
    {
        delete i->second;
    }
    mItemInfos.clear();

    delete mUnknown;
}

ItemInfo*
ItemManager::getItemInfo(int id)
{
    ItemInfoIterator i = mItemInfos.find(id);

    return (i != mItemInfos.end()) ? i->second : mUnknown;
}