From 7bf4dec2e22d07ba24d40d5c9f9ad5f5bf9f937e Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Sat, 17 Sep 2016 14:28:34 +0200 Subject: options/tie: simplify enum combobox --- options/tie.hpp | 80 +++++++++++++++------------------------------------------ 1 file changed, 21 insertions(+), 59 deletions(-) (limited to 'options') diff --git a/options/tie.hpp b/options/tie.hpp index 228aef8c..22b46bd0 100644 --- a/options/tie.hpp +++ b/options/tie.hpp @@ -26,75 +26,37 @@ tie_setting(value& v, QComboBox* cb) cb->setCurrentIndex(cb->findData((unsigned)static_cast(v))); v = static_cast(cb->currentData().toInt()); - // QObject::connect plays badly with std::bind of std::shared_ptr. Data seems to get freed. - // Direct accesses of cb->currentData within arbitrary thread context cause crashes as well. - // Hence we go for a verbose implementation. - - std::vector enum_cases; - enum_cases.reserve(unsigned(cb->count())); + std::vector enum_cases(unsigned(cb->count())); for (int i = 0; i < cb->count(); i++) - enum_cases.push_back(cb->itemData(i).toInt()); - - struct fn1 - { - value& v; - QComboBox* cb; - std::vector enum_cases; - - fn1(value& v, QComboBox* cb, const std::vector& enum_cases) : - v(v), - cb(cb), - enum_cases(enum_cases) - { - } - - void operator()(int idx) - { - if (idx < 0 || idx >= (int)enum_cases.size()) - v = static_cast(-1); - else - v = static_cast(t(std::intptr_t(enum_cases[idx]))); - } - }; - - struct fn2 - { - value& v; - QComboBox* cb; - std::vector enum_cases; - - fn2(value& v, QComboBox* cb, const std::vector& enum_cases) : - v(v), - cb(cb), - enum_cases(enum_cases) - { - } - - void operator()(int val) - { - for (unsigned i = 0; i < enum_cases.size(); i++) - { - if (val == enum_cases[i]) - { - cb->setCurrentIndex(i); - return; - } - } - cb->setCurrentIndex(-1); - } - }; + enum_cases[i] = cb->itemData(i).toInt(); base_value::connect(cb, static_cast(&QComboBox::currentIndexChanged), &v, - fn1(v, cb, enum_cases), + [&, enum_cases](int idx) { + if (idx < 0 || idx >= (int)enum_cases.size()) + v = static_cast(-1); + else + v = static_cast(enum_cases[idx]); + }, v.DIRECT_CONNTYPE); base_value::connect(&v, static_cast(&base_value::valueChanged), cb, - fn2(v, cb, enum_cases), - v.DIRECT_CONNTYPE); + [&, enum_cases](int val) { + for (unsigned i = 0; i < enum_cases.size(); i++) + { + if (val == enum_cases[i]) + { + cb->setCurrentIndex(i); + return; + } + } + cb->setCurrentIndex(-1); + }, + // don't change or else hatire crashes -sh 20160917 + Qt::QueuedConnection); } template<> -- cgit v1.2.3