Cylinders: Add CylindersModelFiltered

When the show_unused_cylinders flag is not set, the cylinder tables
in the equipment tab and the planner should not show unused cylinders.
However, the code in CylindersModel is fundamentally broken if the
unused cylinders are not at the end of the list: The correct number
of cylinders is shown, but not the correct cylinders.

Therefore, add a higher-level CylindersModelFiltered model on top
of CylindersModel that does the actual filtering. Some calls are
routed through to the base model (notably those that take indexes,
as these have to be mapped), for some calls the caller has to get
access to the source model first. We might want to adjust this.

For filtering, reuse the already existing show_cylinder function
and export it via CylindersModel.

Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
Berthold Stoeger 2020-01-30 20:12:11 +01:00 committed by Dirk Hohndel
parent b37c261c95
commit 6622f42aab
9 changed files with 140 additions and 78 deletions

View file

@ -126,7 +126,7 @@ void PlannerShared::set_o2narcotic(bool value)
{ {
qPrefDivePlanner::set_o2narcotic(value); qPrefDivePlanner::set_o2narcotic(value);
DivePlannerPointsModel::instance()->emitDataChanged(); DivePlannerPointsModel::instance()->emitDataChanged();
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
} }
double PlannerShared::bottompo2() double PlannerShared::bottompo2()
@ -136,7 +136,7 @@ double PlannerShared::bottompo2()
void PlannerShared::set_bottompo2(double value) void PlannerShared::set_bottompo2(double value)
{ {
qPrefDivePlanner::set_bottompo2((int) (value * 1000.0)); qPrefDivePlanner::set_bottompo2((int) (value * 1000.0));
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
} }
double PlannerShared::decopo2() double PlannerShared::decopo2()
@ -148,8 +148,8 @@ void PlannerShared::set_decopo2(double value)
pressure_t olddecopo2; pressure_t olddecopo2;
olddecopo2.mbar = prefs.decopo2; olddecopo2.mbar = prefs.decopo2;
qPrefDivePlanner::instance()->set_decopo2((int) (value * 1000.0)); qPrefDivePlanner::instance()->set_decopo2((int) (value * 1000.0));
CylindersModel::instance()->updateDecoDepths(olddecopo2); CylindersModelFiltered::instance()->model()->updateDecoDepths(olddecopo2);
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
} }
int PlannerShared::bestmixend() int PlannerShared::bestmixend()
@ -159,5 +159,5 @@ int PlannerShared::bestmixend()
void PlannerShared::set_bestmixend(int value) void PlannerShared::set_bestmixend(int value)
{ {
qPrefDivePlanner::set_bestmixend(units_to_depth(value).mm); qPrefDivePlanner::set_bestmixend(units_to_depth(value).mm);
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
} }

View file

