X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fprop%2Fenum.cpp;h=a6a53764ca040b9366d5f589e1667607a6701ea1;hp=2249b570851fd183aeb943cb857923584902608a;hb=dbed5609ae31cdfc3e9db10f3ab91b7607c08372;hpb=7a2b7394beb87938121b48f81422873002d74155 diff --git a/pv/prop/enum.cpp b/pv/prop/enum.cpp index 2249b570..a6a53764 100644 --- a/pv/prop/enum.cpp +++ b/pv/prop/enum.cpp @@ -14,70 +14,90 @@ * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + * along with this program; if not, see . */ -#include +#include #include -#include "enum.h" +#include "enum.hpp" -using namespace boost; -using namespace std; +using std::pair; +using std::vector; namespace pv { namespace prop { -Enum::Enum(QString name, - vector > values, +Enum::Enum(QString name, QString desc, + vector > values, Getter getter, Setter setter) : - Property(name, getter, setter), - _values(values), - _selector(NULL) + Property(name, desc, getter, setter), + values_(values), + selector_(nullptr) { } -Enum::~Enum() +QWidget* Enum::get_widget(QWidget *parent, bool auto_commit) { - for (unsigned int i = 0; i < _values.size(); i++) - g_variant_unref(_values[i].first); -} + if (selector_) + return selector_; -QWidget* Enum::get_widget(QWidget *parent) -{ - if (_selector) - return _selector; + if (!getter_) + return nullptr; - GVariant *const value = _getter ? _getter() : NULL; + Glib::VariantBase variant = getter_(); + if (!variant.gobj()) + return nullptr; - _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 (value && g_variant_equal(v.first, value)) - _selector->setCurrentIndex(i); + 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)); } - g_variant_unref(value); + update_widget(); - return _selector; + if (auto_commit) + connect(selector_, SIGNAL(currentIndexChanged(int)), + this, SLOT(on_current_item_changed(int))); + + return selector_; +} + +void Enum::update_widget() +{ + if (!selector_) + return; + + Glib::VariantBase variant = getter_(); + assert(variant.gobj()); + + for (unsigned int i = 0; i < values_.size(); i++) { + const pair &v = values_[i]; + if (v.first.equal(variant)) + selector_->setCurrentIndex(i); + } } 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((GVariant*)_selector->itemData(index).value()); + setter_(selector_->itemData(index).value()); +} + +void Enum::on_current_item_changed(int) +{ + commit(); } -} // prop -} // pv +} // namespace prop +} // namespace pv