summaryrefslogtreecommitdiffstats
path: root/src/game-server/statusmanager.cpp
blob: 66c2642a737314fab0bb7b598e7e314c3ad3b7d3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/*
 *  The Mana Server
 *  Copyright (C) 2004-2010  The Mana World Development Team
 *
 *  This file is part of The Mana Server.
 *
 *  The Mana Server 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 Server 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 Server.  If not, see <http://www.gnu.org/licenses/>.
 */

#include "game-server/statusmanager.h"

#include "common/resourcemanager.h"
#include "game-server/statuseffect.h"
#include "scripting/script.h"
#include "utils/logger.h"
#include "utils/xml.h"

#include <map>
#include <set>
#include <sstream>

typedef std::map< int, StatusEffect * > StatusEffectsMap;
static StatusEffectsMap statusEffects;
static std::string statusReferenceFile;

void StatusManager::initialize(const std::string &file)
{
    statusReferenceFile = file;
    reload();
}

void StatusManager::reload()
{
    XML::Document doc(statusReferenceFile);
    xmlNodePtr rootNode = doc.rootNode();

    if (!rootNode || !xmlStrEqual(rootNode->name, BAD_CAST "status-effects"))
    {
        LOG_ERROR("Status Manager: Error while parsing status database ("
                  << statusReferenceFile << ")!");
        return;
    }

    LOG_INFO("Loading status reference: " << statusReferenceFile);
    for_each_xml_child_node(node, rootNode)
    {
        if (!xmlStrEqual(node->name, BAD_CAST "status-effect"))
            continue;

        int id = XML::getProperty(node, "id", 0);
        if (id < 1)
        {
            LOG_WARN("Status Manager: The status ID: " << id << " in "
                     << statusReferenceFile
                     << " is invalid and will be ignored.");
            continue;
        }

        std::string scriptFile = XML::getProperty(node, "script", std::string());
        //TODO: Get these modifiers
/*
        modifiers.setAttributeValue(BASE_ATTR_PHY_ATK_MIN,      XML::getProperty(node, "attack-min",      0));
        modifiers.setAttributeValue(BASE_ATTR_PHY_ATK_DELTA,      XML::getProperty(node, "attack-delta",      0));
        modifiers.setAttributeValue(BASE_ATTR_HP,      XML::getProperty(node, "hp",      0));
        modifiers.setAttributeValue(BASE_ATTR_PHY_RES, XML::getProperty(node, "defense", 0));
        modifiers.setAttributeValue(CHAR_ATTR_STRENGTH,     XML::getProperty(node, "strength",     0));
        modifiers.setAttributeValue(CHAR_ATTR_AGILITY,      XML::getProperty(node, "agility",      0));
        modifiers.setAttributeValue(CHAR_ATTR_DEXTERITY,    XML::getProperty(node, "dexterity",    0));
        modifiers.setAttributeValue(CHAR_ATTR_VITALITY,     XML::getProperty(node, "vitality",     0));
        modifiers.setAttributeValue(CHAR_ATTR_INTELLIGENCE, XML::getProperty(node, "intelligence", 0));
        modifiers.setAttributeValue(CHAR_ATTR_WILLPOWER,    XML::getProperty(node, "willpower",    0));
*/
        StatusEffect *statusEffect = new StatusEffect(id);
        if (!scriptFile.empty())
        {
            std::stringstream filename;
            filename << "scripts/status/" << scriptFile;
            if (ResourceManager::exists(filename.str()))       // file exists!
            {
                LOG_INFO("Loading status script: " << filename.str());
                std::string engineName =
                        Script::determineEngineByFilename(filename.str());
                Script *s = Script::create(engineName);
                s->loadFile(filename.str());
                statusEffect->setScript(s);
            } else {
                LOG_WARN("Could not find script file \"" << filename.str()
                         << "\" for status #"<<id);
            }
        }
        statusEffects[id] = statusEffect;
    }
}

void StatusManager::deinitialize()
{
    for (StatusEffectsMap::iterator i = statusEffects.begin(),
           i_end = statusEffects.end(); i != i_end; ++i)
    {
        delete i->second;
    }
    statusEffects.clear();
}

StatusEffect *StatusManager::getStatus(int statusId)
{
    StatusEffectsMap::const_iterator i = statusEffects.find(statusId);
    return i != statusEffects.end() ? i->second : NULL;
}