Correct comparison of enum values in IdTableProxyModel

This commit is contained in:
Stanislav Bas 2015-08-03 19:24:00 +03:00
parent 06f170a8e1
commit 8da9eecea7

View file

@ -5,6 +5,18 @@
#include "idtablebase.hpp" #include "idtablebase.hpp"
namespace
{
std::string getEnumValue(const std::vector<std::string> &values, int index)
{
if (index < 0 || index >= static_cast<int>(values.size()))
{
return "";
}
return values[index];
}
}
void CSMWorld::IdTableProxyModel::updateColumnMap() void CSMWorld::IdTableProxyModel::updateColumnMap()
{ {
Q_ASSERT(mSourceModel != NULL); Q_ASSERT(mSourceModel != NULL);
@ -93,7 +105,9 @@ bool CSMWorld::IdTableProxyModel::lessThan(const QModelIndex &left, const QModel
if (valuesIt != mEnumColumnCache.end()) if (valuesIt != mEnumColumnCache.end())
{ {
return valuesIt->second[left.data().toInt()] < valuesIt->second[right.data().toInt()]; std::string first = getEnumValue(valuesIt->second, left.data().toInt());
std::string second = getEnumValue(valuesIt->second, right.data().toInt());
return first < second;
} }
return QSortFilterProxyModel::lessThan(left, right); return QSortFilterProxyModel::lessThan(left, right);
} }