diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2014-10-12 14:49:18 -0400 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-10-12 14:49:18 -0400 |
commit | 613402f6c9dd73dfd36e65254fab9534765d9eb6 (patch) | |
tree | 39216ad8a0639c7bd926498e3d6912d5a3eaf171 /dive.c | |
parent | 49c9ad199f22f379a93bbc625a9e0b6339cf8110 (diff) | |
download | subsurface-613402f6c9dd73dfd36e65254fab9534765d9eb6.tar.gz |
Correctly copy all information in an event
Instead of trying to use add_event() to reinsert events we simply copy the
memory and adjust the pointers.
Using add_event() lost the gas mix and gas index information on gaschange
events - and this prevent switches between cylinders with the same gasmix
to be rendered correctly.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'dive.c')
-rw-r--r-- | dive.c | 13 |
1 files changed, 9 insertions, 4 deletions
@@ -491,18 +491,23 @@ void selective_copy_dive(struct dive *s, struct dive *d, struct dive_components } #undef CONDITIONAL_COPY_STRING -/* only copies events from the first dive computer */ +/* copies all events in this dive computer */ void copy_events(struct divecomputer *s, struct divecomputer *d) { - struct event *ev; + struct event *ev, **pev; if (!s || !d) return; ev = s->events; - d->events = NULL; + pev = &d->events; while (ev != NULL) { - add_event(d, ev->time.seconds, ev->type, ev->flags, ev->value, ev->name); + int size = sizeof(*ev) + strlen(ev->name) + 1; + struct event *new_ev = malloc(size); + memcpy(new_ev, ev, size); + *pev = new_ev; + pev = &new_ev->next; ev = ev->next; } + *pev = NULL; } int nr_cylinders(struct dive *dive) |