summaryrefslogtreecommitdiff
path: root/src/statuseffect.h
blob: 14312494820fed77a1bee2826d1ddd13d3c2d47d (plain) (blame)
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
122
123
124
125
126
127
128
129
130
/*
 *  The ManaPlus Client
 *  Copyright (C) 2008-2009  The Mana World Development Team
 *  Copyright (C) 2009-2010  The Mana Developers
 *  Copyright (C) 2011-2015  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 STATUSEFFECT_H
#define STATUSEFFECT_H

#include <string>

#include "localconsts.h"

class AnimatedSprite;
class Particle;

class StatusEffect final
{
    public:
        StatusEffect();

        A_DELETE_COPY(StatusEffect)

        ~StatusEffect();

        /**
         * Plays the sound effect associated with this status effect, if
         * possible.
         */
        void playSFX() const;

        /**
         * Delivers the chat message associated with this status effect, if
         * possible.
         */
        void deliverMessage() const;

        /**
         * Creates the particle effect associated with this status effect, if
         * possible.
         */
        Particle *getParticle() const A_WARN_UNUSED;

        /**
         * Retrieves the status icon for this effect, if applicable
         */
        AnimatedSprite *getIcon() const A_WARN_UNUSED;

        /**
         * Retrieves an action to perform, or SpriteAction::INVALID
         */
        std::string getAction() const A_WARN_UNUSED;

        /**
         * Determines whether the particle effect should be restarted when the
         * being changes maps
         */
        bool particleEffectIsPersistent() const A_WARN_UNUSED
        { return mPersistentParticleEffect; }

        bool isPoison() const A_WARN_UNUSED
        { return mIsPoison; }

        /**
         * Retrieves a status effect.
         *
         * \param index Index of the status effect.
         * \param enabling Whether to retrieve the activating effect (true) or
         *    the deactivating effect (false).
         */
        static StatusEffect *getStatusEffect(const int index,
                                             const bool enabling)
                                             A_WARN_UNUSED;

        /**
         * Retrieves a stun effect.
         *
         * \param index Index of the stun effect.
         * \param enabling Whether to retrieve the activating effect (true) or
         *    the deactivating effect (false).
         */
        static StatusEffect *getStunEffect(const int index,
                                           const bool enabling) A_WARN_UNUSED;

        /**
         * Maps a block effect index to its corresponding effect index.  Block
         * effect indices are used for opt2/opt3/status.option blocks; their
         * mapping to regular effect indices is handled in the config file.
         *
         * Returns -1 on failure.
         */
        static int blockEffectIndexToEffectIndex(const int blocKIndex)
                                                 A_WARN_UNUSED;

        static void load();

        static void loadXmlFile(const std::string &fileName);

        static void unload();

    private:
        static bool mLoaded;

        std::string mMessage;
        std::string mSFXEffect;
        std::string mParticleEffect;
        std::string mIcon;
        std::string mAction;
        bool mPersistentParticleEffect;
        bool mIsPoison;
        bool mIsCart;
};

#endif  // STATUSEFFECT_H