|
|
@ -33,6 +33,10 @@ namespace MWMechanics
|
|
|
|
!lock.getClass().hasToolTip(lock)) //If it's unlocked or can not be unlocked back out immediately
|
|
|
|
!lock.getClass().hasToolTip(lock)) //If it's unlocked or can not be unlocked back out immediately
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int uses = lockpick.getClass().getItemHealth(lockpick);
|
|
|
|
|
|
|
|
if (uses == 0)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
int lockStrength = lock.getCellRef().getLockLevel();
|
|
|
|
int lockStrength = lock.getCellRef().getLockLevel();
|
|
|
|
|
|
|
|
|
|
|
|
float pickQuality = lockpick.get<ESM::Lockpick>()->mBase->mData.mQuality;
|
|
|
|
float pickQuality = lockpick.get<ESM::Lockpick>()->mBase->mData.mQuality;
|
|
|
@ -61,9 +65,7 @@ namespace MWMechanics
|
|
|
|
resultMessage = "#{sLockFail}";
|
|
|
|
resultMessage = "#{sLockFail}";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int uses = lockpick.getClass().getItemHealth(lockpick);
|
|
|
|
lockpick.getCellRef().setCharge(uses-1);
|
|
|
|
--uses;
|
|
|
|
|
|
|
|
lockpick.getCellRef().setCharge(uses);
|
|
|
|
|
|
|
|
if (!uses)
|
|
|
|
if (!uses)
|
|
|
|
lockpick.getContainerStore()->remove(lockpick, 1, mActor);
|
|
|
|
lockpick.getContainerStore()->remove(lockpick, 1, mActor);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -71,7 +73,11 @@ namespace MWMechanics
|
|
|
|
void Security::probeTrap(const MWWorld::Ptr &trap, const MWWorld::Ptr &probe,
|
|
|
|
void Security::probeTrap(const MWWorld::Ptr &trap, const MWWorld::Ptr &probe,
|
|
|
|
std::string& resultMessage, std::string& resultSound)
|
|
|
|
std::string& resultMessage, std::string& resultSound)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (trap.getCellRef().getTrap() == "")
|
|
|
|
if (trap.getCellRef().getTrap().empty())
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int uses = probe.getClass().getItemHealth(probe);
|
|
|
|
|
|
|
|
if (uses == 0)
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
float probeQuality = probe.get<ESM::Probe>()->mBase->mData.mQuality;
|
|
|
|
float probeQuality = probe.get<ESM::Probe>()->mBase->mData.mQuality;
|
|
|
@ -104,9 +110,7 @@ namespace MWMechanics
|
|
|
|
resultMessage = "#{sTrapFail}";
|
|
|
|
resultMessage = "#{sTrapFail}";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int uses = probe.getClass().getItemHealth(probe);
|
|
|
|
probe.getCellRef().setCharge(uses-1);
|
|
|
|
--uses;
|
|
|
|
|
|
|
|
probe.getCellRef().setCharge(uses);
|
|
|
|
|
|
|
|
if (!uses)
|
|
|
|
if (!uses)
|
|
|
|
probe.getContainerStore()->remove(probe, 1, mActor);
|
|
|
|
probe.getContainerStore()->remove(probe, 1, mActor);
|
|
|
|
}
|
|
|
|
}
|
|
|
|