2012-05-19 13:01:07 +00:00
|
|
|
#ifndef GAME_MWMECHANICS_ACTIVESPELLS_H
|
|
|
|
#define GAME_MWMECHANICS_ACTIVESPELLS_H
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
|
2016-06-17 14:07:16 +00:00
|
|
|
#include <components/esm/activespells.hpp>
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
#include "../mwworld/timestamp.hpp"
|
|
|
|
|
|
|
|
#include "magiceffects.hpp"
|
|
|
|
|
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
/// \brief Lasting spell effects
|
2012-06-24 09:39:21 +00:00
|
|
|
///
|
|
|
|
/// \note The name of this class is slightly misleading, since it also handels lasting potion
|
|
|
|
/// effects.
|
2012-05-19 13:01:07 +00:00
|
|
|
class ActiveSpells
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2014-05-14 20:16:39 +00:00
|
|
|
typedef ESM::ActiveEffect ActiveEffect;
|
2013-11-17 22:15:57 +00:00
|
|
|
|
|
|
|
struct ActiveSpellParams
|
|
|
|
{
|
2014-05-14 20:16:39 +00:00
|
|
|
std::vector<ActiveEffect> mEffects;
|
2013-11-17 22:15:57 +00:00
|
|
|
MWWorld::TimeStamp mTimeStamp;
|
|
|
|
std::string mDisplayName;
|
2013-11-19 17:43:21 +00:00
|
|
|
|
2014-05-14 05:14:08 +00:00
|
|
|
// The caster that inflicted this spell on us
|
|
|
|
int mCasterActorId;
|
2013-11-17 22:15:57 +00:00
|
|
|
};
|
|
|
|
|
2013-11-09 06:51:46 +00:00
|
|
|
typedef std::multimap<std::string, ActiveSpellParams > TContainer;
|
2012-05-19 13:01:07 +00:00
|
|
|
typedef TContainer::const_iterator TIterator;
|
|
|
|
|
2014-05-14 20:16:39 +00:00
|
|
|
void readState (const ESM::ActiveSpells& state);
|
|
|
|
void writeState (ESM::ActiveSpells& state) const;
|
|
|
|
|
2014-06-17 01:54:41 +00:00
|
|
|
TIterator begin() const;
|
|
|
|
|
|
|
|
TIterator end() const;
|
|
|
|
|
2019-09-18 05:43:32 +00:00
|
|
|
void update(float duration) const;
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
private:
|
|
|
|
|
2013-11-16 04:06:54 +00:00
|
|
|
mutable TContainer mSpells;
|
2012-05-19 13:01:07 +00:00
|
|
|
mutable MagicEffects mEffects;
|
|
|
|
mutable bool mSpellsChanged;
|
|
|
|
|
2021-10-11 22:34:15 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Track the actorId corresponding to these ActiveSpells
|
|
|
|
*/
|
|
|
|
int mActorId;
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2012-09-13 09:30:59 +00:00
|
|
|
void rebuildEffects() const;
|
2012-05-19 13:01:07 +00:00
|
|
|
|
2015-03-01 02:34:18 +00:00
|
|
|
/// Add any effects that are in "from" and not in "addTo" to "addTo"
|
|
|
|
void mergeEffects(std::vector<ActiveEffect>& addTo, const std::vector<ActiveEffect>& from);
|
|
|
|
|
2013-11-15 19:29:47 +00:00
|
|
|
double timeToExpire (const TIterator& iterator) const;
|
|
|
|
///< Returns time (in in-game hours) until the spell pointed to by \a iterator
|
|
|
|
/// expires.
|
|
|
|
|
|
|
|
const TContainer& getActiveSpells() const;
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
ActiveSpells();
|
|
|
|
|
2013-11-17 22:15:57 +00:00
|
|
|
/// Add lasting effects
|
2012-06-24 14:23:43 +00:00
|
|
|
///
|
2013-11-17 22:15:57 +00:00
|
|
|
/// \brief addSpell
|
|
|
|
/// \param id ID for stacking purposes.
|
|
|
|
/// \param stack If false, the spell is not added if one with the same ID exists already.
|
|
|
|
/// \param effects
|
|
|
|
/// \param displayName Name for display in magic menu.
|
|
|
|
///
|
2014-05-14 20:16:39 +00:00
|
|
|
void addSpell (const std::string& id, bool stack, std::vector<ActiveEffect> effects,
|
2014-05-14 05:14:08 +00:00
|
|
|
const std::string& displayName, int casterActorId);
|
2013-11-17 22:15:57 +00:00
|
|
|
|
2021-07-04 10:54:11 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Add a separate addSpell() with a timestamp argument
|
|
|
|
*/
|
|
|
|
void addSpell (const std::string& id, bool stack, std::vector<ActiveEffect> effects,
|
2021-07-06 15:22:19 +00:00
|
|
|
const std::string& displayName, int casterActorId, MWWorld::TimeStamp timestamp, bool sendPacket = true);
|
2021-07-04 10:54:11 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-01-03 03:56:54 +00:00
|
|
|
/// Removes the active effects from this spell/potion/.. with \a id
|
|
|
|
void removeEffects (const std::string& id);
|
|
|
|
|
2021-07-04 10:54:11 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Remove the spell with a certain ID and a certain timestamp, useful
|
|
|
|
when there are stacked spells with the same ID
|
|
|
|
*/
|
2022-02-12 12:00:47 +00:00
|
|
|
bool removeSpellByTimestamp(const std::string& id, MWWorld::TimeStamp timestamp);
|
2021-07-04 10:54:11 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-01-03 03:56:54 +00:00
|
|
|
/// Remove all active effects with this effect id
|
2013-11-17 22:15:57 +00:00
|
|
|
void purgeEffect (short effectId);
|
2012-05-19 13:01:07 +00:00
|
|
|
|
2015-01-05 17:52:37 +00:00
|
|
|
/// Remove all active effects with this effect id and source id
|
2020-06-08 11:19:25 +00:00
|
|
|
void purgeEffect (short effectId, const std::string& sourceId, int effectIndex=-1);
|
2015-01-05 17:52:37 +00:00
|
|
|
|
2014-01-02 19:15:07 +00:00
|
|
|
/// Remove all active effects, if roll succeeds (for each effect)
|
2017-08-14 16:39:04 +00:00
|
|
|
void purgeAll(float chance, bool spellOnly = false);
|
2012-05-19 13:01:07 +00:00
|
|
|
|
2014-05-14 05:14:08 +00:00
|
|
|
/// Remove all effects with CASTER_LINKED flag that were cast by \a casterActorId
|
|
|
|
void purge (int casterActorId);
|
2014-01-12 09:21:49 +00:00
|
|
|
|
2017-12-02 07:22:36 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Allow the purging of an effect for a specific arg (attribute or skill)
|
|
|
|
*/
|
|
|
|
void purgeEffectByArg(short effectId, int effectArg);
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2018-06-30 21:43:29 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Make it easy to get an effect's duration
|
|
|
|
*/
|
2019-04-21 18:53:38 +00:00
|
|
|
float getEffectDuration(short effectId, std::string sourceId);
|
2018-06-30 21:43:29 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-05-14 20:16:39 +00:00
|
|
|
/// Remove all spells
|
|
|
|
void clear();
|
|
|
|
|
2015-12-07 21:49:15 +00:00
|
|
|
bool isSpellActive (const std::string& id) const;
|
2012-11-25 00:26:29 +00:00
|
|
|
///< case insensitive
|
|
|
|
|
2019-09-30 16:27:42 +00:00
|
|
|
void purgeCorprusDisease();
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
const MagicEffects& getMagicEffects() const;
|
|
|
|
|
2013-11-15 19:29:47 +00:00
|
|
|
void visitEffectSources (MWMechanics::EffectSourceVisitor& visitor) const;
|
2012-05-19 13:01:07 +00:00
|
|
|
|
2021-10-11 22:34:15 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Make it possible to set and get the actorId for these ActiveSpells
|
|
|
|
*/
|
|
|
|
int getActorId() const;
|
|
|
|
void setActorId(int actorId);
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|