diff options
-rw-r--r-- | parse-xml.c | 18 | ||||
-rw-r--r-- | save-xml.c | 26 |
2 files changed, 44 insertions, 0 deletions
diff --git a/parse-xml.c b/parse-xml.c index 36a91f4f6..f62ce9891 100644 --- a/parse-xml.c +++ b/parse-xml.c @@ -308,6 +308,20 @@ static void pressure(char *buffer, void *_press) free(buffer); } +static void salinity(char *buffer, void *_salinity) +{ + int *salinity = _salinity; + union int_or_float val; + switch (integer_or_float(buffer, &val)) { + case FLOAT: + *salinity = val.fp * 10.0 + 0.5; + break; + default: + printf("Strange salinity reading %s\n", buffer); + } + free(buffer); +} + static void depth(char *buffer, void *_depth) { depth_t *depth = _depth; @@ -1106,6 +1120,10 @@ static void try_to_fill_dive(struct dive **divep, const char *name, char *buf) return; if (MATCH(".temperature.water", temperature, &dive->watertemp)) return; + if (MATCH(".surface.pressure", pressure, &dive->surface_pressure)) + return; + if (MATCH(".water.salinity", salinity, &dive->salinity)) + return; if (MATCH(".cylinderstartpressure", pressure, &dive->cylinder[0].start)) return; if (MATCH(".cylinderendpressure", pressure, &dive->cylinder[0].end)) diff --git a/save-xml.c b/save-xml.c index fb62651d6..824763c44 100644 --- a/save-xml.c +++ b/save-xml.c @@ -57,6 +57,11 @@ static void show_pressure(FILE *f, pressure_t pressure, const char *pre, const c show_milli(f, pre, pressure.mbar, " bar", post); } +static void show_salinity(FILE *f, int salinity, const char *pre, const char *post) +{ + if (salinity) + fprintf(f, "%s%.1f kg/l%s", pre, salinity / 10.0, post); +} /* * We're outputting utf8 in xml. * We need to quote the characters <, >, &. @@ -154,6 +159,25 @@ static void save_temperatures(FILE *f, struct dive *dive) fputs(" />\n", f); } +static void save_airpressure(FILE *f, struct dive *dive) +{ + if (!dive->surface_pressure.mbar) + return; + fputs(" <surface", f); + show_pressure(f, dive->surface_pressure, " pressure='", "'"); + fputs(" />\n", f); +} + +static void save_salinity(FILE *f, struct dive *dive) +{ + if (!dive->salinity) + return; + fputs(" <water ", f); + show_salinity(f, dive->salinity, " salinity='", "'"); + fputs(" />\n", f); +} + + static void show_location(FILE *f, struct dive *dive) { char buffer[80]; @@ -185,6 +209,8 @@ static void save_overview(FILE *f, struct dive *dive) { save_depths(f, dive); save_temperatures(f, dive); + save_airpressure(f, dive); + save_salinity(f, dive); show_duration(f, dive->surfacetime, " <surfacetime>", "</surfacetime>\n"); show_location(f, dive); show_utf8(f, dive->divemaster, " <divemaster>","</divemaster>\n", 0); |