From f4e6df475e1cfd93dc0d73287ec6a5113b5eb176 Mon Sep 17 00:00:00 2001 From: "Lubomir I. Ivanov" Date: Mon, 17 Jul 2017 22:12:04 +0300 Subject: [PATCH] maplocationmodel: implement the clear() and add() methods - add() will be used to add a MapLocation to the model with beginInsertRows()...endInsertRows() - clear() will be used to clear the model with beginRemoveRows()... endRemoveRows() NOTE: emiting dataChanged() does not seem to update the QML view for this model so calling being<..>Rows() seems to be the "correct Qt approach" to do this. Signed-off-by: Lubomir I. Ivanov --- qt-models/maplocationmodel.cpp | 19 ++++++++++++++++++- qt-models/maplocationmodel.h | 2 ++ 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/qt-models/maplocationmodel.cpp b/qt-models/maplocationmodel.cpp index 5da0733e1..43f28c981 100644 --- a/qt-models/maplocationmodel.cpp +++ b/qt-models/maplocationmodel.cpp @@ -30,7 +30,7 @@ MapLocationModel::MapLocationModel(QObject *parent) : QAbstractListModel(parent) MapLocationModel::~MapLocationModel() { - qDeleteAll(m_mapLocations); + clear(); } QVariant MapLocationModel::data( const QModelIndex & index, int role ) const @@ -63,3 +63,20 @@ MapLocation *MapLocationModel::get(int row) return NULL; return m_mapLocations.at(row); } + +void MapLocationModel::add(MapLocation *location) +{ + beginInsertRows(QModelIndex(), m_mapLocations.size(), m_mapLocations.size()); + m_mapLocations.append(location); + endInsertRows(); +} + +void MapLocationModel::clear() +{ + if (!m_mapLocations.size()) + return; + beginRemoveRows(QModelIndex(), 0, m_mapLocations.size() - 1); + qDeleteAll(m_mapLocations); + m_mapLocations.clear(); + endRemoveRows(); +} diff --git a/qt-models/maplocationmodel.h b/qt-models/maplocationmodel.h index e398a8091..8dff65eac 100644 --- a/qt-models/maplocationmodel.h +++ b/qt-models/maplocationmodel.h @@ -44,6 +44,8 @@ public: QVariant data(const QModelIndex &index, int role) const override; int rowCount(const QModelIndex &parent) const override; int count(); + void add(MapLocation *); + void clear(); protected: QHash roleNames() const;