Use libsigrok C++ bindings (patch version 7).
[pulseview.git] / pv / prop / bool.cpp
index ad9a13e7c0e05bc710fc7d385b6ad7e6b22a04be..699656f75d3ab60adbd81006d0c4c692886161db 100644 (file)
@@ -24,9 +24,6 @@
 
 #include "bool.h"
 
-using namespace std;
-using namespace boost;
-
 namespace pv {
 namespace prop {
 
@@ -40,20 +37,27 @@ Bool::~Bool()
 {
 }
 
-QWidget* Bool::get_widget(QWidget *parent)
+QWidget* Bool::get_widget(QWidget *parent, bool auto_commit)
 {
        if (_check_box)
                return _check_box;
 
-       _check_box = new QCheckBox(name(), parent);
+       if (!_getter)
+               return NULL;
+
+       Glib::VariantBase variant = _getter();
+       if (!variant.gobj())
+               return NULL;
+
+       bool value = Glib::VariantBase::cast_dynamic<Glib::Variant<bool>>(
+               variant).get();
 
-       GVariant *const value = _getter ? _getter() : NULL;
+       _check_box = new QCheckBox(name(), parent);
+       _check_box->setCheckState(value ? Qt::Checked : Qt::Unchecked);
 
-       if (value) {
-               _check_box->setCheckState(g_variant_get_boolean(value) ?
-                       Qt::Checked : Qt::Unchecked);
-               g_variant_unref(value);
-       }
+       if (auto_commit)
+               connect(_check_box, SIGNAL(stateChanged(int)),
+                       this, SLOT(on_state_changed(int)));
 
        return _check_box;
 }
@@ -70,9 +74,14 @@ void Bool::commit()
        if (!_check_box)
                return;
 
-       _setter(g_variant_new_boolean(
+       _setter(Glib::Variant<bool>::create(
                _check_box->checkState() == Qt::Checked));
 }
 
+void Bool::on_state_changed(int)
+{
+       commit();
+}
+
 } // prop
 } // pv