|
|
@ -3072,8 +3072,8 @@ namespace MWWorld
|
|
|
|
mRendering->spawnEffect(model, textureOverride, worldPos);
|
|
|
|
mRendering->spawnEffect(model, textureOverride, worldPos);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void World::explodeSpell(const osg::Vec3f &origin, const ESM::EffectList &effects, const Ptr &caster, ESM::RangeType rangeType,
|
|
|
|
void World::explodeSpell(const osg::Vec3f &origin, const ESM::EffectList &effects, const Ptr &caster, const Ptr& ignore,
|
|
|
|
const std::string& id, const std::string& sourceName)
|
|
|
|
ESM::RangeType rangeType, const std::string& id, const std::string& sourceName)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::map<MWWorld::Ptr, std::vector<ESM::ENAMstruct> > toApply;
|
|
|
|
std::map<MWWorld::Ptr, std::vector<ESM::ENAMstruct> > toApply;
|
|
|
|
for (std::vector<ESM::ENAMstruct>::const_iterator effectIt = effects.mList.begin();
|
|
|
|
for (std::vector<ESM::ENAMstruct>::const_iterator effectIt = effects.mList.begin();
|
|
|
@ -3121,6 +3121,9 @@ namespace MWWorld
|
|
|
|
if (apply->first == caster)
|
|
|
|
if (apply->first == caster)
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (apply->first == ignore)
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
if (source.isEmpty())
|
|
|
|
if (source.isEmpty())
|
|
|
|
source = apply->first;
|
|
|
|
source = apply->first;
|
|
|
|
|
|
|
|
|
|
|
|