summaryrefslogtreecommitdiffstats
path: root/core/dive.c
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2019-07-25 22:29:07 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-07-27 11:55:05 -0700
commita0cd89f850d727f161eba19e0ee4b19e5aaf8f57 (patch)
treed11a8c60dc03aadc34ae2719ec7d270c4f9fdc07 /core/dive.c
parent999a63a5bba58d39a23da34b0eddc37324298699 (diff)
downloadsubsurface-a0cd89f850d727f161eba19e0ee4b19e5aaf8f57.tar.gz
Core: split copy_cylinders() in two functions
copy_cylinders() copied the cylinders of one dive onto another dive and then reset to the original gas values. Presumably, when copy and pasting cylinders from one dive to another, only the types should be copied, not the gases. Moreover, the function could either copy all or only the used cylinders. Firstly, the code was bogus: when restoring the pressures the indices were mixed up: the old indices were used. Thus, when there where uncopied cylinders, not all pressure values were restored. Secondly, it is not clear that all callers actually want to restore the pressure data. It rather appears the two (out of three) callers actually just want to copy the cylinders. Therefore, split the function in 1) copy_cylinders(): copy the cylinders with pressure data 2) copy_cylinder_types(): copy only the cylinder information Since there is only one caller of copy_cylinder_types(), the "used_only" argument can be removed. Since all cylinders are copied there is no point in storing the pressure data. Don't overwrite it in the first place. The resulting two functions should be distinctly easier to understand. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core/dive.c')
-rw-r--r--core/dive.c55
1 files changed, 29 insertions, 26 deletions
diff --git a/core/dive.c b/core/dive.c
index fb1159564..9a5171c32 100644
--- a/core/dive.c
+++ b/core/dive.c
@@ -433,6 +433,7 @@ struct dive *move_dive(struct dive *s)
d->_component = copy_string(s->_component)
// copy elements, depending on bits in what that are set
+static void copy_cylinder_types(const struct dive *s, struct dive *d);
void selective_copy_dive(const struct dive *s, struct dive *d, struct dive_components what, bool clear)
{
if (clear)
@@ -452,7 +453,7 @@ void selective_copy_dive(const struct dive *s, struct dive *d, struct dive_compo
if (what.tags)
d->tag_list = taglist_copy(s->tag_list);
if (what.cylinders)
- copy_cylinders(s, d, false);
+ copy_cylinder_types(s, d);
if (what.weights)
copy_weights(&s->weightsystems, &d->weightsystems);
}
@@ -509,42 +510,44 @@ int nr_weightsystems(const struct dive *dive)
return dive->weightsystems.nr;
}
-/* copy the equipment data part of the cylinders */
-void copy_cylinders(const struct dive *s, struct dive *d, bool used_only)
+/* copy the equipment data part of the cylinders but keep pressures */
+static void copy_cylinder_types(const struct dive *s, struct dive *d)
{
- int i,j;
- cylinder_t t[MAX_CYLINDERS];
+ int i;
if (!s || !d)
return;
for (i = 0; i < MAX_CYLINDERS; i++) {
- // Store the original start and end pressures
- t[i].start.mbar = d->cylinder[i].start.mbar;
- t[i].end.mbar = d->cylinder[i].end.mbar;
- t[i].sample_start.mbar = d->cylinder[i].sample_start.mbar;
- t[i].sample_end.mbar = d->cylinder[i].sample_end.mbar;
-
free((void *)d->cylinder[i].type.description);
- memset(&d->cylinder[i], 0, sizeof(cylinder_t));
+ d->cylinder[i].type = s->cylinder[i].type;
+ d->cylinder[i].type.description = s->cylinder[i].type.description ?
+ strdup(s->cylinder[i].type.description) : NULL;
+ d->cylinder[i].gasmix = s->cylinder[i].gasmix;
+ d->cylinder[i].depth = s->cylinder[i].depth;
+ d->cylinder[i].cylinder_use = s->cylinder[i].cylinder_use;
+ d->cylinder[i].manually_added = true;
}
- for (i = j = 0; i < MAX_CYLINDERS; i++) {
- if (!used_only || is_cylinder_used(s, i) || s->cylinder[i].cylinder_use == NOT_USED) {
- d->cylinder[j].type = s->cylinder[i].type;
- d->cylinder[j].type.description = copy_string(s->cylinder[i].type.description);
- d->cylinder[j].gasmix = s->cylinder[i].gasmix;
- d->cylinder[j].depth = s->cylinder[i].depth;
- d->cylinder[j].cylinder_use = s->cylinder[i].cylinder_use;
- d->cylinder[j].manually_added = true;
-
- // Restore the start and end pressures from original cylinder
- d->cylinder[i].start.mbar = t[i].start.mbar;
- d->cylinder[i].end.mbar = t[i].end.mbar;
- d->cylinder[i].sample_start.mbar = t[i].sample_start.mbar;
- d->cylinder[i].sample_end.mbar = t[i].sample_end.mbar;
+}
+
+void copy_cylinders(const struct dive *s, struct dive *d, bool used_only)
+{
+ int i, j;
+ if (!s || !d)
+ return;
+ for (i = 0, j = 0; i < MAX_CYLINDERS; i++) {
+ if (!used_only || is_cylinder_used(s, i) || s->cylinder[i].cylinder_use == NOT_USED) {
+ free((void *)d->cylinder[j].type.description);
+ d->cylinder[j] = s->cylinder[i];
+ if (d->cylinder[j].type.description)
+ d->cylinder[j].type.description = strdup(d->cylinder[j].type.description);
j++;
}
}
+ for ( ; j < MAX_CYLINDERS; j++) {
+ free((void *)d->cylinder[j].type.description);
+ memset(d->cylinder + j, 0, sizeof(d->cylinder[j]));
+ }
}
void copy_samples(const struct divecomputer *s, struct divecomputer *d)