Apply autocalc corrections to player starting spells

deque
scrawl 11 years ago
parent fd3f109362
commit d63dd88113

@ -186,7 +186,7 @@ namespace MWMechanics
const ESM::Spell* weakestSpell = NULL; const ESM::Spell* weakestSpell = NULL;
int minCost = INT_MAX; int minCost = INT_MAX;
std::set<std::string> selectedSpells; std::vector<std::string> selectedSpells;
const ESM::Race* race = NULL; const ESM::Race* race = NULL;
if (mRaceSelected) if (mRaceSelected)
@ -212,8 +212,6 @@ namespace MWMechanics
continue; continue;
if (reachedLimit && spell->mData.mCost <= minCost) if (reachedLimit && spell->mData.mCost <= minCost)
continue; continue;
if (selectedSpells.find(spell->mId) != selectedSpells.end())
continue;
if (race && std::find(race->mPowers.mList.begin(), race->mPowers.mList.end(), spell->mId) != race->mPowers.mList.end()) if (race && std::find(race->mPowers.mList.begin(), race->mPowers.mList.end(), spell->mId) != race->mPowers.mList.end())
continue; continue;
if (baseMagicka < spell->mData.mCost) if (baseMagicka < spell->mData.mCost)
@ -226,18 +224,19 @@ namespace MWMechanics
if (!attrSkillCheck(spell, skills, attributes)) if (!attrSkillCheck(spell, skills, attributes))
continue; continue;
selectedSpells.insert(spell->mId); selectedSpells.push_back(spell->mId);
if (reachedLimit) if (reachedLimit)
{ {
selectedSpells.erase(weakestSpell->mId); std::vector<std::string>::iterator it = std::find(selectedSpells.begin(), selectedSpells.end(), weakestSpell->mId);
if (it != selectedSpells.end())
selectedSpells.erase(it);
minCost = INT_MAX; minCost = INT_MAX;
for (std::set<std::string>::iterator weakIt = selectedSpells.begin(); weakIt != selectedSpells.end(); ++weakIt) for (std::vector<std::string>::iterator weakIt = selectedSpells.begin(); weakIt != selectedSpells.end(); ++weakIt)
{ {
const ESM::Spell* testSpell = esmStore.get<ESM::Spell>().find(*weakIt); const ESM::Spell* testSpell = esmStore.get<ESM::Spell>().find(*weakIt);
if (testSpell->mData.mCost < minCost) // XXX what if 2 candidates have the same cost? if (testSpell->mData.mCost < minCost)
// Note iAutoPCSpellMax is 100 by default, so reachedLimit is very unlikely to happen
{ {
minCost = testSpell->mData.mCost; minCost = testSpell->mData.mCost;
weakestSpell = testSpell; weakestSpell = testSpell;
@ -257,7 +256,7 @@ namespace MWMechanics
} }
} }
for (std::set<std::string>::iterator it = selectedSpells.begin(); it != selectedSpells.end(); ++it) for (std::vector<std::string>::iterator it = selectedSpells.begin(); it != selectedSpells.end(); ++it)
creatureStats.getSpells().add(*it); creatureStats.getSpells().add(*it);
// forced update and current value adjustments // forced update and current value adjustments

Loading…
Cancel
Save