summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-07 13:35:59 -0700
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-07 13:35:59 -0700
commitd1ce43087834a881885371e0c7ece9fe55e46e64 (patch)
tree12b94032a48f0cf2896eaaa444b3b0bc8142b6e1
parent7bbcf2fabd0d74d46dba1f3fad5a6d85c6f6eb1d (diff)
downloadsubsurface-d1ce43087834a881885371e0c7ece9fe55e46e64.tar.gz
Tweak depth next_minmax() interface
Use start/end sample pointers to make a recursive algorithm possible. Also, clean up the end condition - we don't want to return an uninteresting minmax result just because we ran out of samples. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--profile.c36
1 files changed, 21 insertions, 15 deletions
diff --git a/profile.c b/profile.c
index d38046a4b..9c2f4ed12 100644
--- a/profile.c
+++ b/profile.c
@@ -67,26 +67,25 @@ static void plot_text(cairo_t *cr, text_render_options_t *tro,
* We exit early if we hit "enough" of a depth reversal,
* which is roughly 10 feet.
*/
-static int next_minmax(struct dive *dive, int index, int minmax)
+static struct sample *next_minmax(struct dive *dive, struct sample *sample, struct sample *end, int minmax)
{
const int enough = 3000;
- int timelimit, depthlimit, result;
- struct sample *sample = dive->sample + index;
+ struct sample *result;
+ int timelimit, depthlimit;
- if (index >= dive->samples)
+ if (sample >= end)
return 0;
timelimit = 24*60*60;
depthlimit = sample->depth.mm;
- result = 0;
+ result = NULL;
for (;;) {
int time, depth;
- index++;
sample++;
- if (index >= dive->samples)
- break;
+ if (sample >= end)
+ return NULL;
time = sample->time.seconds;
depth = sample->depth.mm;
if (time > timelimit)
@@ -106,7 +105,7 @@ static int next_minmax(struct dive *dive, int index, int minmax)
}
}
- result = index;
+ result = sample;
depthlimit = depth;
/* Look up to ten minutes into the future */
timelimit = time + 600;
@@ -120,9 +119,9 @@ static int next_minmax(struct dive *dive, int index, int minmax)
static void plot_depth_text(struct dive *dive, cairo_t *cr,
double maxx, double maxy)
{
+ struct sample *sample, *end;
double scalex, scaley;
int maxtime, maxdepth;
- int i;
/* Get plot scaling limits */
maxtime = round_seconds_up(dive->duration.seconds);
@@ -133,10 +132,17 @@ static void plot_depth_text(struct dive *dive, cairo_t *cr,
cairo_set_font_size(cr, 14);
cairo_set_source_rgb(cr, 1, 0.2, 0.2);
- i = 0;
- while ((i = next_minmax(dive, i, 1)) != 0) {
+
+ /*
+ * We never take the last sample into account.
+ * It should be a surface event anyway, although
+ * there are buggy cases where it isn't..
+ */
+ sample = dive->sample;
+ end = dive->sample + dive->samples - 1;
+
+ while ((sample = next_minmax(dive, sample, end, 1)) != NULL) {
text_render_options_t tro = {1.0, 0.2, 0.2, CENTER};
- struct sample *sample = dive->sample+i;
int sec = sample->time.seconds;
depth_t depth = sample->depth;
const char *fmt;
@@ -154,8 +160,8 @@ static void plot_depth_text(struct dive *dive, cairo_t *cr,
}
plot_text(cr, &tro, SCALE(sec, depth.mm), fmt, d);
- i = next_minmax(dive, i, 0);
- if (!i)
+ sample = next_minmax(dive, sample, end, 0);
+ if (!sample)
break;
}
}