mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 14:25:27 +00:00
Add some more parsing functions
.. and fix the 'duration' parsing: it can be either in seconds, or in mm:ss format. Floating point doesn't make any sense. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
048a5a2b32
commit
fc38f4f0c4
1 changed files with 47 additions and 4 deletions
51
parse.c
51
parse.c
|
@ -421,12 +421,18 @@ static void temperature(char *buffer, void *_temperature)
|
|||
|
||||
static void sampletime(char *buffer, void *_time)
|
||||
{
|
||||
int i;
|
||||
int min, sec;
|
||||
duration_t *time = _time;
|
||||
union int_or_float val;
|
||||
|
||||
switch (integer_or_float(buffer, &val)) {
|
||||
case INTEGER:
|
||||
time->seconds = val.i;
|
||||
i = sscanf(buffer, "%d:%d", &min, &sec);
|
||||
switch (i) {
|
||||
case 1:
|
||||
sec = min;
|
||||
min = 0;
|
||||
/* fallthrough */
|
||||
case 2:
|
||||
time->seconds = sec + min*60;
|
||||
break;
|
||||
default:
|
||||
printf("Strange sample time reading %s\n", buffer);
|
||||
|
@ -434,6 +440,15 @@ static void sampletime(char *buffer, void *_time)
|
|||
free(buffer);
|
||||
}
|
||||
|
||||
static void duration(char *buffer, void *_time)
|
||||
{
|
||||
sampletime(buffer, _time);
|
||||
}
|
||||
|
||||
static void ignore(char *buffer, void *_time)
|
||||
{
|
||||
}
|
||||
|
||||
/* We're in samples - try to convert the random xml value to something useful */
|
||||
static void try_to_fill_sample(struct sample *sample, const char *name, char *buf)
|
||||
{
|
||||
|
@ -466,6 +481,34 @@ static void try_to_fill_dive(struct dive *dive, const char *name, char *buf)
|
|||
return;
|
||||
if (match("datetime", last, divedatetime, buf, &dive->when))
|
||||
return;
|
||||
if (match("maxdepth", last, depth, buf, &dive->maxdepth))
|
||||
return;
|
||||
if (match("meandepth", last, depth, buf, &dive->meandepth))
|
||||
return;
|
||||
if (match("divetime", last, duration, buf, &dive->duration))
|
||||
return;
|
||||
if (match("divetimesec", last, duration, buf, &dive->duration))
|
||||
return;
|
||||
if (match("surfacetime", last, duration, buf, &dive->surfacetime))
|
||||
return;
|
||||
if (match("airtemp", last, temperature, buf, &dive->airtemp))
|
||||
return;
|
||||
if (match("watertemp", last, temperature, buf, &dive->watertemp))
|
||||
return;
|
||||
if (match("cylinderstartpressure", last, pressure, buf, &dive->beginning_pressure))
|
||||
return;
|
||||
if (match("cylinderendpressure", last, pressure, buf, &dive->end_pressure))
|
||||
return;
|
||||
if (match("divenumber", last, ignore, buf, NULL))
|
||||
return;
|
||||
if (match("diveseries", last, ignore, buf, NULL))
|
||||
return;
|
||||
if (match("number", last, ignore, buf, NULL))
|
||||
return;
|
||||
if (match("size", last, ignore, buf, NULL))
|
||||
return;
|
||||
if (match("fingerprint", last, ignore, buf, NULL))
|
||||
return;
|
||||
nonmatch("dive", name, last, buf);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue