aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2013-02-22 08:52:35 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-02-22 09:13:20 -0800
commit28aba5a2062cd8310f3f637e9572fe3a92d41dfd (patch)
tree0b7b7f77c6a885cb157de1269068f5f439c4728a
parente19669a2e5d0d9663a62449c1190c837dd5511f0 (diff)
downloadsubsurface-28aba5a2062cd8310f3f637e9572fe3a92d41dfd.tar.gz
Flesh out the UDDF xml parsing a bit more
This uses the example UDDF file from Jan Schubert's Heinrichs Weikamp DR5 dives, and now parses the dive dates, the cylinder mixes and the gas switch events correctly (or at least partially). It's not perfect: the gas mix has an "id" field that we ignore, and instead we just depend on the cylinders being in order (which they seem to be). And I have rather limited test-cases, so maybe something else is messed up too. But for the six example dives I have, this gives reasonable data. Test-data-by: Jan Schubert <Jan.Schubert@gmx.li> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--parse-xml.c52
1 files changed, 43 insertions, 9 deletions
diff --git a/parse-xml.c b/parse-xml.c
index b44d992cd..84a1475a3 100644
--- a/parse-xml.c
+++ b/parse-xml.c
@@ -108,6 +108,15 @@ static int cur_cylinder_index, cur_ws_index;
static int lastndl, laststoptime, laststopdepth, lastcns, lastpo2, lastindeco;
static int lastcylinderindex, lastsensor;
+/*
+ * If we don't have an explicit dive computer,
+ * we use the implicit one that every dive has..
+ */
+static struct divecomputer *get_dc(void)
+{
+ return cur_dc ? : &cur_dive->dc;
+}
+
static enum import_source {
UNKNOWN,
LIBDIVECOMPUTER,
@@ -342,6 +351,10 @@ static void percent(char *buffer, void *_fraction)
switch (integer_or_float(buffer, &val)) {
case FLOAT:
+ /* Turn fractions into percent.. */
+ if (val.fp <= 1.0)
+ val.fp *= 100;
+ /* Then turn percent into our integer permille format */
if (val.fp <= 100.0)
fraction->permille = val.fp * 10 + 0.5;
break;
@@ -524,12 +537,24 @@ static int divinglog_fill_sample(struct sample *sample, const char *name, int le
0;
}
+static void uddf_gasswitch(char *buffer, void *_sample)
+{
+ struct sample *sample = _sample;
+ int idx = atoi(buffer);
+ int seconds = sample->time.seconds;
+ struct dive *dive = cur_dive;
+ struct divecomputer *dc = get_dc();
+
+ add_gas_switch_event(dive, dc, seconds, idx);
+}
+
static int uddf_fill_sample(struct sample *sample, const char *name, int len, char *buf)
{
return MATCH(".divetime", sampletime, &sample->time) ||
MATCH(".depth", depth, &sample->depth) ||
MATCH(".temperature", temperature, &sample->temperature) ||
MATCH(".tankpressure", pressure, &sample->cylinderpressure) ||
+ MATCH(".switchmix.ref", uddf_gasswitch, sample) ||
0;
}
@@ -593,15 +618,6 @@ static void try_to_fill_event(const char *name, char *buf)
nonmatch("event", name, buf);
}
-/*
- * If we don't have an explicit dive computer,
- * we use the implicit one that every dive has..
- */
-static struct divecomputer *get_dc(void)
-{
- return cur_dc ? : &cur_dive->dc;
-}
-
static int match_dc_data_fields(struct divecomputer *dc, const char *name, int len, char *buf)
{
if (MATCH(".maxdepth", depth, &dc->maxdepth))
@@ -835,11 +851,28 @@ success:
*when = utc_mktime(&tm);
}
+#define uddf_datedata(name, offset) \
+static void uddf_##name(char *buffer, void *_when) \
+{ timestamp_t *when = _when; \
+ cur_tm.tm_##name = atoi(buffer) + offset; \
+ *when = utc_mktime(&cur_tm); }
+
+uddf_datedata(year, 0)
+uddf_datedata(mon, -1)
+uddf_datedata(mday, 0)
+uddf_datedata(hour, 0)
+uddf_datedata(min, 0)
+
static int uddf_dive_match(struct dive *dive, const char *name, int len, char *buf)
{
return MATCH(".datetime", uddf_datetime, &dive->when) ||
MATCH(".diveduration", duration, &dive->dc.duration) ||
MATCH(".greatestdepth", depth, &dive->dc.maxdepth) ||
+ MATCH(".date.year", uddf_year, &dive->when) ||
+ MATCH(".date.month", uddf_mon, &dive->when) ||
+ MATCH(".date.day", uddf_mday, &dive->when) ||
+ MATCH(".time.hour", uddf_hour, &dive->when) ||
+ MATCH(".time.minute", uddf_min, &dive->when) ||
0;
}
@@ -1381,6 +1414,7 @@ static struct nesting {
{ "SAMPLE", sample_start, sample_end },
{ "reading", sample_start, sample_end },
{ "event", event_start, event_end },
+ { "mix", cylinder_start, cylinder_end },
{ "gasmix", cylinder_start, cylinder_end },
{ "cylinder", cylinder_start, cylinder_end },
{ "weightsystem", ws_start, ws_end },