X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fprop%2Fenum.cpp;h=ced2f2bb0c79664b98af758a2ecf42b6d711316a;hb=0912f8a7b0fde306f2616fef3c63ce742006602d;hp=1694840a1c7a69357e860bbe047e4af2b681f4fe;hpb=24bb0bd140f7f8b00ea3c0cbe0c5d26dc03a3b69;p=pulseview.git diff --git a/pv/prop/enum.cpp b/pv/prop/enum.cpp index 1694840..ced2f2b 100644 --- a/pv/prop/enum.cpp +++ b/pv/prop/enum.cpp @@ -24,34 +24,43 @@ #include "enum.h" +using namespace boost; using namespace std; namespace pv { namespace prop { Enum::Enum(QString name, - std::vector > values, - boost::function getter, - boost::function setter) : - Property(name), + vector > values, + Getter getter, Setter setter) : + Property(name, getter, setter), _values(values), - _getter(getter), - _setter(setter), _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; + _selector = new QComboBox(parent); - for(vector< pair >::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 &v = _values[i]; + _selector->addItem(v.second, qVariantFromValue((void*)v.first)); + if (value && g_variant_compare(v.first, value) == 0) + _selector->setCurrentIndex(i); + } + + g_variant_unref(value); return _selector; } @@ -60,14 +69,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()); + _setter((GVariant*)_selector->itemData(index).value()); } } // prop