X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fbinding%2Fdevice.cpp;h=521177ad4bfd3f7fb64a70d9c5f66fd726050aec;hp=224bc23a11079ea4593230a4637a2ff947e6886c;hb=49c62417b6b306607048b07f86b73f127e3084a3;hpb=3cc9ad7b867853315473df611612c562d562ed8a diff --git a/pv/binding/device.cpp b/pv/binding/device.cpp index 224bc23a..521177ad 100644 --- a/pv/binding/device.cpp +++ b/pv/binding/device.cpp @@ -56,21 +56,17 @@ namespace binding { Device::Device(shared_ptr configurable) : configurable_(configurable) { - assert(configurable); - for (auto entry : configurable->config_keys(ConfigKey::DEVICE_OPTIONS)) { - auto key = entry.first; - auto capabilities = entry.second; + auto keys = configurable->config_keys(); - Glib::VariantContainerBase gvar_list; + for (auto key : keys) { + + auto capabilities = configurable->config_capabilities(key); if (!capabilities.count(Capability::GET) || !capabilities.count(Capability::SET)) continue; - if (capabilities.count(Capability::LIST)) - gvar_list = configurable->config_list(key); - string name_str; try { name_str = key->description(); @@ -87,8 +83,7 @@ Device::Device(shared_ptr configurable) : config_changed(); }; - switch (key->id()) - { + switch (key->id()) { case SR_CONF_SAMPLERATE: // Sample rate values are not bound because they are shown // in the MainBar @@ -103,27 +98,35 @@ Device::Device(shared_ptr configurable) : case SR_CONF_BUFFERSIZE: case SR_CONF_TRIGGER_SOURCE: case SR_CONF_TRIGGER_SLOPE: - case SR_CONF_FILTER: case SR_CONF_COUPLING: case SR_CONF_CLOCK_EDGE: - bind_enum(name, gvar_list, get, set); + bind_enum(name, key, capabilities, get, set); break; + case SR_CONF_FILTER: case SR_CONF_EXTERNAL_CLOCK: case SR_CONF_RLE: + case SR_CONF_POWER_OFF: bind_bool(name, get, set); break; case SR_CONF_TIMEBASE: - bind_enum(name, gvar_list, get, set, print_timebase); + bind_enum(name, key, capabilities, get, set, print_timebase); break; case SR_CONF_VDIV: - bind_enum(name, gvar_list, get, set, print_vdiv); + bind_enum(name, key, capabilities, get, set, print_vdiv); break; case SR_CONF_VOLTAGE_THRESHOLD: - bind_enum(name, gvar_list, get, set, print_voltage_threshold); + bind_enum(name, key, capabilities, get, set, print_voltage_threshold); + break; + + case SR_CONF_PROBE_FACTOR: + if (capabilities.count(Capability::LIST)) + bind_enum(name, key, capabilities, get, set, print_probe_factor); + else + bind_int(name, "", pair(1, 500), get, set); break; default: @@ -141,7 +144,8 @@ void Device::bind_bool(const QString &name, } void Device::bind_enum(const QString &name, - Glib::VariantContainerBase gvar_list, Property::Getter getter, + const ConfigKey *key, std::set capabilities, + Property::Getter getter, Property::Setter setter, function printer) { Glib::VariantBase gvar; @@ -149,7 +153,10 @@ void Device::bind_enum(const QString &name, assert(configurable_); - Glib::VariantIter iter(gvar_list); + if (!capabilities.count(Capability::LIST)) + return; + + Glib::VariantIter iter(configurable_->config_list(key)); while ((iter.next_value(gvar))) values.push_back(make_pair(gvar, printer(gvar))); @@ -188,5 +195,12 @@ QString Device::print_voltage_threshold(Glib::VariantBase gvar) return QString("L<%1V H>%2V").arg(lo, 0, 'f', 1).arg(hi, 0, 'f', 1); } +QString Device::print_probe_factor(Glib::VariantBase gvar) +{ + uint64_t factor; + factor = g_variant_get_uint64(gvar.gobj()); + return QString("%1x").arg(factor); +} + } // binding } // pv