From c7bcf70c321f9103898e71c22797674501e19fed Mon Sep 17 00:00:00 2001 From: David Cernat Date: Thu, 26 Jul 2018 22:41:04 +0300 Subject: [PATCH] [Client] Ignore ObjectSpawn packets trying to spawn non-actors --- apps/openmw/mwmp/ObjectList.cpp | 54 ++++++++++++++++++--------------- 1 file changed, 29 insertions(+), 25 deletions(-) diff --git a/apps/openmw/mwmp/ObjectList.cpp b/apps/openmw/mwmp/ObjectList.cpp index 2e55c9e5f..0ba9e7523 100644 --- a/apps/openmw/mwmp/ObjectList.cpp +++ b/apps/openmw/mwmp/ObjectList.cpp @@ -402,41 +402,45 @@ void ObjectList::spawnObjects(MWWorld::CellStore* cellStore) MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(), baseObject.refId, 1); MWWorld::Ptr newPtr = ref.getPtr(); - newPtr.getCellRef().setMpNum(baseObject.mpNum); - - newPtr = MWBase::Environment::get().getWorld()->placeObject(newPtr, cellStore, baseObject.position); - - if (baseObject.isSummon) + if (newPtr.getClass().isActor()) { - MWWorld::Ptr masterPtr; - - if (baseObject.master.isPlayer) - masterPtr = MechanicsHelper::getPlayerPtr(baseObject.master); - else - masterPtr = cellStore->searchExact(baseObject.master.refNum, baseObject.master.mpNum); + newPtr = MWBase::Environment::get().getWorld()->placeObject(newPtr, cellStore, baseObject.position); + MWMechanics::CreatureStats& creatureStats = newPtr.getClass().getCreatureStats(newPtr); - if (masterPtr) + if (baseObject.isSummon) { - LOG_APPEND(Log::LOG_VERBOSE, "-- Actor has master: %s", masterPtr.getCellRef().getRefId().c_str()); + MWWorld::Ptr masterPtr; - MWMechanics::AiFollow package(masterPtr); - newPtr.getClass().getCreatureStats(newPtr).getAiSequence().stack(package, newPtr); + if (baseObject.master.isPlayer) + masterPtr = MechanicsHelper::getPlayerPtr(baseObject.master); + else + masterPtr = cellStore->searchExact(baseObject.master.refNum, baseObject.master.mpNum); - MWRender::Animation* anim = MWBase::Environment::get().getWorld()->getAnimation(newPtr); - if (anim) + if (masterPtr) { - const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get() - .search("VFX_Summon_Start"); - if (fx) - anim->addEffect("meshes\\" + fx->mModel, -1, false); - } + LOG_APPEND(Log::LOG_VERBOSE, "-- Actor has master: %s", masterPtr.getCellRef().getRefId().c_str()); - int creatureActorId = newPtr.getClass().getCreatureStats(newPtr).getActorId(); + MWMechanics::AiFollow package(masterPtr); + creatureStats.getAiSequence().stack(package, newPtr); - MWMechanics::CreatureStats& masterCreatureStats = masterPtr.getClass().getCreatureStats(masterPtr); - masterCreatureStats.setSummonedCreatureActorId(baseObject.refId, creatureActorId); + MWRender::Animation* anim = MWBase::Environment::get().getWorld()->getAnimation(newPtr); + if (anim) + { + const ESM::Static* fx = MWBase::Environment::get().getWorld()->getStore().get() + .search("VFX_Summon_Start"); + if (fx) + anim->addEffect("meshes\\" + fx->mModel, -1, false); + } + + int creatureActorId = newPtr.getClass().getCreatureStats(newPtr).getActorId(); + + MWMechanics::CreatureStats& masterCreatureStats = masterPtr.getClass().getCreatureStats(masterPtr); + masterCreatureStats.setSummonedCreatureActorId(baseObject.refId, creatureActorId); + } } } + else + LOG_APPEND(Log::LOG_VERBOSE, "-- Cannot spawn non-actor object!"); } else LOG_APPEND(Log::LOG_VERBOSE, "-- Actor already existed!");