X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-cli.git;a=blobdiff_plain;f=show.c;h=608698723c6426977d1dd91a17c14ede1599036c;hp=ce001cdc55b47c3b099ad71989612c24cea53771;hb=adf8d7a9de5da50b7ee9c9d601c0258c830b38f0;hpb=a360511e48f7b77a5535b0391bf391edd2f4718c diff --git a/show.c b/show.c index ce001cd..6086987 100644 --- a/show.c +++ b/show.c @@ -399,6 +399,8 @@ void show_dev_detail(void) unsigned int num_devices, i, j; char *tmp_str, *s, c; const char **stropts; + double tmp_flt; + const double *fltopts; if (parse_driver(opt_drv, &driver_from_opt, NULL)) { /* A driver was specified, report driver-wide options now. */ @@ -706,12 +708,32 @@ void show_dev_detail(void) } else if (srci->datatype == SR_T_FLOAT) { printf(" %s: ", srci->id); + tmp_flt = 0.0; if (maybe_config_get(driver, sdi, channel_group, key, &gvar) == SR_OK) { - printf("%f\n", g_variant_get_double(gvar)); + tmp_flt = g_variant_get_double(gvar); g_variant_unref(gvar); - } else + } + if (maybe_config_list(driver, sdi, channel_group, key, + &gvar) != SR_OK) { + if (tmp_flt) { + /* Can't list, but got a value to show. */ + printf("%f (current)", tmp_flt); + } printf("\n"); + continue; + } + fltopts = g_variant_get_fixed_array(gvar, + &num_elements, sizeof(tmp_flt)); + for (i = 0; i < num_elements; i++) { + if (i) + printf(", "); + printf("%f", fltopts[i]); + if (tmp_flt && fltopts[i] == tmp_flt) + printf(" (current)"); + } + printf("\n"); + g_variant_unref(gvar); } else if (srci->datatype == SR_T_RATIONAL_PERIOD || srci->datatype == SR_T_RATIONAL_VOLT) { @@ -1062,7 +1084,7 @@ static void print_serial_port(gpointer data, gpointer user_data) port = (void *)data; (void)user_data; - printf("\t%s\t%s\n", port->name, port->description); + printf(" %s\t%s\n", port->name, port->description); } void show_serial_ports(void)