move samplerate/period printers and parsers into libsigrok

This commit is contained in:
Bert Vermeulen 2011-01-31 22:29:40 +01:00
parent a59606dfff
commit 40f5ddac01
4 changed files with 130 additions and 2 deletions

View File

@ -29,7 +29,8 @@ libsigrok_la_SOURCES = \
device.c \
session.c \
hwplugin.c \
filter.c
filter.c \
strutil.c
libsigrok_la_LIBADD = \
$(LIBOBJS) \

View File

@ -30,7 +30,6 @@ libsigrokoutput_la_SOURCES = \
text/bits.c \
text/hex.c \
text/ascii.c \
common.c \
output.c
libsigrokoutput_la_CFLAGS = \

View File

@ -132,5 +132,8 @@ struct sr_output_format **sr_output_list(void);
char *sr_samplerate_string(uint64_t samplerate);
char *sr_period_string(uint64_t frequency);
char **sr_parse_triggerstring(struct sr_device *device, const char *triggerstring);
uint64_t sr_parse_sizestring(const char *sizestring);
uint64_t sr_parse_timestring(const char *timestring);
#endif

View File

@ -95,3 +95,128 @@ char *sr_period_string(uint64_t frequency)
return o;
}
char **sr_parse_triggerstring(struct sr_device *device, const char *triggerstring)
{
GSList *l;
struct probe *probe;
int max_probes, probenum, i;
char **tokens, **triggerlist, *trigger, *tc, *trigger_types;
gboolean error;
max_probes = g_slist_length(device->probes);
error = FALSE;
triggerlist = g_malloc0(max_probes * sizeof(char *));
tokens = g_strsplit(triggerstring, ",", max_probes);
trigger_types = device->plugin->get_device_info(0, SR_DI_TRIGGER_TYPES);
if (trigger_types == NULL)
return NULL;
for (i = 0; tokens[i]; i++) {
if (tokens[i][0] < '0' || tokens[i][0] > '9') {
/* Named probe */
probenum = 0;
for (l = device->probes; l; l = l->next) {
probe = (struct probe *)l->data;
if (probe->enabled
&& !strncmp(probe->name, tokens[i],
strlen(probe->name))) {
probenum = probe->index;
break;
}
}
} else {
probenum = strtol(tokens[i], NULL, 10);
}
if (probenum < 1 || probenum > max_probes) {
printf("Invalid probe.\n");
error = TRUE;
break;
}
if ((trigger = strchr(tokens[i], '='))) {
for (tc = ++trigger; *tc; tc++) {
if (strchr(trigger_types, *tc) == NULL) {
printf("Unsupported trigger type "
"'%c'\n", *tc);
error = TRUE;
break;
}
}
if (!error)
triggerlist[probenum - 1] = g_strdup(trigger);
}
}
g_strfreev(tokens);
if (error) {
for (i = 0; i < max_probes; i++)
if (triggerlist[i])
g_free(triggerlist[i]);
g_free(triggerlist);
triggerlist = NULL;
}
return triggerlist;
}
uint64_t sr_parse_sizestring(const char *sizestring)
{
int multiplier;
uint64_t val;
char *s;
val = strtoull(sizestring, &s, 10);
multiplier = 0;
while (s && *s && multiplier == 0) {
switch (*s) {
case ' ':
break;
case 'k':
case 'K':
multiplier = KHZ(1);
break;
case 'm':
case 'M':
multiplier = MHZ(1);
break;
case 'g':
case 'G':
multiplier = GHZ(1);
break;
default:
val = 0;
multiplier = -1;
}
s++;
}
if (multiplier > 0)
val *= multiplier;
return val;
}
uint64_t sr_parse_timestring(const char *timestring)
{
uint64_t time_msec;
char *s;
time_msec = strtoull(timestring, &s, 10);
if (time_msec == 0 && s == timestring)
return 0;
if (s && *s) {
while (*s == ' ')
s++;
if (!strcmp(s, "s"))
time_msec *= 1000;
else if (!strcmp(s, "ms"))
; /* redundant */
else
return 0;
}
return time_msec;
}