diff options
author | Tomaz Canabrava <tomaz.canabrava@intel.com> | 2015-05-28 15:00:58 -0300 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-05-29 14:08:36 -0700 |
commit | 6e4aa7d044a344527e61f17c2254851ba799c4bd (patch) | |
tree | 1c0d4efddf9a9fc617f6a62789fd8aa48c1a125a | |
parent | 338c0f22aabefcfd5a5e87fceb4c82e73af3f5a9 (diff) | |
download | subsurface-6e4aa7d044a344527e61f17c2254851ba799c4bd.tar.gz |
Move CleanerTableModel to its own file
models.h / .cpp was getting too big (around 2.5k lines), and each change
triggered a rebuild in tons of parts of Subsurface, this is the first
commit trying to make the models code sane by removing them all of the
models.h/cpp file and also clearning code in the process.
Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | CMakeLists.txt | 1 | ||||
-rw-r--r-- | qt-models/cleanertablemodel.cpp | 33 | ||||
-rw-r--r-- | qt-models/cleanertablemodel.h | 27 | ||||
-rw-r--r-- | qt-models/models.cpp | 32 | ||||
-rw-r--r-- | qt-models/models.h | 16 |
5 files changed, 63 insertions, 46 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index 6b036164e..d6a1260e5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -247,6 +247,7 @@ endif() # the data models that will interface # with the views. set(SUBSURFACE_MODELS_LIB_SRCS + qt-models/cleanertablemodel.cpp qt-models/models.cpp qt-models/filtermodels.cpp qt-models/completionmodels.cpp diff --git a/qt-models/cleanertablemodel.cpp b/qt-models/cleanertablemodel.cpp new file mode 100644 index 000000000..d2405d42f --- /dev/null +++ b/qt-models/cleanertablemodel.cpp @@ -0,0 +1,33 @@ +#include "cleanertablemodel.h" +#include "metrics.h" + +CleanerTableModel::CleanerTableModel(QObject *parent) : QAbstractTableModel(parent) +{ +} + +int CleanerTableModel::columnCount(const QModelIndex &parent) const +{ + return headers.count(); +} + +QVariant CleanerTableModel::headerData(int section, Qt::Orientation orientation, int role) const +{ + QVariant ret; + + if (orientation == Qt::Vertical) + return ret; + + switch (role) { + case Qt::FontRole: + ret = defaultModelFont(); + break; + case Qt::DisplayRole: + ret = headers.at(section); + } + return ret; +} + +void CleanerTableModel::setHeaderDataStrings(const QStringList &newHeaders) +{ + headers = newHeaders; +} diff --git a/qt-models/cleanertablemodel.h b/qt-models/cleanertablemodel.h new file mode 100644 index 000000000..a717d7032 --- /dev/null +++ b/qt-models/cleanertablemodel.h @@ -0,0 +1,27 @@ +#ifndef CLEANERTABLEMODEL_H +#define CLEANERTABLEMODEL_H + +#include <QAbstractTableModel> +#include <QStringList> + +/* When using a QAbstractTableModel, consider using this instead + * of the default implementation, as it's easyer to setup the columns + * and headers. + * Most subsurface classes uses this one to save loads of lines + * of code and share a consistent layout. */ + +class CleanerTableModel : public QAbstractTableModel { + Q_OBJECT +public: + explicit CleanerTableModel(QObject *parent = 0); + virtual int columnCount(const QModelIndex &parent = QModelIndex()) const; + virtual QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const; + +protected: + void setHeaderDataStrings(const QStringList &headers); + +private: + QStringList headers; +}; + +#endif diff --git a/qt-models/models.cpp b/qt-models/models.cpp index 69a276bfb..637a2d3b1 100644 --- a/qt-models/models.cpp +++ b/qt-models/models.cpp @@ -15,6 +15,7 @@ #include "gettextfromc.h" #include "display.h" #include "color.h" +#include "cleanertablemodel.h" #include <QCoreApplication> #include <QDebug> @@ -27,37 +28,6 @@ #include <QMessageBox> #include <QStringListModel> -CleanerTableModel::CleanerTableModel(QObject *parent) : QAbstractTableModel(parent) -{ -} - -int CleanerTableModel::columnCount(const QModelIndex &parent) const -{ - return headers.count(); -} - -QVariant CleanerTableModel::headerData(int section, Qt::Orientation orientation, int role) const -{ - QVariant ret; - - if (orientation == Qt::Vertical) - return ret; - - switch (role) { - case Qt::FontRole: - ret = defaultModelFont(); - break; - case Qt::DisplayRole: - ret = headers.at(section); - } - return ret; -} - -void CleanerTableModel::setHeaderDataStrings(const QStringList &newHeaders) -{ - headers = newHeaders; -} - static QPixmap *trashIconPixmap; // initialize the trash icon if necessary diff --git a/qt-models/models.h b/qt-models/models.h index 0123ce171..60b83cd95 100644 --- a/qt-models/models.h +++ b/qt-models/models.h @@ -18,21 +18,7 @@ #include "../dive.h" #include "../divelist.h" #include "../divecomputer.h" - -// Encapsulates Boilerplate. -class CleanerTableModel : public QAbstractTableModel { - Q_OBJECT -public: - explicit CleanerTableModel(QObject *parent = 0); - virtual int columnCount(const QModelIndex &parent = QModelIndex()) const; - virtual QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const; - -protected: - void setHeaderDataStrings(const QStringList &headers); - -private: - QStringList headers; -}; +#include "cleanertablemodel.h" /* Encapsulates the tank_info global variable * to show on Qt's Model View System.*/ |