diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-01-01 11:45:26 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-01-07 09:33:24 -0800 |
commit | 4d06ddd72351f7804acdaec81f0400a735581229 (patch) | |
tree | da5faaf51b301ab3d74acad472ad34cd6a801c40 /core/save-git.c | |
parent | da52440963ac8920acab82502114b74c98e170a1 (diff) | |
download | subsurface-4d06ddd72351f7804acdaec81f0400a735581229.tar.gz |
Dive sites: don't delete unused dive sites on save
Unused dive sites were deleted on save. This clashed with the undo
system in the following scenario:
1) Delete single-use dive site.
2) Save (dive site deleted)
3) Undo (reference to freed dive site)
Therefore, as a quick-fix, keep the referenced dive site around.
Note that this also means that empty dive sites must not be
deleted, as it might refer to a dive in the undo system. Instead
only clear references to empty dive sites in the global dive
table. Factor this functionality out, as it was common to the
XML and git savers.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core/save-git.c')
-rw-r--r-- | core/save-git.c | 12 |
1 files changed, 3 insertions, 9 deletions
diff --git a/core/save-git.c b/core/save-git.c index 7b903a5e9..cdc0ca980 100644 --- a/core/save-git.c +++ b/core/save-git.c @@ -879,18 +879,12 @@ static void save_divesites(git_repository *repo, struct dir *tree) subdir = new_directory(repo, tree, &dirname); free_buffer(&dirname); + purge_empty_dive_sites(); for (int i = 0; i < dive_site_table.nr; i++) { struct membuffer b = { 0 }; struct dive_site *ds = get_dive_site(i); - if (dive_site_is_empty(ds) || !is_dive_site_used(ds, false)) { - int j; - struct dive *d; - for_each_dive(j, d) { - if (d->dive_site == ds) - d->dive_site = NULL; - } - delete_dive_site(ds); - i--; // since we just deleted that one + if (!is_dive_site_used(ds, false)) { + /* Only write used dive sites */ continue; } else if (ds->name && (strncmp(ds->name, "Auto-created dive", 17) == 0 || |