forked from teamnwah/openmw-tes3coop
[Client] Create RecordHelper class with initial NPC and creature methods
This commit is contained in:
parent
9697595857
commit
9d27f5f154
3 changed files with 68 additions and 1 deletions
|
@ -98,7 +98,7 @@ add_openmw_dir (mwbase
|
||||||
)
|
)
|
||||||
|
|
||||||
add_openmw_dir (mwmp Main Networking LocalPlayer DedicatedPlayer PlayerList LocalActor DedicatedActor ActorList WorldEvent
|
add_openmw_dir (mwmp Main Networking LocalPlayer DedicatedPlayer PlayerList LocalActor DedicatedActor ActorList WorldEvent
|
||||||
Cell CellController MechanicsHelper GUIController
|
Cell CellController MechanicsHelper RecordHelper GUIController
|
||||||
)
|
)
|
||||||
|
|
||||||
add_openmw_dir (mwmp/GUI GUIChat GUILogin PlayerMarkerCollection GUIDialogList TextInputDialog
|
add_openmw_dir (mwmp/GUI GUIChat GUILogin PlayerMarkerCollection GUIDialogList TextInputDialog
|
||||||
|
|
48
apps/openmw/mwmp/RecordHelper.cpp
Normal file
48
apps/openmw/mwmp/RecordHelper.cpp
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
#include <components/openmw-mp/Log.hpp>
|
||||||
|
|
||||||
|
#include "../mwbase/environment.hpp"
|
||||||
|
|
||||||
|
#include "../mwworld/worldimp.hpp"
|
||||||
|
|
||||||
|
#include "RecordHelper.hpp"
|
||||||
|
|
||||||
|
bool RecordHelper::doesCreatureExist(const std::string& refId)
|
||||||
|
{
|
||||||
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
||||||
|
|
||||||
|
return world->getStore().get<ESM::Creature>().search(refId);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string RecordHelper::createCreatureRecord(const ESM::Creature& creature)
|
||||||
|
{
|
||||||
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
||||||
|
|
||||||
|
return world->createRecord(creature)->mId;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string RecordHelper::createNpcRecord(const ESM::NPC& npc)
|
||||||
|
{
|
||||||
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
||||||
|
|
||||||
|
return world->createRecord(npc)->mId;
|
||||||
|
}
|
||||||
|
|
||||||
|
void RecordHelper::updateCreatureRecord(const ESM::Creature& creature)
|
||||||
|
{
|
||||||
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
||||||
|
|
||||||
|
MWWorld::ESMStore *esmStore = const_cast<MWWorld::ESMStore *>(&world->getStore());
|
||||||
|
MWWorld::Store<ESM::Creature> *creatureStore = const_cast<MWWorld::Store<ESM::Creature> *> (&esmStore->get<ESM::Creature>());
|
||||||
|
|
||||||
|
creatureStore->insert(creature);
|
||||||
|
}
|
||||||
|
|
||||||
|
void RecordHelper::updateNpcRecord(const ESM::NPC& npc)
|
||||||
|
{
|
||||||
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
||||||
|
|
||||||
|
MWWorld::ESMStore *esmStore = const_cast<MWWorld::ESMStore *>(&world->getStore());
|
||||||
|
MWWorld::Store<ESM::NPC> *npcStore = const_cast<MWWorld::Store<ESM::NPC> *> (&esmStore->get<ESM::NPC>());
|
||||||
|
|
||||||
|
npcStore->insert(npc);
|
||||||
|
}
|
19
apps/openmw/mwmp/RecordHelper.hpp
Normal file
19
apps/openmw/mwmp/RecordHelper.hpp
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
#ifndef OPENMW_RECORDHELPER_HPP
|
||||||
|
#define OPENMW_RECORDHELPER_HPP
|
||||||
|
|
||||||
|
#include <components/esm/loadcrea.hpp>
|
||||||
|
#include <components/esm/loadnpc.hpp>
|
||||||
|
|
||||||
|
namespace RecordHelper
|
||||||
|
{
|
||||||
|
bool doesCreatureExist(const std::string& refId);
|
||||||
|
|
||||||
|
std::string createCreatureRecord(const ESM::Creature& creature);
|
||||||
|
std::string createNpcRecord(const ESM::NPC& npc);
|
||||||
|
|
||||||
|
void updateCreatureRecord(const ESM::Creature& creature);
|
||||||
|
void updateNpcRecord(const ESM::NPC& npc);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endif //OPENMW_RECORDHELPER_HPP
|
Loading…
Reference in a new issue