#endif
}
+static gint sort_probes(gconstpointer a, gconstpointer b)
+{
+ const struct sr_probe *pa = a, *pb = b;
+
+ return pa->index - pb->index;
+}
+
static void print_dev_line(const struct sr_dev_inst *sdi)
{
struct sr_probe *probe;
- GSList *l;
+ GSList *sl, *l;
GString *s;
GVariant *gvar;
probe = sdi->probes->data;
g_string_append_printf(s, "with 1 probe: %s", probe->name);
} else {
- g_string_append_printf(s, "with %d probes:", g_slist_length(sdi->probes));
- for (l = sdi->probes; l; l = l->next) {
+ sl = g_slist_sort(g_slist_copy(sdi->probes), sort_probes);
+ g_string_append_printf(s, "with %d probes:", g_slist_length(sl));
+ for (l = sl; l; l = l->next) {
probe = l->data;
g_string_append_printf(s, " %s", probe->name);
}
+ g_slist_free(sl);
}
}
g_string_append_printf(s, "\n");
GSList *devices, *pgl, *prl;
GVariant *gvar_opts, *gvar_dict, *gvar_list, *gvar;
gsize num_opts, num_elements;
+ double dlow, dhigh, dcur_low, dcur_high;
const uint64_t *uint64, p, q, low, high;
uint64_t cur_low, cur_high;
const int32_t *opts;
} else
printf("on, off\n");
+ } else if (srci->datatype == SR_T_DOUBLE_RANGE) {
+ printf(" %s: ", srci->id);
+ if (sr_config_list(sdi->driver, sdi, probe_group, srci->key,
+ &gvar_list) != SR_OK) {
+ printf("\n");
+ continue;
+ }
+
+ if (sr_config_get(sdi->driver, sdi, NULL, srci->key, &gvar) == SR_OK) {
+ g_variant_get(gvar, "(dd)", &dcur_low, &dcur_high);
+ g_variant_unref(gvar);
+ } else {
+ dcur_low = 0;
+ dcur_high = 0;
+ }
+
+ num_elements = g_variant_n_children(gvar_list);
+ for (i = 0; i < num_elements; i++) {
+ gvar = g_variant_get_child_value(gvar_list, i);
+ g_variant_get(gvar, "(dd)", &dlow, &dhigh);
+ g_variant_unref(gvar);
+ if (i)
+ printf(", ");
+ printf("%.1f-%.1f", dlow, dhigh);
+ if (dlow == dcur_low && dhigh == dcur_high)
+ printf(" (current)");
+ }
+ printf("\n");
+ g_variant_unref(gvar_list);
+
} else {
/* Everything else */
#ifdef HAVE_SRD
void show_pd_detail(void)
{
- GSList *l, *ll;
+ GSList *l, *ll, *ol;
struct srd_decoder *dec;
struct srd_decoder_option *o;
char **pdtokens, **pdtok, *optsep, **ann, *val, *doc;
if (dec->options) {
for (l = dec->options; l; l = l->next) {
o = l->data;
+ printf("- %s: %s (", o->id, o->desc);
+ for (ol = o->values; ol; ol = ol->next) {
+ val = g_variant_print(ol->data, FALSE);
+ printf("%s, ", val);
+ g_free(val);
+ }
val = g_variant_print(o->def, FALSE);
- printf("- %s: %s (default %s)\n", o->id,
- o->desc, val);
+ printf("default %s)\n", val);
g_free(val);
}
} else {