summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@gmail.com>2015-05-31 17:56:53 -0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-05-31 16:02:35 -0700
commit6d9206150a9d0d9496542ab6c4a12d8a41a8f596 (patch)
treeb086c3ca500b54a8fe164cc5a6ba2c4ba7c2be28
parent7129cef66fa4d335d70e6d64ce9cb03f89b3610f (diff)
downloadsubsurface-6d9206150a9d0d9496542ab6c4a12d8a41a8f596.tar.gz
Organize the dive_sites alphabetically
run std::sort on the dive_site list inside of the model. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-models/divelocationmodel.cpp7
-rw-r--r--qt-ui/locationinformation.cpp8
2 files changed, 8 insertions, 7 deletions
diff --git a/qt-models/divelocationmodel.cpp b/qt-models/divelocationmodel.cpp
index 21c3127ca..c335f7039 100644
--- a/qt-models/divelocationmodel.cpp
+++ b/qt-models/divelocationmodel.cpp
@@ -1,6 +1,11 @@
#include "divelocationmodel.h"
#include "dive.h"
+bool dive_site_less_then(dive_site *a, dive_site *b)
+{
+ return QString(a->name) <= QString(b->name);
+}
+
LocationInformationModel *LocationInformationModel::instance()
{
static LocationInformationModel *self = new LocationInformationModel();
@@ -33,7 +38,6 @@ QVariant LocationInformationModel::data(const QModelIndex &index, int role) cons
void LocationInformationModel::update()
{
-
if (rowCount()) {
beginRemoveRows(QModelIndex(), 0, rowCount()-1);
endRemoveRows();
@@ -41,6 +45,7 @@ void LocationInformationModel::update()
if (dive_site_table.nr) {
beginInsertRows(QModelIndex(), 0, dive_site_table.nr);
internalRowCount = dive_site_table.nr;
+ std::sort(dive_site_table.dive_sites, dive_site_table.dive_sites + dive_site_table.nr - 1, dive_site_less_then);
endInsertRows();
}
}
diff --git a/qt-ui/locationinformation.cpp b/qt-ui/locationinformation.cpp
index 6dc77c571..699b80d47 100644
--- a/qt-ui/locationinformation.cpp
+++ b/qt-ui/locationinformation.cpp
@@ -45,11 +45,6 @@ void LocationInformationWidget::setCurrentDiveSite(int dive_nr)
void LocationInformationWidget::setLocationId(uint32_t uuid)
{
- LocationInformationModel *m = (LocationInformationModel*) ui.currentLocation->model();
- if (m->rowCount() == 0) {
- m->update();
- }
-
currentDs = get_dive_site_by_uuid(uuid);
if(!currentDs)
return;
@@ -138,7 +133,8 @@ void LocationInformationWidget::rejectChanges()
void LocationInformationWidget::showEvent(QShowEvent *ev)
{
- emit startFilterDiveSite(displayed_dive_site.uuid);
+ if (displayed_dive_site.uuid)
+ emit startFilterDiveSite(displayed_dive_site.uuid);
ui.diveSiteMessage->setCloseButtonVisible(false);
QGroupBox::showEvent(ev);
}