summaryrefslogtreecommitdiffstats
path: root/dive.c
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-08-16 07:55:31 -0600
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-08-16 09:21:20 -0600
commitdd49e3a9a92e3d1a1534a870e9e3b588845fb364 (patch)
tree64eb9e5cbea9dd01d61193c71f2f56124101c2e8 /dive.c
parentc58d136d3313692d275c73cdab44b9e71f637f09 (diff)
downloadsubsurface-dd49e3a9a92e3d1a1534a870e9e3b588845fb364.tar.gz
Cut'n'paste for dive data: implement some infrastructure
This commit doesn't do anything, yet. It just puts in place helper infrastructure that will later allow us to cut and paste parts of the data of one dive into another dive (or set of dives). Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'dive.c')
-rw-r--r--dive.c45
1 files changed, 40 insertions, 5 deletions
diff --git a/dive.c b/dive.c
index 8e51351fb..88233d394 100644
--- a/dive.c
+++ b/dive.c
@@ -421,6 +421,37 @@ struct dive *clone_dive(struct dive *s)
return dive;
}
+#define CONDITIONAL_COPY_STRING(_component) \
+ if (what._component) \
+ d->_component = copy_string(s->_component)
+
+// copy elements, depending on bits in what that are set
+void selective_copy_dive(struct dive *s, struct dive *d, struct dive_components what)
+{
+ clear_dive(d);
+ CONDITIONAL_COPY_STRING(location);
+ CONDITIONAL_COPY_STRING(notes);
+ CONDITIONAL_COPY_STRING(divemaster);
+ CONDITIONAL_COPY_STRING(buddy);
+ CONDITIONAL_COPY_STRING(suit);
+ if (what.rating)
+ d->rating = s->rating;
+ if (what.visibility)
+ d->visibility = s->visibility;
+ if (what.gps) {
+ d->longitude = s->longitude;
+ d->latitude = s->latitude;
+ }
+ if (what.tags)
+ STRUCTURED_LIST_COPY(struct tag_entry, s->tag_list, d->tag_list, copy_tl);
+ if (what.cylinders)
+ copy_cylinders(s, d, false);
+ if (what.weights)
+ for (int i = 0; i < MAX_WEIGHTSYSTEMS; i++)
+ d->weightsystem[i] = s->weightsystem[i];
+}
+#undef CONDITIONAL_COPY_STRING
+
/* only copies events from the first dive computer */
void copy_events(struct divecomputer *s, struct divecomputer *d)
{
@@ -459,16 +490,20 @@ int nr_weightsystems(struct dive *dive)
return nr;
}
+/* copy the equipment data part of the cylinders */
void copy_cylinders(struct dive *s, struct dive *d, bool used_only)
{
int i;
if (!s || !d)
return;
- for (i = 0; i < MAX_CYLINDERS; i++)
- if (!used_only || is_cylinder_used(s, i))
- d->cylinder[i] = s->cylinder[i];
- else
- memset(&d->cylinder[i], 0, sizeof(cylinder_t));
+ for (i = 0; i < MAX_CYLINDERS; i++) {
+ memset(&d->cylinder[i], 0, sizeof(cylinder_t));
+ if (!used_only || is_cylinder_used(s, i)) {
+ d->cylinder[i].type = s->cylinder[i].type;
+ d->cylinder[i].gasmix = s->cylinder[i].gasmix;
+ d->cylinder[i].depth = s->cylinder[i].depth;
+ }
+ }
}
void copy_samples(struct divecomputer *s, struct divecomputer *d)