]> sigrok.org Git - pulseview.git/blobdiff - pv/prop/enum.cpp
Make pv::prop objects run on GVariants
[pulseview.git] / pv / prop / enum.cpp
index 29f95d8ebcf9d19417a0fe4f8806b512b9f7b615..065fd548f22b336151d03da49f0c03e43456bce1 100644 (file)
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
  */
 
+#include <assert.h>
+
 #include <QComboBox>
 
 #include "enum.h"
 
+using namespace boost;
 using namespace std;
 
 namespace pv {
 namespace prop {
 
-Enum::Enum(QString name, vector< pair<int, QString> > values) :
-       Property(name),
+Enum::Enum(QString name,
+       vector<pair<GVariant*, QString> > values,
+       Getter getter, Setter setter) :
+       Property(name, getter, setter),
        _values(values),
        _selector(NULL)
 {
 }
 
+Enum::~Enum()
+{
+       for (unsigned int i = 0; i < _values.size(); i++)
+               g_variant_unref(_values[i].first);
+}
+
 QWidget* Enum::get_widget(QWidget *parent)
 {
-       if(_selector)
+       if (_selector)
                return _selector;
 
+       GVariant *const value = _getter ? _getter() : NULL;
+       assert(value);
+
        _selector = new QComboBox(parent);
-       for(vector< pair<int, QString> >::const_iterator i = _values.begin();
-               i != _values.end(); i++)
-               _selector->addItem((*i).second,
-                       qVariantFromValue((*i).first));
+       for (unsigned int i = 0; i < _values.size(); i++) {
+               const pair<GVariant*, QString> &v = _values[i];
+               _selector->addItem(v.second, qVariantFromValue((void*)v.first));
+               if (g_variant_compare(v.first, value) == 0)
+                       _selector->setCurrentIndex(i);
+       }
+
+       g_variant_unref(value);
 
        return _selector;
 }
 
+void Enum::commit()
+{
+       assert(_setter);
+
+       if (!_selector)
+               return;
+
+       const int index = _selector->currentIndex();
+       if (index < 0)
+               return;
+
+       _setter((GVariant*)_selector->itemData(index).value<void*>());
+}
+
 } // prop
 } // pv