diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2014-10-27 12:35:19 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-10-27 12:37:27 -0700 |
commit | 7b4bf883134b49ad177f8970b5d46eb9aecd3b59 (patch) | |
tree | acc6634169766f17d59fe2d6d1ca74f060e28827 /qt-ui/diveplanner.cpp | |
parent | 5888fa07788cd53a3269448e02869143b2c38c45 (diff) | |
download | subsurface-7b4bf883134b49ad177f8970b5d46eb9aecd3b59.tar.gz |
Correctly save a re-planned dive
In commit a85a219df325 ("Add ability to replan a dive that we planned
before") I completely mishandled the saving of the replanned data.
How embarrassing.
Fixes #747
See #527
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/diveplanner.cpp')
-rw-r--r-- | qt-ui/diveplanner.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index b8ca2fb27..d490de3b4 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -1179,9 +1179,15 @@ void DivePlannerPointsModel::createPlan() //TODO: C-based function here? plan(&diveplan, &cache, isPlanner(), true); - if (!current_dive || displayed_dive.id != current_dive->id) + if (!current_dive || displayed_dive.id != current_dive->id) { // we were planning a new dive, not re-planning an existing on record_dive(clone_dive(&displayed_dive)); + } else if (current_dive && displayed_dive.id == current_dive->id) { + // we are replanning a dive - make sure changes are reflected + // correctly in the dive structure and copy it back into the dive table + fixup_dive(&displayed_dive); + copy_dive(&displayed_dive, current_dive); + } mark_divelist_changed(true); // Remove and clean the diveplan, so we don't delete |