diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-02-03 18:37:56 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-02-06 08:51:32 -0800 |
commit | 285ea9b7ca71e11c2f821cf1b314083cd55e95d0 (patch) | |
tree | d1cd2a39dbc4c4ab1b5e8457c3576387876976de | |
parent | cf1e3524a1e000c27ff97e69b21d87d92cbbcc1a (diff) | |
download | subsurface-285ea9b7ca71e11c2f821cf1b314083cd55e95d0.tar.gz |
Cleanup: don't initialize DivePlannerPointsModel at startup
The whole point of having X::instance() functions is to solve
the infamous "Static Initialization Order Fiasco": When having
global objects in different translation units, their order
of initialization is undefined. Thus, when these objects access
each other one cannot guarantee the correct order of
initialization. The X::instance() functions generate the objects
on first use.
DivePlannerPointsModel has such an instance() function. However,
for convenience(?) in diveplanner.cpp we find the global variable
static DivePlannerPointsModel* plannerModel =
DivePlannerPointsModel::instance();
Thus, the DivePlannerPointsModel constructor is run before main(),
negating the whole purpose of the instance() function.
Let's remove this line to avoid hard-to-debug startup issues.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | desktop-widgets/diveplanner.cpp | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/desktop-widgets/diveplanner.cpp b/desktop-widgets/diveplanner.cpp index f1c0582f9..8d3cbcbd4 100644 --- a/desktop-widgets/diveplanner.cpp +++ b/desktop-widgets/diveplanner.cpp @@ -24,8 +24,6 @@ #define MAX_DEPTH M_OR_FT(150, 450) #define MIN_DEPTH M_OR_FT(20, 60) -static DivePlannerPointsModel* plannerModel = DivePlannerPointsModel::instance(); - DiveHandler::DiveHandler() : QGraphicsEllipseItem() { setRect(-5, -5, 10, 10); @@ -46,6 +44,7 @@ void DiveHandler::contextMenuEvent(QGraphicsSceneContextMenuEvent *event) QMenu m; // Don't have a gas selection for the last point emit released(); + DivePlannerPointsModel *plannerModel = DivePlannerPointsModel::instance(); QModelIndex index = plannerModel->index(parentIndex(), DivePlannerPointsModel::GAS); if (index.sibling(index.row() + 1, index.column()).isValid()) { GasSelectionModel *model = GasSelectionModel::instance(); @@ -77,6 +76,7 @@ void DiveHandler::selfRemove() void DiveHandler::changeGas() { QAction *action = qobject_cast<QAction *>(sender()); + DivePlannerPointsModel *plannerModel = DivePlannerPointsModel::instance(); QModelIndex index = plannerModel->index(parentIndex(), DivePlannerPointsModel::GAS); plannerModel->gasChange(index.sibling(index.row() + 1, index.column()), action->data().toInt()); } @@ -109,6 +109,7 @@ void DiveHandler::mouseReleaseEvent(QGraphicsSceneMouseEvent *event) DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidget(parent, f) { + DivePlannerPointsModel *plannerModel = DivePlannerPointsModel::instance(); ui.setupUi(this); ui.dateEdit->setDisplayFormat(prefs.date_format); ui.tableWidget->setTitle(tr("Dive planner points")); @@ -218,7 +219,7 @@ void DivePlannerWidget::setSalinity(int salinity) ui.customSalinity->setEnabled(true); ui.customSalinity->setValue(salinity / 10000.0); } - plannerModel->setSalinity(salinity); + DivePlannerPointsModel::instance()->setSalinity(salinity); } void DivePlannerWidget::settingsChanged() @@ -234,13 +235,13 @@ void DivePlannerWidget::settingsChanged() ui.atmHeight->setMaximum(3000); } ui.atmHeight->blockSignals(true); - ui.atmHeight->setValue((int) get_depth_units((int) pressure_to_altitude(plannerModel->getSurfacePressure()), NULL,NULL)); + ui.atmHeight->setValue((int) get_depth_units((int) pressure_to_altitude(DivePlannerPointsModel::instance()->getSurfacePressure()), NULL,NULL)); ui.atmHeight->blockSignals(false); } void DivePlannerWidget::atmPressureChanged(const int pressure) { - plannerModel->setSurfacePressure(pressure); + DivePlannerPointsModel::instance()->setSurfacePressure(pressure); ui.atmHeight->blockSignals(true); ui.atmHeight->setValue((int) get_depth_units((int) pressure_to_altitude(pressure), NULL,NULL)); ui.atmHeight->blockSignals(false); @@ -252,7 +253,7 @@ void DivePlannerWidget::heightChanged(const int height) ui.ATMPressure->blockSignals(true); ui.ATMPressure->setValue(pressure); ui.ATMPressure->blockSignals(false); - plannerModel->setSurfacePressure(pressure); + DivePlannerPointsModel::instance()->setSurfacePressure(pressure); } void DivePlannerWidget::waterTypeUpdateTexts() @@ -273,7 +274,7 @@ void DivePlannerWidget::waterTypeChanged(const int index) { ui.customSalinity->setEnabled(index == ui.waterType->count() - 1); ui.customSalinity->setValue(ui.waterType->itemData(index).toInt() / 10000.0); - plannerModel->setSalinity(ui.waterType->itemData(index).toInt()); + DivePlannerPointsModel::instance()->setSalinity(ui.waterType->itemData(index).toInt()); } void DivePlannerWidget::customSalinityChanged(double density) @@ -281,7 +282,7 @@ void DivePlannerWidget::customSalinityChanged(double density) if (ui.customSalinity->isEnabled()) { int newSalinity = (int)(density * 10000.0); ui.waterType->setItemData(ui.waterType->count() - 1, newSalinity); - plannerModel->setSalinity(newSalinity); + DivePlannerPointsModel::instance()->setSalinity(newSalinity); } } @@ -421,6 +422,7 @@ PlannerSettingsWidget::PlannerSettingsWidget(QWidget *parent, Qt::WindowFlags f) { ui.setupUi(this); + DivePlannerPointsModel *plannerModel = DivePlannerPointsModel::instance(); plannerModel->getDiveplan().bottomsac = prefs.bottomsac; plannerModel->getDiveplan().decosac = prefs.decosac; @@ -516,6 +518,7 @@ PlannerSettingsWidget::PlannerSettingsWidget(QWidget *parent, Qt::WindowFlags f) void PlannerSettingsWidget::updateUnitsUI() { + DivePlannerPointsModel *plannerModel = DivePlannerPointsModel::instance(); ui.ascRate75->setValue(plannerModel->ascrate75Display()); ui.ascRate50->setValue(plannerModel->ascrate50Display()); ui.ascRateStops->setValue(plannerModel->ascratestopsDisplay()); |