From e58fa7b9b506d5bb30268060279bc8dcbbeb99ea Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Sun, 4 Sep 2011 14:29:57 -0700 Subject: [PATCH] Parse uemis cylinder data This is some seriously crazy stuff. Instead of making sense as a divelog, the uemis xml makes more sense as a "dive computer settings dump". And I guess I can see why they'd do that. But it makes parsing it just incredibly annoying. The thing is more of a "these are the configurations I support as a dive computer thing" than a "this was the tank you were diving with". Signed-off-by: Linus Torvalds --- dive.h | 2 +- parse-xml.c | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/dive.h b/dive.h index 1386a3bf8..08194f6a9 100644 --- a/dive.h +++ b/dive.h @@ -108,7 +108,7 @@ struct sample { int cylinderindex; }; -#define MAX_CYLINDERS (4) +#define MAX_CYLINDERS (8) struct dive { time_t when; diff --git a/parse-xml.c b/parse-xml.c index 1ca046db7..75959d682 100644 --- a/parse-xml.c +++ b/parse-xml.c @@ -587,6 +587,7 @@ static void uemis_time_zone(char *buffer, void *_when) *when += tz * 3600; } +/* Christ. Uemis tank data is a total mess. */ static int uemis_dive_match(struct dive *dive, const char *name, int len, char *buf) { return MATCH(".units.length", uemis_length_unit, &units) || @@ -599,6 +600,20 @@ static int uemis_dive_match(struct dive *dive, const char *name, int len, char * MATCH(".date_time", uemis_date_time, &dive->when) || MATCH(".time_zone", uemis_time_zone, &dive->when) || MATCH(".ambient.temperature", decicelsius, &dive->airtemp) || + MATCH(".air.bottom_tank.size", cylindersize, &dive->cylinder[0].type.size) || + MATCH(".air.bottom_tank.oxygen", percent, &dive->cylinder[0].gasmix.o2) || + MATCH(".nitrox_1.bottom_tank.size", cylindersize, &dive->cylinder[1].type.size) || + MATCH(".nitrox_1.bottom_tank.oxygen", percent, &dive->cylinder[1].gasmix.o2) || + MATCH(".nitrox_2.bottom_tank.size", cylindersize, &dive->cylinder[2].type.size) || + MATCH(".nitrox_2.bottom_tank.oxygen", percent, &dive->cylinder[2].gasmix.o2) || + MATCH(".nitrox_2.deco_tank.size", cylindersize, &dive->cylinder[3].type.size) || + MATCH(".nitrox_2.deco_tank.oxygen", percent, &dive->cylinder[3].gasmix.o2) || + MATCH(".nitrox_3.bottom_tank.size", cylindersize, &dive->cylinder[4].type.size) || + MATCH(".nitrox_3.bottom_tank.oxygen", percent, &dive->cylinder[4].gasmix.o2) || + MATCH(".nitrox_3.deco_tank.size", cylindersize, &dive->cylinder[5].type.size) || + MATCH(".nitrox_3.deco_tank.oxygen", percent, &dive->cylinder[5].gasmix.o2) || + MATCH(".nitrox_3.travel_tank.size", cylindersize, &dive->cylinder[6].type.size) || + MATCH(".nitrox_3.travel_tank.oxygen", percent, &dive->cylinder[6].gasmix.o2) || 0; }