summaryrefslogtreecommitdiffstats
path: root/qt-models
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2018-07-29 17:40:53 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-07-30 12:21:17 -0700
commit4bdd811f06096c2420a05dd3cc78fffbd7f3a663 (patch)
treec263a6b92a517d21c160d7c43439d2804423db88 /qt-models
parent5e1e6110ce50b33e24667ce83ab5d2417a2a466e (diff)
downloadsubsurface-4bdd811f06096c2420a05dd3cc78fffbd7f3a663.tar.gz
Cleanup: remove DiveListView::fixMessyQtModelBehaviour()
The function DiveListView::fixMessyQtModelBehaviour() was used to expand the first columns of dive-trips in the dive-list view. This function was called everytime that the dive-list was modified. It is kind of ludicrous that external callers would have to tell the DiveListView, when it has to update its column headers. Instead, place this functionality in the overriden reset() and rowsInserted() functions, as these are the only ways that rows can be added. Change the DiveTripModel to use the proper beginResetModel()/endResetModel() pair instead of the previous full deletion and full repopulation using the beginRemoveRows()/ endRemoveRows() and beginInsertRows()/endInsertRows(). Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'qt-models')
-rw-r--r--qt-models/divetripmodel.cpp10
-rw-r--r--qt-models/filtermodels.cpp1
2 files changed, 2 insertions, 9 deletions
diff --git a/qt-models/divetripmodel.cpp b/qt-models/divetripmodel.cpp
index fd8a2f08a..384da6b89 100644
--- a/qt-models/divetripmodel.cpp
+++ b/qt-models/divetripmodel.cpp
@@ -584,10 +584,7 @@ void DiveTripModel::setupModelData()
{
int i = dive_table.nr;
- if (rowCount()) {
- beginRemoveRows(QModelIndex(), 0, rowCount() - 1);
- endRemoveRows();
- }
+ beginResetModel();
if (autogroup)
autogroup_dives();
@@ -621,10 +618,7 @@ void DiveTripModel::setupModelData()
tripItem->children.push_back(diveItem);
}
- if (rowCount()) {
- beginInsertRows(QModelIndex(), 0, rowCount() - 1);
- endInsertRows();
- }
+ endResetModel();
}
DiveTripModel::Layout DiveTripModel::layout() const
diff --git a/qt-models/filtermodels.cpp b/qt-models/filtermodels.cpp
index 34345f381..12d755dc1 100644
--- a/qt-models/filtermodels.cpp
+++ b/qt-models/filtermodels.cpp
@@ -430,7 +430,6 @@ void MultiFilterSortModel::myInvalidate()
divesDisplayed = 0;
invalidateFilter();
- MainWindow::instance()->dive_list()->fixMessyQtModelBehaviour();
// first make sure the trips are no longer shown as selected
// (but without updating the selection state of the dives... this just cleans