1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-27 18:15:31 +00:00
openmw-tes3mp/apps/openmw/mwworld/actionread.cpp

62 lines
2 KiB
C++
Raw Normal View History

#include "actionread.hpp"
#include "../mwbase/environment.hpp"
#include "../mwbase/windowmanager.hpp"
2012-09-15 17:06:56 +00:00
#include "../mwbase/world.hpp"
2012-09-15 17:06:56 +00:00
#include "../mwmechanics/npcstats.hpp"
2015-09-10 06:48:34 +00:00
#include "../mwmechanics/actorutil.hpp"
2012-10-01 15:17:04 +00:00
#include "player.hpp"
#include "class.hpp"
#include "esmstore.hpp"
2012-09-15 17:06:56 +00:00
namespace MWWorld
{
ActionRead::ActionRead (const MWWorld::Ptr& object) : Action (false, object)
{
}
void ActionRead::executeImp (const MWWorld::Ptr& actor) {
2015-09-10 06:48:34 +00:00
if (actor != MWMechanics::getPlayer())
return;
//Ensure we're not in combat
2015-09-10 06:48:34 +00:00
if(MWMechanics::isPlayerInCombat()
// Reading in combat is still allowed if the scroll/book is not in the player inventory yet
// (since otherwise, there would be no way to pick it up)
&& getTarget().getContainerStore() == &actor.getClass().getContainerStore(actor)
) {
MWBase::Environment::get().getWindowManager()->messageBox("#{sInventoryMessage4}");
return;
}
LiveCellRef<ESM::Book> *ref = getTarget().get<ESM::Book>();
2012-11-05 12:07:59 +00:00
if (ref->mBase->mData.mIsScroll)
MWBase::Environment::get().getWindowManager()->pushGuiMode(MWGui::GM_Scroll, getTarget());
else
MWBase::Environment::get().getWindowManager()->pushGuiMode(MWGui::GM_Book, getTarget());
2012-09-15 17:06:56 +00:00
2015-03-11 19:33:55 +00:00
MWMechanics::NpcStats& npcStats = actor.getClass().getNpcStats (actor);
2012-09-25 16:59:24 +00:00
2012-09-15 18:03:53 +00:00
// Skill gain from books
if (ref->mBase->mData.mSkillId >= 0 && ref->mBase->mData.mSkillId < ESM::Skill::Length
2012-11-05 12:07:59 +00:00
&& !npcStats.hasBeenUsed (ref->mBase->mId))
2012-09-15 17:06:56 +00:00
{
2015-03-11 19:33:55 +00:00
MWWorld::LiveCellRef<ESM::NPC> *playerRef = actor.get<ESM::NPC>();
const ESM::Class *class_ =
MWBase::Environment::get().getWorld()->getStore().get<ESM::Class>().find (
playerRef->mBase->mClass
);
2012-09-15 17:06:56 +00:00
2018-03-24 10:43:18 +00:00
npcStats.increaseSkill (ref->mBase->mData.mSkillId, *class_, true, true);
2012-09-15 17:06:56 +00:00
2012-11-05 12:07:59 +00:00
npcStats.flagAsUsed (ref->mBase->mId);
2012-09-15 17:06:56 +00:00
}
}
}