]> sigrok.org Git - pulseview.git/blobdiff - pv/prop/enum.cpp
Adjust pv:prop::Enum to GVariant-based sr_config_* functions
[pulseview.git] / pv / prop / enum.cpp
index 1694840a1c7a69357e860bbe047e4af2b681f4fe..894ba9f8e2754ded46f9e07b783484871d25eade 100644 (file)
 
 #include <assert.h>
 
+#include <glib-2.0/glib.h>
 #include <QComboBox>
 
 #include "enum.h"
 
+using namespace boost;
 using namespace std;
 
 namespace pv {
 namespace prop {
 
 Enum::Enum(QString name,
-       std::vector<std::pair<const void*, QString> > values,
-       boost::function<const void* ()> getter,
-       boost::function<void (const void*)> setter) :
+       vector<pair<const void*, QString> > values,
+       function<GVariant* ()> getter,
+       function<void (GVariant*)> setter) :
        Property(name),
        _values(values),
        _getter(getter),
@@ -43,15 +45,21 @@ Enum::Enum(QString name,
 
 QWidget* Enum::get_widget(QWidget *parent)
 {
-       if(_selector)
+       if (_selector)
                return _selector;
 
+       const void *value = NULL;
+       if (_getter)
+               value = _getter();
+
        _selector = new QComboBox(parent);
-       for(vector< pair<const void*, QString> >::const_iterator i =
-                       _values.begin();
-               i != _values.end(); i++)
-               _selector->addItem((*i).second,
-                       qVariantFromValue((void*)(*i).first));
+       for (unsigned int i = 0; i < _values.size(); i++) {
+               const pair<const void*, QString> &v = _values[i];
+               _selector->addItem(v.second,
+                       qVariantFromValue((void*)v.first));
+               if (v.first == value)
+                       _selector->setCurrentIndex(i);
+       }
 
        return _selector;
 }
@@ -60,14 +68,14 @@ void Enum::commit()
 {
        assert(_setter);
 
-       if(!_selector)
+       if (!_selector)
                return;
 
        const int index = _selector->currentIndex();
        if (index < 0)
                return;
 
-       _setter(_selector->itemData(index).value<void*>());
+       _setter(_selector->itemData(index).value<GVariant*>());
 }
 
 } // prop