X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fprop%2Fenum.cpp;h=6717101b9288f51d66f0c294a95def76590a14f0;hb=2acdb232d6bb452cfdfaea3ef5218fb4da592329;hp=1694840a1c7a69357e860bbe047e4af2b681f4fe;hpb=24bb0bd140f7f8b00ea3c0cbe0c5d26dc03a3b69;p=pulseview.git diff --git a/pv/prop/enum.cpp b/pv/prop/enum.cpp index 1694840..6717101 100644 --- a/pv/prop/enum.cpp +++ b/pv/prop/enum.cpp @@ -22,52 +22,71 @@ #include -#include "enum.h" +#include "enum.hpp" -using namespace std; +using std::pair; +using std::vector; namespace pv { namespace prop { Enum::Enum(QString name, - std::vector > values, - boost::function getter, - boost::function setter) : - Property(name), - _values(values), - _getter(getter), - _setter(setter), - _selector(NULL) + vector > values, + Getter getter, Setter setter) : + Property(name, getter, setter), + values_(values), + selector_(NULL) { } -QWidget* Enum::get_widget(QWidget *parent) +Enum::~Enum() { - if(_selector) - return _selector; +} + +QWidget* Enum::get_widget(QWidget *parent, bool auto_commit) +{ + if (selector_) + return selector_; + + if (!getter_) + return NULL; + + Glib::VariantBase variant = getter_(); + if (!variant.gobj()) + return 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)); + selector_ = new QComboBox(parent); + 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); + } - return _selector; + if (auto_commit) + connect(selector_, SIGNAL(currentIndexChanged(int)), + this, SLOT(on_current_item_changed(int))); + + return selector_; } void Enum::commit() { - assert(_setter); + assert(setter_); - if(!_selector) + if (!selector_) return; - const int index = _selector->currentIndex(); + const int index = selector_->currentIndex(); if (index < 0) return; - _setter(_selector->itemData(index).value()); + setter_(selector_->itemData(index).value()); +} + +void Enum::on_current_item_changed(int) +{ + commit(); } } // prop