fix CLI size string specification
accept "hz" as optional qualifier but nothing else properly return an error instead of quietly returning zero size
This commit is contained in:
parent
cb93f8a927
commit
f64c14141b
|
@ -107,7 +107,7 @@ int sr_session_load(const char *filename)
|
||||||
device->plugin->set_configuration(devcnt, SR_HWCAP_CAPTUREFILE, val);
|
device->plugin->set_configuration(devcnt, SR_HWCAP_CAPTUREFILE, val);
|
||||||
g_ptr_array_add(capturefiles, val);
|
g_ptr_array_add(capturefiles, val);
|
||||||
} else if (!strcmp(keys[j], "samplerate")) {
|
} else if (!strcmp(keys[j], "samplerate")) {
|
||||||
tmp_u64 = sr_parse_sizestring(val);
|
sr_parse_sizestring(val, &tmp_u64);
|
||||||
device->plugin->set_configuration(devcnt, SR_HWCAP_SAMPLERATE, &tmp_u64);
|
device->plugin->set_configuration(devcnt, SR_HWCAP_SAMPLERATE, &tmp_u64);
|
||||||
} else if (!strcmp(keys[j], "unitsize")) {
|
} else if (!strcmp(keys[j], "unitsize")) {
|
||||||
tmp_u64 = strtoull(val, NULL, 10);
|
tmp_u64 = strtoull(val, NULL, 10);
|
||||||
|
|
|
@ -142,7 +142,7 @@ char *sr_samplerate_string(uint64_t samplerate);
|
||||||
char *sr_period_string(uint64_t frequency);
|
char *sr_period_string(uint64_t frequency);
|
||||||
char **sr_parse_triggerstring(struct sr_device *device,
|
char **sr_parse_triggerstring(struct sr_device *device,
|
||||||
const char *triggerstring);
|
const char *triggerstring);
|
||||||
uint64_t sr_parse_sizestring(const char *sizestring);
|
int sr_parse_sizestring(const char *sizestring, uint64_t *size);
|
||||||
uint64_t sr_parse_timestring(const char *timestring);
|
uint64_t sr_parse_timestring(const char *timestring);
|
||||||
gboolean sr_parse_boolstring(const char *boolstring);
|
gboolean sr_parse_boolstring(const char *boolstring);
|
||||||
|
|
||||||
|
|
25
strutil.c
25
strutil.c
|
@ -186,19 +186,19 @@ char **sr_parse_triggerstring(struct sr_device *device,
|
||||||
* Spaces (but not other whitespace) between value and suffix are allowed.
|
* Spaces (but not other whitespace) between value and suffix are allowed.
|
||||||
*
|
*
|
||||||
* @param sizestring A string containing a (decimal) size value.
|
* @param sizestring A string containing a (decimal) size value.
|
||||||
* @return The string's size value as uint64_t.
|
* @param size Pointer to uint64_t which will contain the string's size value.
|
||||||
|
* @return SR_OK or error code
|
||||||
*
|
*
|
||||||
* TODO: Error handling.
|
|
||||||
*/
|
*/
|
||||||
uint64_t sr_parse_sizestring(const char *sizestring)
|
int sr_parse_sizestring(const char *sizestring, uint64_t *size)
|
||||||
{
|
{
|
||||||
int multiplier;
|
int multiplier, done;
|
||||||
uint64_t val;
|
|
||||||
char *s;
|
char *s;
|
||||||
|
|
||||||
val = strtoull(sizestring, &s, 10);
|
*size = strtoull(sizestring, &s, 10);
|
||||||
multiplier = 0;
|
multiplier = 0;
|
||||||
while (s && *s && multiplier == 0) {
|
done = FALSE;
|
||||||
|
while (s && *s && multiplier == 0 && !done) {
|
||||||
switch (*s) {
|
switch (*s) {
|
||||||
case ' ':
|
case ' ':
|
||||||
break;
|
break;
|
||||||
|
@ -215,15 +215,18 @@ uint64_t sr_parse_sizestring(const char *sizestring)
|
||||||
multiplier = SR_GHZ(1);
|
multiplier = SR_GHZ(1);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
val = 0;
|
done = TRUE;
|
||||||
multiplier = -1;
|
s--;
|
||||||
}
|
}
|
||||||
s++;
|
s++;
|
||||||
}
|
}
|
||||||
if (multiplier > 0)
|
if (multiplier > 0)
|
||||||
val *= multiplier;
|
*size *= multiplier;
|
||||||
|
|
||||||
return val;
|
if (*s && strcasecmp(s, "Hz"))
|
||||||
|
return SR_ERR;
|
||||||
|
|
||||||
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue