X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fprop%2Fenum.cpp;h=7a4a7837ff0e319cd8cd23535321386311f0283d;hb=56853c982046f78abe433f4f096f9305f8bcf806;hp=f762bd1a8ab83e56a1d8f2e9d3e733e54d9dc573;hpb=8a017a8bbc52e19c4d83362dbf58eb7ae447fd8b;p=pulseview.git
diff --git a/pv/prop/enum.cpp b/pv/prop/enum.cpp
index f762bd1..7a4a783 100644
--- a/pv/prop/enum.cpp
+++ b/pv/prop/enum.cpp
@@ -14,62 +14,75 @@
* 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,
- function getter,
- 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_(nullptr)
{
}
-QWidget* Enum::get_widget(QWidget *parent)
+QWidget* Enum::get_widget(QWidget *parent, bool auto_commit)
{
- if (_selector)
- return _selector;
+ if (selector_)
+ return selector_;
- _selector = new QComboBox(parent);
- for (vector< pair >::const_iterator i =
- _values.begin();
- i != _values.end(); i++)
- _selector->addItem((*i).second,
- qVariantFromValue((void*)(*i).first));
+ if (!getter_)
+ return nullptr;
- return _selector;
+ 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(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_;
}
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
-} // pv
+} // namespace prop
+} // namespace pv