1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 06:26:36 +00:00

Merge branch 'i_am_the_caster_now' into 'master'

Preserve the original caster if classic reflected absorb spells behaviour is on

Closes #6511

See merge request OpenMW/openmw!1497
This commit is contained in:
psi29a 2021-12-21 12:01:09 +00:00
commit da3c718fe2

View file

@ -9,6 +9,8 @@
#include <components/esm/loadmgef.hpp> #include <components/esm/loadmgef.hpp>
#include <components/settings/settings.hpp>
#include "creaturestats.hpp" #include "creaturestats.hpp"
#include "spellcasting.hpp" #include "spellcasting.hpp"
#include "spelleffects.hpp" #include "spelleffects.hpp"
@ -236,7 +238,13 @@ namespace MWMechanics
if(result == MagicApplicationResult::REFLECTED) if(result == MagicApplicationResult::REFLECTED)
{ {
if(!reflected) if(!reflected)
{
static const bool keepOriginalCaster = Settings::Manager::getBool("classic reflected absorb spells behavior", "Game");
if(keepOriginalCaster)
reflected = {*spellIt, caster};
else
reflected = {*spellIt, ptr}; reflected = {*spellIt, ptr};
}
auto& reflectedEffect = reflected->mEffects.emplace_back(*it); auto& reflectedEffect = reflected->mEffects.emplace_back(*it);
reflectedEffect.mFlags = ESM::ActiveEffect::Flag_Ignore_Reflect | ESM::ActiveEffect::Flag_Ignore_SpellAbsorption; reflectedEffect.mFlags = ESM::ActiveEffect::Flag_Ignore_Reflect | ESM::ActiveEffect::Flag_Ignore_SpellAbsorption;
it = spellIt->mEffects.erase(it); it = spellIt->mEffects.erase(it);