From 8c77c15dd877cc75c09616b8280fa1ae2095f5fb Mon Sep 17 00:00:00 2001 From: Jan Mulder Date: Tue, 19 Dec 2017 13:13:06 +0100 Subject: git storage: invalidate cache on merge dive site In hindsight a very simple bug to fix, but it requires some knowledge on the inner workings of our git storage. The changes on merge of dive sites were simply not saved (completely) because the git storage code has a cache that we need to invalidate selectively (ie. for the dive we just gave a new dive site uuid) to get things finally embedded in the overall commit. The main reason this bug went unnoticed for more than 2 years is that most people use the XML/SSRF format (where this problem is non exsistent), and dive site merging is probably not a very much used feature either. Fixes: #939 Signed-off-by: Jan Mulder --- core/divesite.c | 1 + 1 file changed, 1 insertion(+) diff --git a/core/divesite.c b/core/divesite.c index 3d5547905..e4ba71abb 100644 --- a/core/divesite.c +++ b/core/divesite.c @@ -336,6 +336,7 @@ void merge_dive_sites(uint32_t ref, uint32_t* uuids, int count) if (d->dive_site_uuid != uuids[i] ) continue; d->dive_site_uuid = ref; + invalidate_dive_cache(d); } } -- cgit v1.2.3-70-g09d2