static const int64_t DecodeChunkLength;
public:
- Decoder(const srd_decoder *const decoder,
- std::map<const srd_probe*,
- boost::shared_ptr<pv::view::LogicSignal> > probes,
- GHashTable *options);
+ Decoder(const srd_decoder *const decoder);
virtual ~Decoder();
- const srd_decoder* get_decoder() const;
+ const srd_decoder* decoder() const;
+
+ const std::map<const srd_probe*, boost::shared_ptr<view::LogicSignal> >&
+ probes() const;
+ void set_probes(std::map<const srd_probe*,
+ boost::shared_ptr<view::LogicSignal> > probes);
+
+ const GHashTable* options() const;
+
+ void set_option(const char *id, GVariant *value);
const std::vector< boost::shared_ptr<pv::view::decode::Annotation> >
annotations() const;
private:
void begin_decode();
- void init_decoder();
-
void decode_proc(boost::shared_ptr<data::Logic> data);
static void annotation_callback(srd_proto_data *pdata,
void new_decode_data();
private:
+
+ /**
+ * This mutex prevents more than one decode operation occuring
+ * concurrently.
+ * @todo A proper solution should be implemented to allow multiple
+ * decode operations.
+ */
+ static boost::mutex _global_decode_mutex;
+
const srd_decoder *const _decoder;
std::map<const srd_probe*, boost::shared_ptr<view::LogicSignal> >
_probes;