X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=sidebyside;f=pv%2Fprop%2Fenum.cpp;h=03524344048d5ca27e4a06b3a7f72f3f17e18fd6;hb=e8d009288de28cb194bc7964f96677c2baf900c9;hp=ce33c5a8e724b779214d61416e23cda74b91db39;hpb=d191508b2cfa24b5cf56c5184e7609353582f972;p=pulseview.git diff --git a/pv/prop/enum.cpp b/pv/prop/enum.cpp index ce33c5a..0352434 100644 --- a/pv/prop/enum.cpp +++ b/pv/prop/enum.cpp @@ -24,42 +24,49 @@ #include "enum.h" -using namespace boost; -using namespace std; +using std::pair; +using std::vector; namespace pv { namespace prop { Enum::Enum(QString name, - vector > values, - function getter, - function setter) : - Property(name), + vector > values, + Getter getter, Setter setter) : + Property(name, getter, setter), _values(values), - _getter(getter), - _setter(setter), _selector(NULL) { } -QWidget* Enum::get_widget(QWidget *parent) +Enum::~Enum() +{ +} + +QWidget* Enum::get_widget(QWidget *parent, bool auto_commit) { if (_selector) return _selector; - const void *value = NULL; - if(_getter) - value = _getter(); + if (!_getter) + return NULL; + + Glib::VariantBase variant = _getter(); + if (!variant.gobj()) + return NULL; _selector = new QComboBox(parent); - for(unsigned int i = 0; i < _values.size(); i++) { - const pair &v = _values[i]; - _selector->addItem(v.second, - qVariantFromValue((void*)v.first)); - if(v.first == value) + for (unsigned int i = 0; i < _values.size(); i++) { + const pair &v = _values[i]; + _selector->addItem(v.second, qVariantFromValue(v.first)); + if (v.first.equal(variant)) _selector->setCurrentIndex(i); } + if (auto_commit) + connect(_selector, SIGNAL(currentIndexChanged(int)), + this, SLOT(on_current_item_changed(int))); + return _selector; } @@ -74,7 +81,12 @@ void Enum::commit() if (index < 0) return; - _setter(_selector->itemData(index).value()); + _setter(_selector->itemData(index).value()); +} + +void Enum::on_current_item_changed(int) +{ + commit(); } } // prop