forked from teamnwah/openmw-tes3coop
Fix respawning of NPCs/creatures when they were moved to a different cell
This commit is contained in:
parent
da6dcfc49e
commit
fb219fea17
2 changed files with 10 additions and 10 deletions
|
@ -772,18 +772,18 @@ namespace MWClass
|
||||||
{
|
{
|
||||||
if (isFlagBitSet(ptr, ESM::Creature::Respawn))
|
if (isFlagBitSet(ptr, ESM::Creature::Respawn))
|
||||||
{
|
{
|
||||||
// Note we do not respawn moved references in the cell they were moved to. Instead they are respawned in the original cell.
|
|
||||||
// This also means we cannot respawn dynamically placed references with no content file connection.
|
|
||||||
if (ptr.getCellRef().hasContentFile())
|
if (ptr.getCellRef().hasContentFile())
|
||||||
{
|
{
|
||||||
if (ptr.getRefData().getCount() == 0)
|
if (ptr.getRefData().getCount() == 0)
|
||||||
ptr.getRefData().setCount(1);
|
ptr.getRefData().setCount(1);
|
||||||
|
|
||||||
// Reset to original position
|
|
||||||
ptr.getRefData().setPosition(ptr.getCellRef().getPosition());
|
|
||||||
|
|
||||||
MWBase::Environment::get().getWorld()->removeContainerScripts(ptr);
|
MWBase::Environment::get().getWorld()->removeContainerScripts(ptr);
|
||||||
ptr.getRefData().setCustomData(NULL);
|
ptr.getRefData().setCustomData(NULL);
|
||||||
|
|
||||||
|
// Reset to original position
|
||||||
|
MWBase::Environment::get().getWorld()->moveObject(ptr, ptr.getCellRef().getPosition().pos[0],
|
||||||
|
ptr.getCellRef().getPosition().pos[1],
|
||||||
|
ptr.getCellRef().getPosition().pos[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1305,18 +1305,18 @@ namespace MWClass
|
||||||
{
|
{
|
||||||
if (ptr.get<ESM::NPC>()->mBase->mFlags & ESM::NPC::Respawn)
|
if (ptr.get<ESM::NPC>()->mBase->mFlags & ESM::NPC::Respawn)
|
||||||
{
|
{
|
||||||
// Note we do not respawn moved references in the cell they were moved to. Instead they are respawned in the original cell.
|
|
||||||
// This also means we cannot respawn dynamically placed references with no content file connection.
|
|
||||||
if (ptr.getCellRef().hasContentFile())
|
if (ptr.getCellRef().hasContentFile())
|
||||||
{
|
{
|
||||||
if (ptr.getRefData().getCount() == 0)
|
if (ptr.getRefData().getCount() == 0)
|
||||||
ptr.getRefData().setCount(1);
|
ptr.getRefData().setCount(1);
|
||||||
|
|
||||||
// Reset to original position
|
|
||||||
ptr.getRefData().setPosition(ptr.getCellRef().getPosition());
|
|
||||||
|
|
||||||
MWBase::Environment::get().getWorld()->removeContainerScripts(ptr);
|
MWBase::Environment::get().getWorld()->removeContainerScripts(ptr);
|
||||||
ptr.getRefData().setCustomData(NULL);
|
ptr.getRefData().setCustomData(NULL);
|
||||||
|
|
||||||
|
// Reset to original position
|
||||||
|
MWBase::Environment::get().getWorld()->moveObject(ptr, ptr.getCellRef().getPosition().pos[0],
|
||||||
|
ptr.getCellRef().getPosition().pos[1],
|
||||||
|
ptr.getCellRef().getPosition().pos[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue