diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2019-06-22 12:12:09 -0700 |
---|---|---|
committer | bstoeger <32835590+bstoeger@users.noreply.github.com> | 2019-06-23 11:29:52 +0200 |
commit | 6619bd972c4821b5f2eec7cc2f0290aab8811819 (patch) | |
tree | bbe53c6f1df07b547219597b8d2ed89f2a544f7a | |
parent | 21b275c4fde6a580640d1e56b8a7e013f38c06db (diff) | |
download | subsurface-6619bd972c4821b5f2eec7cc2f0290aab8811819.tar.gz |
Desktop: don't use planner to manually add dive
Instead of calling into the planner, simply create the dive computer
information right there, using the existing helper function we have to
create simple profiles.
Fixes #2128
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | desktop-widgets/mainwindow.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/desktop-widgets/mainwindow.cpp b/desktop-widgets/mainwindow.cpp index 2f3db5b2c..7cf8afc5e 100644 --- a/desktop-widgets/mainwindow.cpp +++ b/desktop-widgets/mainwindow.cpp @@ -18,6 +18,7 @@ #include <QtConcurrentRun> #include "core/color.h" +#include "core/device.h" #include "core/divecomputer.h" #include "core/divesitehelpers.h" #include "core/file.h" @@ -962,21 +963,18 @@ void MainWindow::on_actionAddDive_triggered() if (!plannerStateClean()) return; - // TODO: We (mis)use displayed_dive to construct a default dive using the dive planner. - // This means that we have to do all this in a setPlanState()/setProfileState() pair, - // to avoid the profile and planner going out of sync (which in turn can lead to crashes). - // This should all be simplified. There is no apparent no reason to go via the planner - // to create a default profile. + // create a dive an hour from now with a default depth (15m/45ft) and duration (40 minutes) + // as a starting point for the user to edit clear_dive(&displayed_dive); - graphics->setPlanState(); - DivePlannerPointsModel::instance()->setupStartTime(); - DivePlannerPointsModel::instance()->createSimpleDive(); displayed_dive.id = dive_getUniqID(); displayed_dive.when = QDateTime::currentMSecsSinceEpoch() / 1000L + gettimezoneoffset() + 3600; + displayed_dive.dc.duration.seconds = 40 * 60; + displayed_dive.dc.maxdepth.mm = M_OR_FT(15, 45); + displayed_dive.dc.meandepth.mm = M_OR_FT(13, 39); // this creates a resonable looking safety stop displayed_dive.dc.model = strdup("manually added dive"); // don't translate! this is stored in the XML file - fixup_dc_duration(&displayed_dive.dc); displayed_dive.duration = displayed_dive.dc.duration; - graphics->setProfileState(); + fake_dc(&displayed_dive.dc); + fixup_dive(&displayed_dive); Command::addDive(&displayed_dive, autogroup, true); |