diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-05-05 12:18:04 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-05-11 12:06:19 -0700 |
commit | 065423896dee0fe1cc6e2bd13e7e8d1b1cb3e181 (patch) | |
tree | 45b9664321b47bb2d4faae6d8fb233f6f6bd510a /qt-models/filtermodels.cpp | |
parent | cd5489e08d4c76b96ae0d388d9efea24134dde8d (diff) | |
download | subsurface-065423896dee0fe1cc6e2bd13e7e8d1b1cb3e181.tar.gz |
Filter: add reference counting for dive-site mode
The dive-site-edit and dive-site-table tabs both put the filter
into a special dive-site mode. When switching between both, it
could happen that the one got its show befor the other got
its hide event.
Thus, the first would start dive-site filtering and the second
stop it. Now the app was not in filter mode even though it should.
To solve this problem, add reference counting for the filter's
dive-site mode. In both tabs call the enter/exit functions
on show/hide. In the dive-site-table tab, when the selection
changes, use a set function that doesn't modify the reference count.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'qt-models/filtermodels.cpp')
-rw-r--r-- | qt-models/filtermodels.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/qt-models/filtermodels.cpp b/qt-models/filtermodels.cpp index bcadce613..ce0d5ff42 100644 --- a/qt-models/filtermodels.cpp +++ b/qt-models/filtermodels.cpp @@ -105,7 +105,8 @@ MultiFilterSortModel *MultiFilterSortModel::instance() } MultiFilterSortModel::MultiFilterSortModel(QObject *parent) : QSortFilterProxyModel(parent), - divesDisplayed(0) + divesDisplayed(0), + diveSiteRefCount(0) { setFilterKeyColumn(-1); // filter all columns setFilterCaseSensitivity(Qt::CaseInsensitive); @@ -269,15 +270,24 @@ void MultiFilterSortModel::clearFilter() void MultiFilterSortModel::startFilterDiveSites(QVector<dive_site *> ds) { dive_sites = ds; + ++diveSiteRefCount; myInvalidate(); } void MultiFilterSortModel::stopFilterDiveSites() { + if (--diveSiteRefCount > 0) + return; dive_sites.clear(); myInvalidate(); } +void MultiFilterSortModel::setFilterDiveSite(QVector<dive_site *> ds) +{ + dive_sites = ds; + myInvalidate(); +} + const QVector<dive_site *> &MultiFilterSortModel::filteredDiveSites() const { return dive_sites; |