summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Boris Barbulovski <bbarbulovski@gmail.com>2014-02-11 18:46:14 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-02-11 12:36:45 -0800
commit507a929a27d31eaf077437674e6ec3cdaaed34d2 (patch)
tree5aa79a268e7359d7a384d03caba656111332e992
parentaf8c44fa22ef6fca6a06fe4ad9e8af949a137458 (diff)
downloadsubsurface-507a929a27d31eaf077437674e6ec3cdaaed34d2.tar.gz
Migrate MainTab models(QStringListModel)
Migrate MainTab models from static xxxCompletioModel::instance() to private MainTab variable members. Signed-off-by: Boris Barbulovski <bbarbulovski@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/completionmodels.cpp15
-rw-r--r--qt-ui/completionmodels.h5
-rw-r--r--qt-ui/maintab.cpp20
-rw-r--r--qt-ui/maintab.h7
4 files changed, 17 insertions, 30 deletions
diff --git a/qt-ui/completionmodels.cpp b/qt-ui/completionmodels.cpp
index 8ccab3f2f..b0a5db2d3 100644
--- a/qt-ui/completionmodels.cpp
+++ b/qt-ui/completionmodels.cpp
@@ -2,21 +2,6 @@
#include "dive.h"
#include "mainwindow.h"
-#define CREATE_SINGLETON(X) \
-X* X::instance() \
-{ \
- static QScopedPointer<X> self(new X()); \
- return self.data(); \
-}
-
-CREATE_SINGLETON(BuddyCompletionModel);
-CREATE_SINGLETON(DiveMasterCompletionModel);
-CREATE_SINGLETON(LocationCompletionModel);
-CREATE_SINGLETON(SuitCompletionModel);
-CREATE_SINGLETON(TagCompletionModel);
-
-#undef CREATE_SINGLETON
-
#define CREATE_UPDATE_METHOD(Class, diveStructMember) \
void Class::updateModel() \
{ \
diff --git a/qt-ui/completionmodels.h b/qt-ui/completionmodels.h
index 146186531..2ac9f17a1 100644
--- a/qt-ui/completionmodels.h
+++ b/qt-ui/completionmodels.h
@@ -6,35 +6,30 @@
class BuddyCompletionModel : public QStringListModel {
Q_OBJECT
public:
- static BuddyCompletionModel* instance();
void updateModel();
};
class DiveMasterCompletionModel : public QStringListModel {
Q_OBJECT
public:
- static DiveMasterCompletionModel* instance();
void updateModel();
};
class LocationCompletionModel : public QStringListModel {
Q_OBJECT
public:
- static LocationCompletionModel* instance();
void updateModel();
};
class SuitCompletionModel : public QStringListModel {
Q_OBJECT
public:
- static SuitCompletionModel* instance();
void updateModel();
};
class TagCompletionModel : public QStringListModel {
Q_OBJECT
public:
- static TagCompletionModel* instance();
void updateModel();
};
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 0aa683dcb..bdaddb827 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -89,11 +89,11 @@ MainTab::MainTab(QWidget *parent) : QTabWidget(parent),
ui.weights->view()->setItemDelegateForColumn(WeightModel::TYPE, new WSInfoDelegate(this));
// disabled as this column is pointless outside the disabled planner
// ui.cylinders->view()->setColumnHidden(CylindersModel::DEPTH, true);
- completers.buddy = new QCompleter(BuddyCompletionModel::instance(), ui.buddy);
- completers.divemaster = new QCompleter(DiveMasterCompletionModel::instance(), ui.divemaster);
- completers.location = new QCompleter(LocationCompletionModel::instance(), ui.location);
- completers.suit = new QCompleter(SuitCompletionModel::instance(), ui.suit);
- completers.tags = new QCompleter(TagCompletionModel::instance(), ui.tagWidget);
+ completers.buddy = new QCompleter(&buddyModel, ui.buddy);
+ completers.divemaster = new QCompleter(&diveMasterModel, ui.divemaster);
+ completers.location = new QCompleter(&locationModel, ui.location);
+ completers.suit = new QCompleter(&suitModel, ui.suit);
+ completers.tags = new QCompleter(&tagModel, ui.tagWidget);
completers.buddy->setCaseSensitivity(Qt::CaseInsensitive);
completers.divemaster->setCaseSensitivity(Qt::CaseInsensitive);
completers.location->setCaseSensitivity(Qt::CaseInsensitive);
@@ -563,11 +563,11 @@ void MainTab::addWeight_clicked()
void MainTab::reload()
{
- SuitCompletionModel::instance()->updateModel();
- BuddyCompletionModel::instance()->updateModel();
- LocationCompletionModel::instance()->updateModel();
- DiveMasterCompletionModel::instance()->updateModel();
- TagCompletionModel::instance()->updateModel();
+ suitModel.updateModel();
+ buddyModel.updateModel();
+ locationModel.updateModel();
+ diveMasterModel.updateModel();
+ tagModel.updateModel();
}
void MainTab::acceptChanges()
diff --git a/qt-ui/maintab.h b/qt-ui/maintab.h
index c5afd2f55..1edeebab6 100644
--- a/qt-ui/maintab.h
+++ b/qt-ui/maintab.h
@@ -13,6 +13,7 @@
#include "models.h"
#include "ui_maintab.h"
+#include "completionmodels.h"
class QCompleter;
struct dive;
@@ -94,6 +95,12 @@ private:
QMap<dive*, NotesBackup> notesBackup;
EditMode editMode;
+ BuddyCompletionModel buddyModel;
+ DiveMasterCompletionModel diveMasterModel;
+ LocationCompletionModel locationModel;
+ SuitCompletionModel suitModel;
+ TagCompletionModel tagModel;
+
/* since the multi-edition of the equipment is fairly more
* complex than a single item, because it involves a Qt
* Model to edit things, we are copying the first selected