@ -120,8 +120,8 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::DIVEMODE, new DiveTypesDelegate(this)); ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::DIVEMODE, new DiveTypesDelegate(this));
ui.cylinderTableWidget->setTitle(tr("Available gases")); ui.cylinderTableWidget->setTitle(tr("Available gases"));
ui.cylinderTableWidget->setBtnToolTip(tr("Add cylinder")); ui.cylinderTableWidget->setBtnToolTip(tr("Add cylinder"));
ui.cylinderTableWidget->setModel(CylindersModel::instance()); ui.cylinderTableWidget->setModel(CylindersModelFiltered::instance());
connect(ui.cylinderTableWidget, &TableView::itemClicked, CylindersModel::instance(), &CylindersModel::remove); connect(ui.cylinderTableWidget, &TableView::itemClicked, CylindersModelFiltered::instance(), &CylindersModelFiltered::remove);
ui.waterType->setItemData(0, FRESHWATER_SALINITY); ui.waterType->setItemData(0, FRESHWATER_SALINITY);
ui.waterType->setItemData(1, SEAWATER_SALINITY); ui.waterType->setItemData(1, SEAWATER_SALINITY);
ui.waterType->setItemData(2, EN13319_SALINITY); ui.waterType->setItemData(2, EN13319_SALINITY);
@ -139,13 +139,13 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
// Continue to use old syntax, to avoid problems. // Continue to use old syntax, to avoid problems.
connect(ui.tableWidget, SIGNAL(addButtonClicked()), plannerModel, SLOT(addStop())); connect(ui.tableWidget, SIGNAL(addButtonClicked()), plannerModel, SLOT(addStop()));
connect(CylindersModel::instance(), &CylindersModel::dataChanged, GasSelectionModel::instance(), &GasSelectionModel::repopulate); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::dataChanged, GasSelectionModel::instance(), &GasSelectionModel::repopulate);
connect(CylindersModel::instance(), &CylindersModel::rowsInserted, GasSelectionModel::instance(), &GasSelectionModel::repopulate); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::rowsInserted, GasSelectionModel::instance(), &GasSelectionModel::repopulate);
connect(CylindersModel::instance(), &CylindersModel::rowsRemoved, GasSelectionModel::instance(), &GasSelectionModel::repopulate); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::rowsRemoved, GasSelectionModel::instance(), &GasSelectionModel::repopulate);
connect(CylindersModel::instance(), &CylindersModel::dataChanged, plannerModel, &DivePlannerPointsModel::emitDataChanged); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::dataChanged, plannerModel, &DivePlannerPointsModel::emitDataChanged);
connect(CylindersModel::instance(), &CylindersModel::dataChanged, plannerModel, &DivePlannerPointsModel::cylinderModelEdited); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::dataChanged, plannerModel, &DivePlannerPointsModel::cylinderModelEdited);
connect(CylindersModel::instance(), &CylindersModel::rowsInserted, plannerModel, &DivePlannerPointsModel::cylinderModelEdited); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::rowsInserted, plannerModel, &DivePlannerPointsModel::cylinderModelEdited);
connect(CylindersModel::instance(), &CylindersModel::rowsRemoved, plannerModel, &DivePlannerPointsModel::cylinderModelEdited); connect(CylindersModelFiltered::instance(), &CylindersModelFiltered::rowsRemoved, plannerModel, &DivePlannerPointsModel::cylinderModelEdited);
connect(plannerModel, &DivePlannerPointsModel::calculatedPlanNotes, MainWindow::instance(), &MainWindow::setPlanNotes); connect(plannerModel, &DivePlannerPointsModel::calculatedPlanNotes, MainWindow::instance(), &MainWindow::setPlanNotes);

View file

@ -918,7 +918,7 @@ void MainWindow::on_actionReplanDive_triggered()
divePlannerWidget->setSalinity(current_dive->salinity); divePlannerWidget->setSalinity(current_dive->salinity);
DivePlannerPointsModel::instance()->loadFromDive(current_dive); DivePlannerPointsModel::instance()->loadFromDive(current_dive);
reset_cylinders(&displayed_dive, true); reset_cylinders(&displayed_dive, true);
CylindersModel::instance()->updateDive(); CylindersModelFiltered::instance()->updateDive();
} }
void MainWindow::on_actionDivePlanner_triggered() void MainWindow::on_actionDivePlanner_triggered()

View file

