]> sigrok.org Git - pulseview.git/blobdiff - pv/dialogs/decoder.cpp
Modified Decode to only use LogicSignals
[pulseview.git] / pv / dialogs / decoder.cpp
index 292e4722c3928bdae995c1cd03030fa597059ba0..07375f649b35a883efa8b65991f5f1d300d8a88c 100644 (file)
@@ -22,8 +22,15 @@ extern "C" {
 #include <libsigrokdecode/libsigrokdecode.h>
 }
 
+#include <utility>
+
+#include <boost/foreach.hpp>
+
+#include <QDebug>
+
 #include "decoder.h"
 
+#include <pv/view/logicsignal.h>
 #include <pv/view/signal.h>
 
 using namespace boost;
@@ -33,10 +40,11 @@ namespace pv {
 namespace dialogs {
 
 Decoder::Decoder(QWidget *parent, const srd_decoder *decoder,
-       const vector< shared_ptr<view::Signal> > &sigs) :
+       const vector< shared_ptr<view::LogicSignal> > &sigs,
+       GHashTable *options) :
        QDialog(parent),
-       _decoder(decoder),
        _sigs(sigs),
+       _binding(decoder, options),
        _layout(this),
        _form(this),
        _form_layout(&_form),
@@ -62,7 +70,7 @@ Decoder::Decoder(QWidget *parent, const srd_decoder *decoder,
        _layout.addWidget(&_form);
        _layout.addWidget(&_button_box);
 
-       _form_layout.addRow(new QLabel("<h3>Probes</h3>", &_form));
+       _form_layout.addRow(new QLabel(tr("<h3>Probes</h3>"), &_form));
 
        // Add the mandatory probes
        for(probe = decoder->probes; probe; probe = probe->next) {
@@ -90,6 +98,19 @@ Decoder::Decoder(QWidget *parent, const srd_decoder *decoder,
 
        _form_layout.addRow(new QLabel(
                tr("<i>* Required Probes</i>"), &_form));
+
+       // Add the options
+       if (!_binding.properties().empty()) {
+               _form_layout.addRow(new QLabel(tr("<h3>Options</h3>"),
+                       &_form));
+               _binding.add_properties_to_form(&_form_layout);
+       }
+}
+
+void Decoder::accept()
+{
+       QDialog::accept();
+       _binding.commit();
 }
 
 QComboBox* Decoder::create_probe_selector(
@@ -101,10 +122,11 @@ QComboBox* Decoder::create_probe_selector(
        selector->setCurrentIndex(0);
 
        for(size_t i = 0; i < _sigs.size(); i++) {
-               const shared_ptr<view::Signal> s(_sigs[i]);
+               const shared_ptr<view::LogicSignal> s(_sigs[i]);
                assert(s);
 
-               if (s->enabled()) {
+               if (s->enabled())
+               {
                        selector->addItem(s->get_name(), qVariantFromValue(i));
                        if(s->get_name().toLower().contains(
                                QString(name).toLower()))
@@ -115,5 +137,24 @@ QComboBox* Decoder::create_probe_selector(
        return selector;
 }
 
+map<const srd_probe*, shared_ptr<view::LogicSignal> > Decoder::get_probes()
+{
+       map<const srd_probe*, shared_ptr<view::LogicSignal> > probe_map;
+       for(map<const srd_probe*, QComboBox*>::const_iterator i =
+               _probe_selector_map.begin();
+               i != _probe_selector_map.end(); i++)
+       {
+               const QComboBox *const combo = (*i).second;
+               const int probe_index =
+                       combo->itemData(combo->currentIndex()).value<int>();
+               if(probe_index >= 0) {
+                       shared_ptr<view::LogicSignal> sig = _sigs[probe_index];
+                       probe_map[(*i).first] = sig;
+               }
+       }
+
+       return probe_map;
+}
+
 } // namespace dialogs
 } // namespace pv