aboutsummaryrefslogtreecommitdiffstats
path: root/commands/command_edit.cpp
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2020-04-04 16:35:24 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-04-04 11:49:23 -0700
commit69d437bc8675267eb71f6658b05991b4afdfb6fb (patch)
treec6fe0aadca8532205c661af56969fea9557d33dc /commands/command_edit.cpp
parent039ed38067a9d34c8625b2b8b260822c8f65d63e (diff)
downloadsubsurface-69d437bc8675267eb71f6658b05991b4afdfb6fb.tar.gz
undo/mobile: keep track of dive sites
When editing the dive site of a dive, the dive-table of the corresponding dive site was not properly updated by the undo commands. Try to get this right. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'commands/command_edit.cpp')
-rw-r--r--commands/command_edit.cpp12
1 files changed, 11 insertions, 1 deletions
diff --git a/commands/command_edit.cpp b/commands/command_edit.cpp
index e3ecf8cf8..46c206c98 100644
--- a/commands/command_edit.cpp
+++ b/commands/command_edit.cpp
@@ -1004,13 +1004,14 @@ void EditWeight::undo()
EditDive::EditDive(dive *oldDiveIn, dive *newDiveIn, dive_site *createDs, dive_site *editDs, location_t dsLocationIn)
: oldDive(oldDiveIn)
, newDive(newDiveIn)
+ , newDiveSite(newDiveIn->dive_site)
, changedFields(DiveField::NONE)
, siteToRemove(nullptr)
, siteToAdd(createDs)
, siteToEdit(editDs)
, dsLocation(dsLocationIn)
{
- if (!oldDive || ! newDive)
+ if (!oldDive || !newDive)
return;
setText(Command::Base::tr("Edit dive [%1]").arg(diveNumberOrDate(oldDive)));
@@ -1061,6 +1062,8 @@ EditDive::EditDive(dive *oldDiveIn, dive *newDiveIn, dive_site *createDs, dive_s
changedFields |= DiveField::NOTES;
if (oldDive->salinity != newDive->salinity)
changedFields |= DiveField::SALINITY;
+
+ newDive->dive_site = nullptr; // We will add the dive to the site manually and therefore saved the dive site.
}
void EditDive::undo()
@@ -1097,9 +1100,16 @@ void EditDive::exchangeDives()
// Bluntly exchange dive data by shallow copy.
// Don't forget to unregister the old and register the new dive!
+ // Likewise take care to add/remove the dive from the dive site.
fulltext_unregister(oldDive);
+ dive_site *oldDiveSite = oldDive->dive_site;
+ if (oldDiveSite)
+ unregister_dive_from_dive_site(oldDive); // the dive-site pointer in the dive is now NULL
std::swap(*newDive, *oldDive);
fulltext_register(oldDive);
+ if (newDiveSite)
+ add_dive_to_dive_site(oldDive, newDiveSite);
+ newDiveSite = oldDiveSite; // remember the previous dive site
invalidate_dive_cache(oldDive);
// Changing times may have unsorted the dive and trip tables