@ -238,7 +238,7 @@ static struct RevertCylinderData {
void TankInfoDelegate::setModelData(QWidget*, QAbstractItemModel*, const QModelIndex&) const void TankInfoDelegate::setModelData(QWidget*, QAbstractItemModel*, const QModelIndex&) const
{ {
CylindersModel *mymodel = qobject_cast<CylindersModel *>(currCombo.model); CylindersModelFiltered *mymodel = qobject_cast<CylindersModelFiltered *>(currCombo.model);
TankInfoModel *tanks = TankInfoModel::instance(); TankInfoModel *tanks = TankInfoModel::instance();
QModelIndexList matches = tanks->match(tanks->index(0, 0), Qt::DisplayRole, currCombo.activeText); QModelIndexList matches = tanks->match(tanks->index(0, 0), Qt::DisplayRole, currCombo.activeText);
int row; int row;
@ -277,7 +277,7 @@ void TankInfoDelegate::editorClosed(QWidget*, QAbstractItemDelegate::EndEditHint
{ {
if (hint == QAbstractItemDelegate::NoHint || if (hint == QAbstractItemDelegate::NoHint ||
hint == QAbstractItemDelegate::RevertModelCache) { hint == QAbstractItemDelegate::RevertModelCache) {
CylindersModel *mymodel = qobject_cast<CylindersModel *>(currCombo.model); CylindersModelFiltered *mymodel = qobject_cast<CylindersModelFiltered *>(currCombo.model);
mymodel->setData(IDX(CylindersModel::TYPE), currCylinderData.type, Qt::EditRole); mymodel->setData(IDX(CylindersModel::TYPE), currCylinderData.type, Qt::EditRole);
mymodel->passInData(IDX(CylindersModel::WORKINGPRESS), currCylinderData.pressure); mymodel->passInData(IDX(CylindersModel::WORKINGPRESS), currCylinderData.pressure);
mymodel->passInData(IDX(CylindersModel::SIZE), currCylinderData.size); mymodel->passInData(IDX(CylindersModel::SIZE), currCylinderData.size);
@ -289,7 +289,7 @@ QWidget *TankInfoDelegate::createEditor(QWidget *parent, const QStyleOptionViewI
// ncreate editor needs to be called before because it will populate a few // ncreate editor needs to be called before because it will populate a few
// things in the currCombo global var. // things in the currCombo global var.
QWidget *delegate = ComboBoxDelegate::createEditor(parent, option, index); QWidget *delegate = ComboBoxDelegate::createEditor(parent, option, index);
CylindersModel *mymodel = qobject_cast<CylindersModel *>(currCombo.model); CylindersModelFiltered *mymodel = qobject_cast<CylindersModelFiltered *>(currCombo.model);
cylinder_t *cyl = mymodel->cylinderAt(index); cylinder_t *cyl = mymodel->cylinderAt(index);
currCylinderData.type = cyl->type.description; currCylinderData.type = cyl->type.description;
currCylinderData.pressure = cyl->type.workingpressure.mbar; currCylinderData.pressure = cyl->type.workingpressure.mbar;

View file

@ -17,7 +17,7 @@
#include <QCompleter> #include <QCompleter>
TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent), TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
cylindersModel(new CylindersModel(this)), cylindersModel(new CylindersModelFiltered(this)),
weightModel(new WeightModel(this)) weightModel(new WeightModel(this))
{ {
QCompleter *suitCompleter; QCompleter *suitCompleter;
@ -33,7 +33,7 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
ui.weights->setModel(weightModel); ui.weights->setModel(weightModel);
connect(&diveListNotifier, &DiveListNotifier::divesChanged, this, &TabDiveEquipment::divesChanged); connect(&diveListNotifier, &DiveListNotifier::divesChanged, this, &TabDiveEquipment::divesChanged);
connect(ui.cylinders, &TableView::itemClicked, cylindersModel, &CylindersModel::remove); connect(ui.cylinders, &TableView::itemClicked, cylindersModel, &CylindersModelFiltered::remove);
connect(ui.cylinders, &TableView::itemClicked, this, &TabDiveEquipment::editCylinderWidget); connect(ui.cylinders, &TableView::itemClicked, this, &TabDiveEquipment::editCylinderWidget);
connect(ui.weights, &TableView::itemClicked, this, &TabDiveEquipment::editWeightWidget); connect(ui.weights, &TableView::itemClicked, this, &TabDiveEquipment::editWeightWidget);
@ -164,7 +164,7 @@ void TabDiveEquipment::addWeight_clicked()
void TabDiveEquipment::editCylinderWidget(const QModelIndex &index) void TabDiveEquipment::editCylinderWidget(const QModelIndex &index)
{ {
if (cylindersModel->changed && !MainWindow::instance()->mainTab->isEditing()) { if (cylindersModel->model()->changed && !MainWindow::instance()->mainTab->isEditing()) {
MainWindow::instance()->mainTab->enableEdition(); MainWindow::instance()->mainTab->enableEdition();
return; return;
} }
@ -228,7 +228,7 @@ void TabDiveEquipment::acceptChanges()
// to the original value in current_dive like it should // to the original value in current_dive like it should
QVector<dive *> selectedDives = getSelectedDivesCurrentLast(); QVector<dive *> selectedDives = getSelectedDivesCurrentLast();
if (cylindersModel->changed) { if (cylindersModel->model()->changed) {
mark_divelist_changed(true); mark_divelist_changed(true);
MODIFY_DIVES(selectedDives, MODIFY_DIVES(selectedDives,
// if we started out with the same cylinder description (for multi-edit) or if we do copt & paste // if we started out with the same cylinder description (for multi-edit) or if we do copt & paste
@ -257,12 +257,12 @@ void TabDiveEquipment::acceptChanges()
if (do_replot) if (do_replot)
MainWindow::instance()->graphics->replot(); MainWindow::instance()->graphics->replot();
cylindersModel->changed = false; cylindersModel->model()->changed = false;
} }
void TabDiveEquipment::rejectChanges() void TabDiveEquipment::rejectChanges()
{ {
cylindersModel->changed = false; cylindersModel->model()->changed = false;
cylindersModel->updateDive(); cylindersModel->updateDive();
weightModel->updateDive(current_dive); weightModel->updateDive(current_dive);
} }

View file

@ -12,7 +12,7 @@ namespace Ui {
}; };
class WeightModel; class WeightModel;
class CylindersModel; class CylindersModelFiltered;
class TabDiveEquipment : public TabBase { class TabDiveEquipment : public TabBase {
Q_OBJECT Q_OBJECT
@ -38,7 +38,7 @@ private slots:
private: private:
Ui::TabDiveEquipment ui; Ui::TabDiveEquipment ui;
SuitCompletionModel suitModel; SuitCompletionModel suitModel;
CylindersModel *cylindersModel; CylindersModelFiltered *cylindersModel;
WeightModel *weightModel; WeightModel *weightModel;
}; };

View file

@ -14,9 +14,9 @@ CylindersModel::CylindersModel(QObject *parent) :
changed(false), changed(false),
rows(0) rows(0)
{ {
// enum {REMOVE, TYPE, SIZE, WORKINGPRESS, START, END, O2, HE, DEPTH, MOD, MND, USE}; // enum {REMOVE, TYPE, SIZE, WORKINGPRESS, START, END, O2, HE, DEPTH, MOD, MND, USE, IS_USED};
setHeaderDataStrings(QStringList() << "" << tr("Type") << tr("Size") << tr("Work press.") << tr("Start press.") << tr("End press.") << tr("O₂%") << tr("He%") setHeaderDataStrings(QStringList() << "" << tr("Type") << tr("Size") << tr("Work press.") << tr("Start press.") << tr("End press.") << tr("O₂%") << tr("He%")
<< tr("Deco switch at") <<tr("Bot. MOD") <<tr("MND") << tr("Use")); << tr("Deco switch at") <<tr("Bot. MOD") <<tr("MND") << tr("Use") << "Is used");
connect(&diveListNotifier, &DiveListNotifier::cylindersReset, this, &CylindersModel::cylindersReset); connect(&diveListNotifier, &DiveListNotifier::cylindersReset, this, &CylindersModel::cylindersReset);
} }
@ -29,12 +29,6 @@ QVariant CylindersModel::headerData(int section, Qt::Orientation orientation, in
return CleanerTableModel::headerData(section, orientation, role); return CleanerTableModel::headerData(section, orientation, role);
} }
CylindersModel *CylindersModel::instance()
{
static CylindersModel self;
return &self;
}
static QString get_cylinder_string(const cylinder_t *cyl) static QString get_cylinder_string(const cylinder_t *cyl)
{ {
QString unit; QString unit;
@ -129,6 +123,28 @@ static QVariant percent_string(fraction_t fraction)
return QString("%L1%").arg(permille / 10.0, 0, 'f', 1); return QString("%L1%").arg(permille / 10.0, 0, 'f', 1);
} }
bool CylindersModel::cylinderUsed(int i) const
{
const struct dive *dive = &displayed_dive;
if (i < 0 || i >= dive->cylinders.nr)
return false;
if (is_cylinder_used(dive, i))
return true;
cylinder_t *cyl = get_cylinder(dive, i);
if (cyl->start.mbar || cyl->sample_start.mbar ||
cyl->end.mbar || cyl->sample_end.mbar)
return true;
if (cyl->manually_added)
return true;
/*
* The cylinder has some data, but none of it is very interesting,
* it has no pressures and no gas switches. Do we want to show it?
*/
return false;
}
QVariant CylindersModel::data(const QModelIndex &index, int role) const QVariant CylindersModel::data(const QModelIndex &index, int role) const
{ {
if (!index.isValid() || index.row() >= rows) if (!index.isValid() || index.row() >= rows)
@ -447,40 +463,13 @@ void CylindersModel::clear()
} }
} }
static bool show_cylinder(struct dive *dive, int i)
{
if (i < 0 || i >= dive->cylinders.nr)
return false;
if (is_cylinder_used(dive, i))
return true;
cylinder_t *cyl = get_cylinder(dive, i);
if (cyl->start.mbar || cyl->sample_start.mbar ||
cyl->end.mbar || cyl->sample_end.mbar)
return true;
if (cyl->manually_added)
return true;
/*
* The cylinder has some data, but none of it is very interesting,
* it has no pressures and no gas switches. Do we want to show it?
*/
return prefs.display_unused_tanks;
}
void CylindersModel::updateDive() void CylindersModel::updateDive()
{ {
#ifdef DEBUG_CYL #ifdef DEBUG_CYL
dump_cylinders(&displayed_dive, true); dump_cylinders(&displayed_dive, true);
#endif #endif
beginResetModel(); beginResetModel();
// TODO: this is fundamentally broken - it assumes that unused cylinders are at rows = displayed_dive.cylinders.nr;
// the end. Fix by using a QSortFilterProxyModel.
rows = 0;
for (int i = 0; i < displayed_dive.cylinders.nr; ++i) {
if (show_cylinder(&displayed_dive, i))
++rows;
}
endResetModel(); endResetModel();
} }
@ -493,7 +482,6 @@ Qt::ItemFlags CylindersModel::flags(const QModelIndex &index) const
void CylindersModel::remove(QModelIndex index) void CylindersModel::remove(QModelIndex index)
{ {
if (index.column() == USE) { if (index.column() == USE) {
cylinder_t *cyl = cylinderAt(index); cylinder_t *cyl = cylinderAt(index);
if (cyl->cylinder_use == OC_GAS) if (cyl->cylinder_use == OC_GAS)
@ -622,3 +610,54 @@ void CylindersModel::cylindersReset(const QVector<dive *> &dives)
// And update the model.. // And update the model..
updateDive(); updateDive();
} }
CylindersModelFiltered *CylindersModelFiltered::instance()
{
static CylindersModelFiltered self;
return &self;
}
CylindersModelFiltered::CylindersModelFiltered(QObject *parent) : QSortFilterProxyModel(parent)
{
setSourceModel(&source);
}
void CylindersModelFiltered::updateDive()
{
source.updateDive();
}
void CylindersModelFiltered::clear()
{
source.clear();
}
void CylindersModelFiltered::add()
{
source.add();
}
CylindersModel *CylindersModelFiltered::model()
{
return &source;
}
void CylindersModelFiltered::remove(QModelIndex index)
{
source.remove(mapToSource(index));
}
void CylindersModelFiltered::passInData(const QModelIndex &index, const QVariant &value)
{
source.passInData(mapToSource(index), value);
}
cylinder_t *CylindersModelFiltered::cylinderAt(const QModelIndex &index)
{
return source.cylinderAt(mapToSource(index));
}
bool CylindersModelFiltered::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const
{
return prefs.display_unused_tanks || source.cylinderUsed(source_row);
}

View file

@ -2,6 +2,8 @@
#ifndef CYLINDERMODEL_H #ifndef CYLINDERMODEL_H
#define CYLINDERMODEL_H #define CYLINDERMODEL_H
#include <QSortFilterProxyModel>
#include "cleanertablemodel.h" #include "cleanertablemodel.h"
#include "core/dive.h" #include "core/dive.h"
@ -27,7 +29,6 @@ public:
}; };
explicit CylindersModel(QObject *parent = 0); explicit CylindersModel(QObject *parent = 0);
static CylindersModel *instance();
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override; QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
int rowCount(const QModelIndex &parent = QModelIndex()) const override; int rowCount(const QModelIndex &parent = QModelIndex()) const override;
Qt::ItemFlags flags(const QModelIndex &index) const override; Qt::ItemFlags flags(const QModelIndex &index) const override;
@ -44,6 +45,7 @@ public:
bool changed; bool changed;
QVariant headerData(int section, Qt::Orientation orientation, int role) const override; QVariant headerData(int section, Qt::Orientation orientation, int role) const override;
bool updateBestMixes(); bool updateBestMixes();
bool cylinderUsed(int i) const;
public public
slots: slots:
@ -54,4 +56,25 @@ private:
int rows; int rows;
}; };
// Cylinder model that hides unused cylinders if the pref.show_unused_cylinders flag is not set
class CylindersModelFiltered : public QSortFilterProxyModel {
Q_OBJECT
public:
CylindersModelFiltered(QObject *parent = 0);
static CylindersModelFiltered *instance();
CylindersModel *model(); // Access to unfiltered base model
void clear();
void add();
void updateDive();
cylinder_t *cylinderAt(const QModelIndex &index);
void passInData(const QModelIndex &index, const QVariant &value);
public
slots:
void remove(QModelIndex index);
private:
CylindersModel source;
bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const override;
};
#endif #endif

View file

@ -37,7 +37,7 @@ void DivePlannerPointsModel::removeSelectedPoints(const QVector<int> &rows)
divepoints.remove(v2[i]); divepoints.remove(v2[i]);
} }
endRemoveRows(); endRemoveRows();
CylindersModel::instance()->updateTrashIcon(); CylindersModelFiltered::instance()->model()->updateTrashIcon();
} }
void DivePlannerPointsModel::createSimpleDive() void DivePlannerPointsModel::createSimpleDive()
@ -89,7 +89,7 @@ void DivePlannerPointsModel::loadFromDive(dive *d)
const struct event *evd = NULL; const struct event *evd = NULL;
enum divemode_t current_divemode = UNDEF_COMP_TYPE; enum divemode_t current_divemode = UNDEF_COMP_TYPE;
recalc = false; recalc = false;
CylindersModel::instance()->updateDive(); CylindersModelFiltered::instance()->updateDive();
duration_t lasttime = { 0 }; duration_t lasttime = { 0 };
duration_t lastrecordedtime = {}; duration_t lastrecordedtime = {};
duration_t newtime = {}; duration_t newtime = {};
@ -162,7 +162,7 @@ void DivePlannerPointsModel::setupCylinders()
reset_cylinders(&displayed_dive, true); reset_cylinders(&displayed_dive, true);
if (displayed_dive.cylinders.nr > 0) { if (displayed_dive.cylinders.nr > 0) {
CylindersModel::instance()->updateDive(); CylindersModelFiltered::instance()->updateDive();
return; // We have at least one cylinder return; // We have at least one cylinder
} }
} }
@ -180,7 +180,7 @@ void DivePlannerPointsModel::setupCylinders()
add_to_cylinder_table(&displayed_dive.cylinders, 0, cyl); add_to_cylinder_table(&displayed_dive.cylinders, 0, cyl);
} }
reset_cylinders(&displayed_dive, false); reset_cylinders(&displayed_dive, false);
CylindersModel::instance()->updateDive(); CylindersModelFiltered::instance()->updateDive();
} }
// Update the dive's maximum depth. Returns true if max. depth changed // Update the dive's maximum depth. Returns true if max. depth changed
@ -209,7 +209,7 @@ void DivePlannerPointsModel::removeDeco()
void DivePlannerPointsModel::addCylinder_clicked() void DivePlannerPointsModel::addCylinder_clicked()
{ {
CylindersModel::instance()->add(); CylindersModelFiltered::instance()->add();
} }
@ -317,7 +317,7 @@ bool DivePlannerPointsModel::setData(const QModelIndex &index, const QVariant &v
if (value.toInt() >= 0) { if (value.toInt() >= 0) {
p.depth = units_to_depth(value.toInt()); p.depth = units_to_depth(value.toInt());
if (updateMaxDepth()) if (updateMaxDepth())
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
} }
break; break;
case RUNTIME: case RUNTIME:
@ -343,8 +343,8 @@ bool DivePlannerPointsModel::setData(const QModelIndex &index, const QVariant &v
p.cylinderid = value.toInt(); p.cylinderid = value.toInt();
/* Did we change the start (dp 0) cylinder to another cylinderid than 0? */ /* Did we change the start (dp 0) cylinder to another cylinderid than 0? */
if (value.toInt() != 0 && index.row() == 0) if (value.toInt() != 0 && index.row() == 0)
CylindersModel::instance()->moveAtFirst(value.toInt()); CylindersModelFiltered::instance()->model()->moveAtFirst(value.toInt());
CylindersModel::instance()->updateTrashIcon(); CylindersModelFiltered::instance()->model()->updateTrashIcon();
break; break;
case DIVEMODE: case DIVEMODE:
if (value.toInt() < FREEDIVE) { if (value.toInt() < FREEDIVE) {
@ -799,9 +799,9 @@ void DivePlannerPointsModel::editStop(int row, divedatapoint newData)
divepoints[row] = newData; divepoints[row] = newData;
std::sort(divepoints.begin(), divepoints.end(), divePointsLessThan); std::sort(divepoints.begin(), divepoints.end(), divePointsLessThan);
if (updateMaxDepth()) if (updateMaxDepth())
CylindersModel::instance()->updateBestMixes(); CylindersModelFiltered::instance()->model()->updateBestMixes();
if (divepoints[0].cylinderid != old_first_cylid) if (divepoints[0].cylinderid != old_first_cylid)
CylindersModel::instance()->moveAtFirst(divepoints[0].cylinderid); CylindersModelFiltered::instance()->model()->moveAtFirst(divepoints[0].cylinderid);
emitDataChanged(); emitDataChanged();
} }
@ -850,9 +850,9 @@ void DivePlannerPointsModel::remove(const QModelIndex &index)
divepoints.remove(index.row()); divepoints.remove(index.row());
} }
endRemoveRows(); endRemoveRows();
CylindersModel::instance()->updateTrashIcon(); CylindersModelFiltered::instance()->model()->updateTrashIcon();
if (divepoints[0].cylinderid != old_first_cylid) if (divepoints[0].cylinderid != old_first_cylid)
CylindersModel::instance()->moveAtFirst(divepoints[0].cylinderid); CylindersModelFiltered::instance()->model()->moveAtFirst(divepoints[0].cylinderid);
} }
struct diveplan &DivePlannerPointsModel::getDiveplan() struct diveplan &DivePlannerPointsModel::getDiveplan()
@ -907,13 +907,13 @@ void DivePlannerPointsModel::clear()
{ {
bool oldRecalc = setRecalc(false); bool oldRecalc = setRecalc(false);
CylindersModel::instance()->updateDive(); CylindersModelFiltered::instance()->updateDive();
if (rowCount() > 0) { if (rowCount() > 0) {
beginRemoveRows(QModelIndex(), 0, rowCount() - 1); beginRemoveRows(QModelIndex(), 0, rowCount() - 1);
divepoints.clear(); divepoints.clear();
endRemoveRows(); endRemoveRows();
} }
CylindersModel::instance()->clear(); CylindersModelFiltered::instance()->clear();
setRecalc(oldRecalc); setRecalc(oldRecalc);
} }