Avoid redundant conversion to lower case for CommandDispatcher::mSelection items

depth-refraction
elsid 2 years ago
parent 7daef583cb
commit 191f207e78
No known key found for this signature in database
GPG Key ID: 4DE04C198CBA7625

@ -113,11 +113,7 @@ void CSMWorld::CommandDispatcher::setEditLock(bool locked)
void CSMWorld::CommandDispatcher::setSelection(const std::vector<std::string>& selection) void CSMWorld::CommandDispatcher::setSelection(const std::vector<std::string>& selection)
{ {
mSelection = selection; mSelection = selection;
for (auto& sel : mSelection) std::sort(mSelection.begin(), mSelection.end(), Misc::StringUtils::CiComp{});
{
Misc::StringUtils::lowerCaseInPlace(sel);
}
std::sort(mSelection.begin(), mSelection.end());
} }
void CSMWorld::CommandDispatcher::setExtendedTypes(const std::vector<UniversalId>& types) void CSMWorld::CommandDispatcher::setExtendedTypes(const std::vector<UniversalId>& types)
@ -290,8 +286,7 @@ void CSMWorld::CommandDispatcher::executeExtendedDelete()
if (record.mState == RecordBase::State_Deleted) if (record.mState == RecordBase::State_Deleted)
continue; continue;
if (!std::binary_search(mSelection.begin(), mSelection.end(), if (!std::binary_search(mSelection.begin(), mSelection.end(), record.get().mCell))
Misc::StringUtils::lowerCase(record.get().mCell.getRefIdString())))
continue; continue;
macro.push(new CSMWorld::DeleteCommand(model, record.get().mId.getRefIdString())); macro.push(new CSMWorld::DeleteCommand(model, record.get().mId.getRefIdString()));
@ -321,8 +316,7 @@ void CSMWorld::CommandDispatcher::executeExtendedRevert()
{ {
const Record<CellRef>& record = collection.getRecord(i); const Record<CellRef>& record = collection.getRecord(i);
if (!std::binary_search(mSelection.begin(), mSelection.end(), if (!std::binary_search(mSelection.begin(), mSelection.end(), record.get().mCell))
Misc::StringUtils::lowerCase(record.get().mCell.getRefIdString())))
continue; continue;
macro.push(new CSMWorld::RevertCommand(model, record.get().mId.getRefIdString())); macro.push(new CSMWorld::RevertCommand(model, record.get().mId.getRefIdString()));

Loading…
Cancel
Save