summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/profile.c42
1 files changed, 25 insertions, 17 deletions
diff --git a/core/profile.c b/core/profile.c
index a012eb0cf..9fb2566bf 100644
--- a/core/profile.c
+++ b/core/profile.c
@@ -493,17 +493,19 @@ static void calculate_max_limits_new(struct dive *dive, struct divecomputer *giv
/* copy the previous entry (we know this exists), update time and depth
* and zero out the sensor pressure (since this is a synthetic entry)
* increment the entry pointer and the count of synthetic entries. */
-#define INSERT_ENTRY(_time, _depth, _sac) \
- *entry = entry[-1]; \
- entry->sec = _time; \
- entry->depth = _depth; \
- entry->running_sum = (entry - 1)->running_sum + (_time - (entry - 1)->sec) * (_depth + (entry - 1)->depth) / 2; \
- memset(entry->pressure, 0, sizeof(entry->pressure)); \
- entry->sac = _sac; \
- entry->ndl = -1; \
- entry->bearing = -1; \
- entry++; \
- idx++
+static void insert_entry(struct plot_info *pi, int idx, int time, int depth, int sac)
+{
+ struct plot_data *entry = pi->entry + idx;
+ struct plot_data *prev = pi->entry + idx - 1;
+ *entry = *prev;
+ entry->sec = time;
+ entry->depth = depth;
+ entry->running_sum = prev->running_sum + (time - prev->sec) * (depth + prev->depth) / 2;
+ memset(entry->pressure, 0, sizeof(entry->pressure));
+ entry->sac = sac;
+ entry->ndl = -1;
+ entry->bearing = -1;
+}
void free_plot_info_data(struct plot_info *pi)
{
@@ -562,12 +564,16 @@ static void populate_plot_entries(struct dive *dive, struct divecomputer *dc, st
/* Add events if they are between plot entries */
while (ev && (int)ev->time.seconds < lasttime + offset) {
- INSERT_ENTRY(ev->time.seconds, interpolate(lastdepth, depth, ev->time.seconds - lasttime, delta), sac);
+ insert_entry(pi, idx, ev->time.seconds, interpolate(lastdepth, depth, ev->time.seconds - lasttime, delta), sac);
+ entry++;
+ idx++;
ev = ev->next;
}
/* now insert the time interpolated entry */
- INSERT_ENTRY(lasttime + offset, interpolate(lastdepth, depth, offset, delta), sac);
+ insert_entry(pi, idx, lasttime + offset, interpolate(lastdepth, depth, offset, delta), sac);
+ entry++;
+ idx++;
/* skip events that happened at this time */
while (ev && (int)ev->time.seconds == lasttime + offset)
@@ -576,7 +582,9 @@ static void populate_plot_entries(struct dive *dive, struct divecomputer *dc, st
/* Add events if they are between plot entries */
while (ev && (int)ev->time.seconds < time) {
- INSERT_ENTRY(ev->time.seconds, interpolate(lastdepth, depth, ev->time.seconds - lasttime, delta), sac);
+ insert_entry(pi, idx, ev->time.seconds, interpolate(lastdepth, depth, ev->time.seconds - lasttime, delta), sac);
+ entry++;
+ idx++;
ev = ev->next;
}
@@ -628,8 +636,10 @@ static void populate_plot_entries(struct dive *dive, struct divecomputer *dc, st
int time = ev->time.seconds;
if (time > lasttime) {
- INSERT_ENTRY(ev->time.seconds, 0, 0);
+ insert_entry(pi, idx, ev->time.seconds, 0, 0);
lasttime = time;
+ idx++;
+ entry++;
}
ev = ev->next;
}
@@ -640,8 +650,6 @@ static void populate_plot_entries(struct dive *dive, struct divecomputer *dc, st
pi->nr = idx;
}
-#undef INSERT_ENTRY
-
/*
* Calculate the sac rate between the two plot entries 'first' and 'last'.
*