]> sigrok.org Git - pulseview.git/blobdiff - pv/data/decoder.cpp
Create decoder instance
[pulseview.git] / pv / data / decoder.cpp
index cdfe57f9540b3bd8de3c8c787ed8121490567523..65854ee056b9384c1c0a7a774de78ee9fdb3f1b3 100644 (file)
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
  */
 
+#include <libsigrokdecode/libsigrokdecode.h>
+
 #include "decoder.h"
 
 #include <pv/view/signal.h>
 
+using namespace boost;
+using namespace std;
+
 namespace pv {
 namespace data {
 
@@ -29,8 +34,10 @@ Decoder::Decoder(const srd_decoder *const dec,
        std::map<const srd_probe*,
                boost::shared_ptr<pv::view::Signal> > probes) :
        _decoder(dec),
-       _probes(probes)
+       _probes(probes),
+       _decoder_inst(NULL)
 {
+       init_decoder();
 }
 
 const srd_decoder* Decoder::get_decoder() const
@@ -38,6 +45,28 @@ const srd_decoder* Decoder::get_decoder() const
        return _decoder;
 }
 
+void Decoder::init_decoder()
+{
+       _decoder_inst = srd_inst_new(_decoder->id, NULL);
+       assert(_decoder_inst);
+
+       GHashTable *probes = g_hash_table_new_full(g_str_hash,
+               g_str_equal, g_free, (GDestroyNotify)g_variant_unref);
+
+       for(map<const srd_probe*, shared_ptr<view::Signal> >::
+               const_iterator i = _probes.begin();
+               i != _probes.end(); i++)
+       {
+               shared_ptr<view::Signal> signal((*i).second);
+               GVariant *const gvar = g_variant_new_int32(
+                       signal->probe()->index);
+               g_variant_ref_sink(gvar);
+               g_hash_table_insert(probes, (*i).first->id, gvar);
+       }
+
+       srd_inst_probe_set_all(_decoder_inst, probes);
+}
+
 void Decoder::clear_snapshots()
 {
 }