summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2013-06-04 07:36:38 +0900
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-06-05 10:17:01 +0900
commit2e2cb178d78bd584666528f7acc63608461a1504 (patch)
treeca41e90f693279a48ad44e74d9dfa0238e67de58
parenta13e97380b64f429a8d0c97f965bb8ec7b67af76 (diff)
downloadsubsurface-2e2cb178d78bd584666528f7acc63608461a1504.tar.gz
Merge dive tags when merging dives
.. otherwise the dive tags generally end up cleared when you download a duplicate dive from another dive computer. This uses MERGE_NONZERO, which means that if one of the dives has tags set, we'll prefer those tags. If both dives have tags set, we take the tags from the first ("preferred") dive. We could do a "just or all the bits together" too. But this way we at least take a set of tags that are consistent (ie we don't get both "boat" and "shore" set unless one of the original dives already had that inconsistency) Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--dive.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/dive.c b/dive.c
index 34025d68c..0625aa384 100644
--- a/dive.c
+++ b/dive.c
@@ -1796,6 +1796,7 @@ struct dive *merge_dives(struct dive *a, struct dive *b, int offset, gboolean pr
MERGE_MAX(res, a, b, number);
MERGE_NONZERO(res, a, b, cns);
MERGE_NONZERO(res, a, b, visibility);
+ MERGE_NONZERO(res, a, b, dive_tags);
merge_equipment(res, a, b);
merge_airtemps(res, a, b);
if (dl) {