QItemSelectionModel: replace a QPair with a dedicated struct

Pairs are easy to use, but they have no semantics attached: Two
QPair<int, int> compare equal, e.g., even though one is used as a
coordinate and the other as, say, a fraction. It also carries no
information for the reader of the code, as exemplified by the urge to
comment on the content of the pairs in both functions that use them.

So, write a minimal struct with equality and qHash() instead. The
comments are now no longer needed.

Change-Id: I51f6ff049a5f8fa61c51856376ac2fcbfb8dd506
Reviewed-by: David Faure <david.faure@kdab.com>
This commit is contained in:
Marc Mutz 2020-05-03 19:25:38 +02:00
parent 2eee9e6fcf
commit a6a412dbb6

View File

@ -1721,6 +1721,23 @@ QModelIndexList QItemSelectionModel::selectedIndexes() const
return selected.indexes(); return selected.indexes();
} }
struct RowOrColumnDefinition {
QModelIndex parent;
int rowOrColumn;
friend bool operator==(const RowOrColumnDefinition &lhs, const RowOrColumnDefinition &rhs) noexcept
{ return lhs.parent == rhs.parent && lhs.rowOrColumn == rhs.rowOrColumn; }
friend bool operator!=(const RowOrColumnDefinition &lhs, const RowOrColumnDefinition &rhs) noexcept
{ return !operator==(lhs, rhs); }
};
size_t qHash(const RowOrColumnDefinition &key, size_t seed = 0) noexcept
{
QtPrivate::QHashCombine hash;
seed = hash(seed, key.parent);
seed = hash(seed, key.rowOrColumn);
return seed;
}
/*! /*!
\since 4.2 \since 4.2
Returns the indexes in the given \a column for the rows where all columns are selected. Returns the indexes in the given \a column for the rows where all columns are selected.
@ -1731,16 +1748,15 @@ QModelIndexList QItemSelectionModel::selectedIndexes() const
QModelIndexList QItemSelectionModel::selectedRows(int column) const QModelIndexList QItemSelectionModel::selectedRows(int column) const
{ {
QModelIndexList indexes; QModelIndexList indexes;
//the QSet contains pairs of parent modelIndex
//and row number QSet<RowOrColumnDefinition> rowsSeen;
QSet< QPair<QModelIndex, int> > rowsSeen;
const QItemSelection ranges = selection(); const QItemSelection ranges = selection();
for (int i = 0; i < ranges.count(); ++i) { for (int i = 0; i < ranges.count(); ++i) {
const QItemSelectionRange &range = ranges.at(i); const QItemSelectionRange &range = ranges.at(i);
QModelIndex parent = range.parent(); QModelIndex parent = range.parent();
for (int row = range.top(); row <= range.bottom(); row++) { for (int row = range.top(); row <= range.bottom(); row++) {
QPair<QModelIndex, int> rowDef = qMakePair(parent, row); RowOrColumnDefinition rowDef = {parent, row};
if (!rowsSeen.contains(rowDef)) { if (!rowsSeen.contains(rowDef)) {
rowsSeen << rowDef; rowsSeen << rowDef;
if (isRowSelected(row, parent)) { if (isRowSelected(row, parent)) {
@ -1763,16 +1779,15 @@ QModelIndexList QItemSelectionModel::selectedRows(int column) const
QModelIndexList QItemSelectionModel::selectedColumns(int row) const QModelIndexList QItemSelectionModel::selectedColumns(int row) const
{ {
QModelIndexList indexes; QModelIndexList indexes;
//the QSet contains pairs of parent modelIndex
//and column number QSet<RowOrColumnDefinition> columnsSeen;
QSet< QPair<QModelIndex, int> > columnsSeen;
const QItemSelection ranges = selection(); const QItemSelection ranges = selection();
for (int i = 0; i < ranges.count(); ++i) { for (int i = 0; i < ranges.count(); ++i) {
const QItemSelectionRange &range = ranges.at(i); const QItemSelectionRange &range = ranges.at(i);
QModelIndex parent = range.parent(); QModelIndex parent = range.parent();
for (int column = range.left(); column <= range.right(); column++) { for (int column = range.left(); column <= range.right(); column++) {
QPair<QModelIndex, int> columnDef = qMakePair(parent, column); RowOrColumnDefinition columnDef = {parent, column};
if (!columnsSeen.contains(columnDef)) { if (!columnsSeen.contains(columnDef)) {
columnsSeen << columnDef; columnsSeen << columnDef;
if (isColumnSelected(column, parent)) { if (isColumnSelected(column, parent)) {