|
|
@ -59,15 +59,18 @@ namespace
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<ESM::NPC> getNPCsToReplace(const MWWorld::Store<ESM::Faction>& factions, const MWWorld::Store<ESM::Class>& classes, const std::unordered_map<std::string, ESM::NPC, Misc::StringUtils::CiHash, Misc::StringUtils::CiEqual>& npcs)
|
|
|
|
const std::string& getDefaultClass(const MWWorld::Store<ESM::Class>& classes)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Cache first class from store - we will use it if current class is not found
|
|
|
|
|
|
|
|
std::string defaultCls;
|
|
|
|
|
|
|
|
auto it = classes.begin();
|
|
|
|
auto it = classes.begin();
|
|
|
|
if (it != classes.end())
|
|
|
|
if (it != classes.end())
|
|
|
|
defaultCls = it->mId;
|
|
|
|
return it->mId;
|
|
|
|
else
|
|
|
|
|
|
|
|
throw std::runtime_error("List of NPC classes is empty!");
|
|
|
|
throw std::runtime_error("List of NPC classes is empty!");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<ESM::NPC> getNPCsToReplace(const MWWorld::Store<ESM::Faction>& factions, const MWWorld::Store<ESM::Class>& classes, const std::unordered_map<std::string, ESM::NPC, Misc::StringUtils::CiHash, Misc::StringUtils::CiEqual>& npcs)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Cache first class from store - we will use it if current class is not found
|
|
|
|
|
|
|
|
const std::string& defaultCls = getDefaultClass(classes);
|
|
|
|
|
|
|
|
|
|
|
|
// Validate NPCs for non-existing class and faction.
|
|
|
|
// Validate NPCs for non-existing class and faction.
|
|
|
|
// We will replace invalid entries by fixed ones
|
|
|
|
// We will replace invalid entries by fixed ones
|
|
|
@ -78,7 +81,7 @@ namespace
|
|
|
|
ESM::NPC npc = npcIter.second;
|
|
|
|
ESM::NPC npc = npcIter.second;
|
|
|
|
bool changed = false;
|
|
|
|
bool changed = false;
|
|
|
|
|
|
|
|
|
|
|
|
const std::string npcFaction = npc.mFaction;
|
|
|
|
const std::string& npcFaction = npc.mFaction;
|
|
|
|
if (!npcFaction.empty())
|
|
|
|
if (!npcFaction.empty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const ESM::Faction *fact = factions.search(npcFaction);
|
|
|
|
const ESM::Faction *fact = factions.search(npcFaction);
|
|
|
@ -91,9 +94,7 @@ namespace
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string npcClass = npc.mClass;
|
|
|
|
const std::string& npcClass = npc.mClass;
|
|
|
|
if (!npcClass.empty())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
const ESM::Class *cls = classes.search(npcClass);
|
|
|
|
const ESM::Class *cls = classes.search(npcClass);
|
|
|
|
if (!cls)
|
|
|
|
if (!cls)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -101,7 +102,6 @@ namespace
|
|
|
|
npc.mClass = defaultCls;
|
|
|
|
npc.mClass = defaultCls;
|
|
|
|
changed = true;
|
|
|
|
changed = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (changed)
|
|
|
|
if (changed)
|
|
|
|
npcsToReplace.push_back(npc);
|
|
|
|
npcsToReplace.push_back(npc);
|
|
|
|