diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2014-01-07 22:10:41 +0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-01-07 22:10:41 +0800 |
commit | 409c2e9bcfd8a3f328e21b511919cc70629cc1ab (patch) | |
tree | cfd247a14fe71ea2d6c1f985673d87b671074f2b /qt-ui | |
parent | a8db19f54829880c222b749394c70cef31d5fb6f (diff) | |
download | subsurface-409c2e9bcfd8a3f328e21b511919cc70629cc1ab.tar.gz |
Not everything can be done with the diveId
In commit c3fe1a9e9f79 ("Get rid of pointers to dive structures in the
UI") I was a bit too aggressive moving away from pointers to dives.
This is only needed for pointers that are held across operations that
could change the dive_table. I figured that it wouldn't hurt to get rid of
some more pointers as well, but it turns out I was wrong. The current dive
that we store in the Cylinder and Weight models can be a dive that isn't
in the dive_table at all: the multiEditEquipmentPlaceholder. And when
using the diveId we end up finding the original dive in the dive_table and
therefore modify the wrong structure.
This undoes two thirds of the above mentioned commit.
Reported-and-analyzed-by: Patrick Valsecchi <patrick@thus.ch>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui')
-rw-r--r-- | qt-ui/models.cpp | 32 | ||||
-rw-r--r-- | qt-ui/models.h | 4 |
2 files changed, 6 insertions, 30 deletions
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp index 685d64505..c2b324f97 100644 --- a/qt-ui/models.cpp +++ b/qt-ui/models.cpp @@ -62,7 +62,7 @@ void CleanerTableModel::setHeaderDataStrings(const QStringList& newHeaders) headers = newHeaders; } -CylindersModel::CylindersModel(QObject* parent): currentId(0), rows(0) +CylindersModel::CylindersModel(QObject* parent): current(0), rows(0) { // enum{REMOVE, TYPE, SIZE, WORKINGPRESS, START, END, O2, HE, DEPTH}; setHeaderDataStrings( QStringList() << "" << tr("Type") << tr("Size") << tr("WorkPress") << tr("StartPress") << tr("EndPress") << trUtf8("O" UTF8_SUBSCRIPT_2 "%") << tr("He%") << tr("Switch at")); @@ -90,8 +90,6 @@ QVariant CylindersModel::data(const QModelIndex& index, int role) const if (!index.isValid() || index.row() >= MAX_CYLINDERS) return ret; - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); cylinder_t *cyl = ¤t->cylinder[index.row()]; switch (role) { case Qt::FontRole: { @@ -159,8 +157,6 @@ QVariant CylindersModel::data(const QModelIndex& index, int role) const cylinder_t* CylindersModel::cylinderAt(const QModelIndex& index) { - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); return ¤t->cylinder[index.row()]; } @@ -318,8 +314,6 @@ void CylindersModel::add() } int row = rows; - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); fill_default_cylinder(¤t->cylinder[row]); beginInsertRows(QModelIndex(), row, row); rows++; @@ -329,8 +323,6 @@ void CylindersModel::add() void CylindersModel::update() { - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); setDive(current); } @@ -344,7 +336,6 @@ void CylindersModel::clear() void CylindersModel::setDive(dive* d) { - struct dive *current = getDiveById(currentId); if (current) clear(); if (!d) @@ -355,7 +346,7 @@ void CylindersModel::setDive(dive* d) rows = i+1; } } - currentId = d->id; + current = d; changed = false; if (rows > 0) { beginInsertRows(QModelIndex(), 0, rows-1); @@ -375,8 +366,6 @@ void CylindersModel::remove(const QModelIndex& index) if (index.column() != REMOVE) { return; } - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); cylinder_t *cyl = ¤t->cylinder[index.row()]; if (DivePlannerPointsModel::instance()->tankInUse(cyl->gasmix.o2.permille, cyl->gasmix.he.permille)) { QMessageBox::warning(mainWindow(), TITLE_OR_TEXT( @@ -392,7 +381,7 @@ void CylindersModel::remove(const QModelIndex& index) endRemoveRows(); } -WeightModel::WeightModel(QObject* parent): currentId(0), rows(0) +WeightModel::WeightModel(QObject* parent): current(0), rows(0) { //enum Column {REMOVE, TYPE, WEIGHT}; setHeaderDataStrings(QStringList() << tr("") << tr("Type") << tr("Weight")); @@ -400,8 +389,6 @@ WeightModel::WeightModel(QObject* parent): currentId(0), rows(0) weightsystem_t* WeightModel::weightSystemAt(const QModelIndex& index) { - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); return ¤t->weightsystem[index.row()]; } @@ -410,8 +397,6 @@ void WeightModel::remove(const QModelIndex& index) if (index.column() != REMOVE) { return; } - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); beginRemoveRows(QModelIndex(), index.row(), index.row()); // yah, know, ugly. rows--; remove_weightsystem(current, index.row()); @@ -433,8 +418,6 @@ QVariant WeightModel::data(const QModelIndex& index, int role) const if (!index.isValid() || index.row() >= MAX_WEIGHTSYSTEMS) return ret; - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); weightsystem_t *ws = ¤t->weightsystem[index.row()]; switch (role) { @@ -472,8 +455,6 @@ QVariant WeightModel::data(const QModelIndex& index, int role) const // so we only implement the two columns we care about void WeightModel::passInData(const QModelIndex& index, const QVariant& value) { - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); weightsystem_t *ws = ¤t->weightsystem[index.row()]; if (index.column() == WEIGHT) { if (ws->weight.grams != value.toInt()) { @@ -507,8 +488,6 @@ lbs: bool WeightModel::setData(const QModelIndex& index, const QVariant& value, int role) { QString vString = value.toString(); - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); weightsystem_t *ws = ¤t->weightsystem[index.row()]; switch(index.column()) { case TYPE: @@ -570,14 +549,11 @@ void WeightModel::add() void WeightModel::update() { - struct dive *current = getDiveById(currentId); - Q_ASSERT(current != NULL); setDive(current); } void WeightModel::setDive(dive* d) { - struct dive *current = getDiveById(currentId); if (current) clear(); rows = 0; @@ -586,7 +562,7 @@ void WeightModel::setDive(dive* d) rows = i+1; } } - currentId = d->id; + current = d; changed = false; if (rows > 0) { beginInsertRows(QModelIndex(), 0, rows-1); diff --git a/qt-ui/models.h b/qt-ui/models.h index 1f1641e16..06dc66aa1 100644 --- a/qt-ui/models.h +++ b/qt-ui/models.h @@ -101,7 +101,7 @@ public slots: void remove(const QModelIndex& index); private: - int currentId; + struct dive *current; int rows; }; @@ -130,7 +130,7 @@ public slots: void remove(const QModelIndex& index); private: - int currentId; + struct dive *current; int rows; }; |