From 376f6d51a9fdc0b85f13b00b2d1344dc7162427e Mon Sep 17 00:00:00 2001
From: Tomaz Canabrava <tomaz.canabrava@gmail.com>
Date: Fri, 29 May 2015 21:19:44 -0300
Subject: [PATCH 3/7] LocationInformationModel moved to qt-models

I forgot about this one, and we are going to use it
in the mobile version too.

Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com>
---
 CMakeLists.txt                  |  4 ++--
 qt-models/divelocationmodel.cpp | 42 +++++++++++++++++++++++++++++++++++++++++
 qt-models/divelocationmodel.h   | 17 +++++++++++++++++
 qt-ui/locationinformation.cpp   | 42 +----------------------------------------
 qt-ui/locationinformation.h     | 11 -----------
 5 files changed, 62 insertions(+), 54 deletions(-)
 create mode 100644 qt-models/divelocationmodel.cpp
 create mode 100644 qt-models/divelocationmodel.h

diff --git a/CMakeLists.txt b/CMakeLists.txt
index 6f98692..bc4a4a2 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -264,8 +264,8 @@ set(SUBSURFACE_MODELS_LIB_SRCS
 	qt-models/completionmodels.cpp
 	qt-models/profileprintmodel.cpp
 	qt-models/divepicturemodel.cpp
-        qt-models/diveplotdatamodel.cpp
-
+	qt-models/diveplotdatamodel.cpp
+	qt-models/divelocationmodel.cpp
 )
 source_group("Subsurface Models" FILES ${SUBSURFACE_MODELS})
 
diff --git a/qt-models/divelocationmodel.cpp b/qt-models/divelocationmodel.cpp
new file mode 100644
index 0000000..a5303da
--- /dev/null
+++ b/qt-models/divelocationmodel.cpp
@@ -0,0 +1,42 @@
+#include "divelocationmodel.h"
+#include "dive.h"
+
+LocationInformationModel::LocationInformationModel(QObject *obj) : QAbstractListModel(obj), internalRowCount(0)
+{
+}
+
+int LocationInformationModel::rowCount(const QModelIndex &parent) const
+{
+	Q_UNUSED(parent);
+	return internalRowCount;
+}
+
+QVariant LocationInformationModel::data(const QModelIndex &index, int role) const
+{
+	if (!index.isValid())
+		return QVariant();
+	struct dive_site *ds = get_dive_site(index.row());
+
+	switch(role) {
+		case Qt::DisplayRole : return qPrintable(ds->name);
+	}
+
+	return QVariant();
+}
+
+void LocationInformationModel::update()
+{
+	int i;
+	struct dive_site *ds;
+	for_each_dive_site (i, ds);
+
+	if (rowCount()) {
+		beginRemoveRows(QModelIndex(), 0, rowCount()-1);
+		endRemoveRows();
+	}
+	if (i) {
+		beginInsertRows(QModelIndex(), 0, i);
+		internalRowCount = i;
+		endInsertRows();
+	}
+}
diff --git a/qt-models/divelocationmodel.h b/qt-models/divelocationmodel.h
new file mode 100644
index 0000000..1bf7ced
--- /dev/null
+++ b/qt-models/divelocationmodel.h
@@ -0,0 +1,17 @@
+#ifndef DIVELOCATIONMODEL_H
+#define DIVELOCATIONMODEL_H
+
+#include <QAbstractListModel>
+
+class LocationInformationModel : public QAbstractListModel {
+Q_OBJECT
+public:
+	LocationInformationModel(QObject *obj = 0);
+	int rowCount(const QModelIndex &parent = QModelIndex()) const;
+	QVariant data(const QModelIndex &index = QModelIndex(), int role = Qt::DisplayRole) const;
+	void update();
+private:
+	int internalRowCount;
+};
+
+#endif
diff --git a/qt-ui/locationinformation.cpp b/qt-ui/locationinformation.cpp
index e2fa846..1ba7fd4 100644
--- a/qt-ui/locationinformation.cpp
+++ b/qt-ui/locationinformation.cpp
@@ -5,50 +5,10 @@
 #include "qthelper.h"
 #include "globe.h"
 #include "filtermodels.h"
-
+#include "divelocationmodel.h"
 #include <QDebug>
 #include <QShowEvent>
 
-LocationInformationModel::LocationInformationModel(QObject *obj) : QAbstractListModel(obj), internalRowCount(0)
-{
-}
-
-int LocationInformationModel::rowCount(const QModelIndex &parent) const
-{
-	Q_UNUSED(parent);
-	return internalRowCount;
-}
-
-QVariant LocationInformationModel::data(const QModelIndex &index, int role) const
-{
-	if (!index.isValid())
-		return QVariant();
-	struct dive_site *ds = get_dive_site(index.row());
-
-	switch(role) {
-		case Qt::DisplayRole : return qPrintable(ds->name);
-	}
-
-	return QVariant();
-}
-
-void LocationInformationModel::update()
-{
-	int i;
-	struct dive_site *ds;
-	for_each_dive_site (i, ds);
-
-	if (rowCount()) {
-		beginRemoveRows(QModelIndex(), 0, rowCount()-1);
-		endRemoveRows();
-	}
-	if (i) {
-		beginInsertRows(QModelIndex(), 0, i);
-		internalRowCount = i;
-		endInsertRows();
-	}
-}
-
 LocationInformationWidget::LocationInformationWidget(QWidget *parent) : QGroupBox(parent), modified(false)
 {
 	ui.setupUi(this);
diff --git a/qt-ui/locationinformation.h b/qt-ui/locationinformation.h
index 1fb6e8d..2a34512 100644
--- a/qt-ui/locationinformation.h
+++ b/qt-ui/locationinformation.h
@@ -5,17 +5,6 @@
 #include <stdint.h>
 #include <QAbstractListModel>
 
-class LocationInformationModel : public QAbstractListModel {
-Q_OBJECT
-public:
-	LocationInformationModel(QObject *obj = 0);
-	int rowCount(const QModelIndex &parent = QModelIndex()) const;
-	QVariant data(const QModelIndex &index = QModelIndex(), int role = Qt::DisplayRole) const;
-	void update();
-private:
-	int internalRowCount;
-};
-
 class LocationInformationWidget : public QGroupBox {
 Q_OBJECT
 public:
-- 
2.3.2 (Apple Git-55)

