aboutsummaryrefslogtreecommitdiffstats
path: root/qt-models/maplocationmodel.cpp
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2019-08-31 23:17:04 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-09-06 11:48:47 -0700
commit9322092e415946e212f94b3e0a4e330f4b7c07d6 (patch)
tree65e00af455a252f0ff35f4c80c0b3106c2ead214 /qt-models/maplocationmodel.cpp
parent4dd86cc205dd71bf1ee484f5dc8bfa3bccd94a59 (diff)
downloadsubsurface-9322092e415946e212f94b3e0a4e330f4b7c07d6.tar.gz
Cleanup: simplify role handling in MapLocationModel
To connect a model to QML, one is supposed to provide a QHash<int, QByteArray> MapLocationModel::roleNames() function that returns a role -> attribute-name hash. That was realized by filling the hash in the constructor, storing it as a member variable, using static strings that were declared in the class-definition and defined in the translation unit. Adding a new role was a pain and the whole thing was totally pointless as the attribute names were used nowhere else and the roleNames() function is called only once. Simply do, what we do everywhere else: initialize the hash in the roleNames() function and use normal string literals. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'qt-models/maplocationmodel.cpp')
-rw-r--r--qt-models/maplocationmodel.cpp19
1 files changed, 7 insertions, 12 deletions
diff --git a/qt-models/maplocationmodel.cpp b/qt-models/maplocationmodel.cpp
index 4ca4a3a53..57fc76179 100644
--- a/qt-models/maplocationmodel.cpp
+++ b/qt-models/maplocationmodel.cpp
@@ -10,12 +10,6 @@
#include <QDebug>
#include <algorithm>
-const char *MapLocation::PROPERTY_NAME_COORDINATE = "coordinate";
-const char *MapLocation::PROPERTY_NAME_DIVESITE = "divesite";
-const char *MapLocation::PROPERTY_NAME_NAME = "name";
-const char *MapLocation::PROPERTY_NAME_PIXMAP = "pixmap";
-const char *MapLocation::PROPERTY_NAME_Z = "z";
-
#define MIN_DISTANCE_BETWEEN_DIVE_SITES_M 50.0
MapLocation::MapLocation() : m_ds(nullptr), m_selected(false)
@@ -87,11 +81,6 @@ QVariant MapLocation::divesiteVariant()
MapLocationModel::MapLocationModel(QObject *parent) : QAbstractListModel(parent)
{
- m_roles[MapLocation::Roles::RoleDivesite] = MapLocation::PROPERTY_NAME_DIVESITE;
- m_roles[MapLocation::Roles::RoleCoordinate] = MapLocation::PROPERTY_NAME_COORDINATE;
- m_roles[MapLocation::Roles::RoleName] = MapLocation::PROPERTY_NAME_NAME;
- m_roles[MapLocation::Roles::RolePixmap] = MapLocation::PROPERTY_NAME_PIXMAP;
- m_roles[MapLocation::Roles::RoleZ] = MapLocation::PROPERTY_NAME_Z;
connect(&diveListNotifier, &DiveListNotifier::diveSiteChanged, this, &MapLocationModel::diveSiteChanged);
}
@@ -110,7 +99,13 @@ QVariant MapLocationModel::data(const QModelIndex & index, int role) const
QHash<int, QByteArray> MapLocationModel::roleNames() const
{
- return m_roles;
+ QHash<int, QByteArray> roles;
+ roles[MapLocation::Roles::RoleDivesite] = "divesite";
+ roles[MapLocation::Roles::RoleCoordinate] = "coordinate";
+ roles[MapLocation::Roles::RoleName] = "name";
+ roles[MapLocation::Roles::RolePixmap] = "pixmap";
+ roles[MapLocation::Roles::RoleZ] = "z";
+ return roles;
}
int MapLocationModel::rowCount(const QModelIndex&) const