1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 22:23:51 +00:00
openmw-tes3mp/apps/openmw/mwmechanics/repair.cpp

109 lines
3.7 KiB
C++
Raw Normal View History

2013-03-23 07:16:46 +00:00
#include "repair.hpp"
#include <boost/format.hpp>
2015-04-22 15:58:55 +00:00
#include <components/misc/rng.hpp>
2013-03-23 07:16:46 +00:00
#include "../mwbase/world.hpp"
#include "../mwbase/environment.hpp"
#include "../mwbase/mechanicsmanager.hpp"
#include "../mwbase/windowmanager.hpp"
#include "../mwbase/soundmanager.hpp"
#include "../mwworld/containerstore.hpp"
#include "../mwworld/class.hpp"
2014-02-23 19:11:05 +00:00
#include "../mwworld/esmstore.hpp"
2013-03-23 07:16:46 +00:00
2015-08-21 09:12:39 +00:00
#include "creaturestats.hpp"
#include "npcstats.hpp"
#include "actorutil.hpp"
2013-03-23 07:16:46 +00:00
namespace MWMechanics
{
void Repair::repair(const MWWorld::Ptr &itemToRepair)
{
2015-08-21 09:12:39 +00:00
MWWorld::Ptr player = getPlayer();
2013-03-23 07:16:46 +00:00
MWWorld::LiveCellRef<ESM::Repair> *ref =
mTool.get<ESM::Repair>();
2014-01-02 20:21:28 +00:00
// unstack tool if required
player.getClass().getContainerStore(player).unstack(mTool, player);
2013-03-23 07:16:46 +00:00
// reduce number of uses left
int uses = mTool.getClass().getItemHealth(mTool);
mTool.getCellRef().setCharge(uses-1);
2013-03-23 07:16:46 +00:00
MWMechanics::CreatureStats& stats = player.getClass().getCreatureStats(player);
MWMechanics::NpcStats& npcStats = player.getClass().getNpcStats(player);
2013-03-23 07:16:46 +00:00
float fatigueTerm = stats.getFatigueTerm();
int pcStrength = stats.getAttribute(ESM::Attribute::Strength).getModified();
int pcLuck = stats.getAttribute(ESM::Attribute::Luck).getModified();
int armorerSkill = npcStats.getSkill(ESM::Skill::Armorer).getModified();
float fRepairAmountMult = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>()
.find("fRepairAmountMult")->getFloat();
float toolQuality = ref->mBase->mData.mQuality;
float x = (0.1f * pcStrength + 0.1f * pcLuck + armorerSkill) * fatigueTerm;
2013-03-23 07:16:46 +00:00
2015-04-22 15:58:55 +00:00
int roll = Misc::Rng::roll0to99();
2013-03-23 07:16:46 +00:00
if (roll <= x)
{
int y = static_cast<int>(fRepairAmountMult * toolQuality * roll);
2013-03-23 07:16:46 +00:00
y = std::max(1, y);
// repair by 'y' points
int charge = itemToRepair.getClass().getItemHealth(itemToRepair);
charge = std::min(charge + y, itemToRepair.getClass().getItemMaxHealth(itemToRepair));
itemToRepair.getCellRef().setCharge(charge);
2013-03-23 07:16:46 +00:00
// attempt to re-stack item, in case it was fully repaired
MWWorld::ContainerStoreIterator stacked = player.getClass().getContainerStore(player).restack(itemToRepair);
2013-03-23 07:16:46 +00:00
// set the OnPCRepair variable on the item's script
std::string script = stacked->getClass().getScript(itemToRepair);
2013-03-23 07:16:46 +00:00
if(script != "")
stacked->getRefData().getLocals().setVarByInt(script, "onpcrepair", 1);
2013-03-23 07:16:46 +00:00
// increase skill
player.getClass().skillUsageSucceeded(player, ESM::Skill::Armorer, 0);
2013-03-23 07:16:46 +00:00
MWBase::Environment::get().getSoundManager()->playSound("Repair",1,1);
MWBase::Environment::get().getWindowManager()->messageBox("#{sRepairSuccess}");
}
else
{
MWBase::Environment::get().getSoundManager()->playSound("Repair Fail",1,1);
MWBase::Environment::get().getWindowManager()->messageBox("#{sRepairFailed}");
}
// tool used up?
if (mTool.getCellRef().getCharge() == 0)
2013-03-23 07:16:46 +00:00
{
MWWorld::ContainerStore& store = player.getClass().getContainerStore(player);
store.remove(mTool, 1, player);
2013-03-23 07:16:46 +00:00
std::string message = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>()
.find("sNotifyMessage51")->getString();
MWBase::Environment::get().getWindowManager()->messageBox((boost::format(message) % mTool.getClass().getName(mTool)).str());
2013-03-23 07:16:46 +00:00
// try to find a new tool of the same ID
for (MWWorld::ContainerStoreIterator iter (store.begin());
iter!=store.end(); ++iter)
{
if (Misc::StringUtils::ciEqual(iter->getCellRef().getRefId(), mTool.getCellRef().getRefId()))
2013-03-23 07:16:46 +00:00
{
mTool = *iter;
break;
}
}
}
}
}