summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-08-30 20:54:43 -0700
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-08-30 20:54:43 -0700
commit3aa02ccba93648f2decab899a5b9c42b6bcea9bf (patch)
tree359cefd9120385d3ccf94cb8ed448f9e99453652
parent0ca546b31e5527713f11676bc965aa1ed8dac619 (diff)
downloadsubsurface-3aa02ccba93648f2decab899a5b9c42b6bcea9bf.tar.gz
Generate a default name for a dive, if it doesn't have one already
The name is a string containint date, time, depth and length. So it's useful even with nothing else going on. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--dive.h1
-rw-r--r--parse.c24
2 files changed, 25 insertions, 0 deletions
diff --git a/dive.h b/dive.h
index 53ecdfe00..ba9f66882 100644
--- a/dive.h
+++ b/dive.h
@@ -101,6 +101,7 @@ struct sample {
};
struct dive {
+ const char *name;
time_t when;
depth_t maxdepth, meandepth;
duration_t duration, surfacetime;
diff --git a/parse.c b/parse.c
index 1a8e3ba61..f90c16ce1 100644
--- a/parse.c
+++ b/parse.c
@@ -391,10 +391,34 @@ static void dive_start(void)
memset(&tm, 0, sizeof(tm));
}
+static char *generate_name(struct dive *dive)
+{
+ int len;
+ struct tm *tm;
+ char buffer[256], *p;
+
+ tm = gmtime(&dive->when);
+
+ len = snprintf(buffer, sizeof(buffer),
+ "%04d-%02d-%02d "
+ "%02d:%02d:%02d "
+ "(%d ft, %d min)\n",
+ tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday,
+ tm->tm_hour, tm->tm_min, tm->tm_sec,
+ to_feet(dive->maxdepth), dive->duration.seconds / 60);
+ p = malloc(len+1);
+ if (!p)
+ exit(1);
+ memcpy(p, buffer, len+1);
+ return p;
+}
+
static void dive_end(void)
{
if (!dive)
return;
+ if (!dive->name)
+ dive->name = generate_name(dive);
record_dive(dive);
dive = NULL;
}