|
|
@ -19,16 +19,14 @@ namespace MWMechanics
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/// @return ID of resulting item, or empty if none
|
|
|
|
/// @return ID of resulting item, or empty if none
|
|
|
|
inline std::string getLevelledItem (const ESM::LevelledListBase* levItem, bool creature, unsigned char failChance=0)
|
|
|
|
inline std::string getLevelledItem (const ESM::LevelledListBase* levItem, bool creature)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const std::vector<ESM::LevelledListBase::LevelItem>& items = levItem->mList;
|
|
|
|
const std::vector<ESM::LevelledListBase::LevelItem>& items = levItem->mList;
|
|
|
|
|
|
|
|
|
|
|
|
const MWWorld::Ptr& player = getPlayer();
|
|
|
|
const MWWorld::Ptr& player = getPlayer();
|
|
|
|
int playerLevel = player.getClass().getCreatureStats(player).getLevel();
|
|
|
|
int playerLevel = player.getClass().getCreatureStats(player).getLevel();
|
|
|
|
|
|
|
|
|
|
|
|
failChance += levItem->mChanceNone;
|
|
|
|
if (Misc::Rng::roll0to99() < levItem->mChanceNone)
|
|
|
|
|
|
|
|
|
|
|
|
if (Misc::Rng::roll0to99() < failChance)
|
|
|
|
|
|
|
|
return std::string();
|
|
|
|
return std::string();
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<std::string> candidates;
|
|
|
|
std::vector<std::string> candidates;
|
|
|
@ -76,9 +74,9 @@ namespace MWMechanics
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (ref.getPtr().getTypeName() == typeid(ESM::ItemLevList).name())
|
|
|
|
if (ref.getPtr().getTypeName() == typeid(ESM::ItemLevList).name())
|
|
|
|
return getLevelledItem(ref.getPtr().get<ESM::ItemLevList>()->mBase, false, failChance);
|
|
|
|
return getLevelledItem(ref.getPtr().get<ESM::ItemLevList>()->mBase, false);
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return getLevelledItem(ref.getPtr().get<ESM::CreatureLevList>()->mBase, true, failChance);
|
|
|
|
return getLevelledItem(ref.getPtr().get<ESM::CreatureLevList>()->mBase, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|