mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 05: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:
commit
da3c718fe2
1 changed files with 9 additions and 1 deletions
|
@ -9,6 +9,8 @@
|
|||
|
||||
#include <components/esm/loadmgef.hpp>
|
||||
|
||||
#include <components/settings/settings.hpp>
|
||||
|
||||
#include "creaturestats.hpp"
|
||||
#include "spellcasting.hpp"
|
||||
#include "spelleffects.hpp"
|
||||
|
@ -236,7 +238,13 @@ namespace MWMechanics
|
|||
if(result == MagicApplicationResult::REFLECTED)
|
||||
{
|
||||
if(!reflected)
|
||||
reflected = {*spellIt, ptr};
|
||||
{
|
||||
static const bool keepOriginalCaster = Settings::Manager::getBool("classic reflected absorb spells behavior", "Game");
|
||||
if(keepOriginalCaster)
|
||||
reflected = {*spellIt, caster};
|
||||
else
|
||||
reflected = {*spellIt, ptr};
|
||||
}
|
||||
auto& reflectedEffect = reflected->mEffects.emplace_back(*it);
|
||||
reflectedEffect.mFlags = ESM::ActiveEffect::Flag_Ignore_Reflect | ESM::ActiveEffect::Flag_Ignore_SpellAbsorption;
|
||||
it = spellIt->mEffects.erase(it);
|
||||
|
|
Loading…
Reference in a new issue