#ifndef PULSEVIEW_PV_DATA_DECODE_DECODER_HPP
#define PULSEVIEW_PV_DATA_DECODE_DECODER_HPP
+#include <deque>
#include <map>
#include <memory>
#include <set>
+#include <vector>
#include <glib.h>
+#include <QObject>
+
+#include <pv/data/decode/row.hpp>
+
+using std::deque;
using std::map;
-using std::set;
using std::shared_ptr;
using std::string;
+using std::vector;
struct srd_decoder;
struct srd_decoder_inst;
namespace decode {
-class Decoder
+class Decoder;
+
+class AnnotationClass: public QObject
{
+ Q_OBJECT
+
+public:
+ AnnotationClass(size_t _id, char* _name, char* _description, Row* _row);
+
+ bool visible() const;
+ void set_visible(bool visible);
+
+Q_SIGNALS:
+ void visibility_changed();
+
public:
- Decoder(const srd_decoder *const dec);
+ size_t id;
+ char* name;
+ char* description;
+ Row* row;
+
+private:
+ bool visible_;
+};
+
+struct DecodeChannel
+{
+ uint16_t id; ///< Global numerical ID for the decode channels in the stack
+ uint16_t bit_id; ///< Tells which bit within a sample represents this channel
+ const bool is_optional;
+ shared_ptr<const pv::data::SignalBase> assigned_signal;
+ const QString name, desc;
+ int initial_pin_state;
+ const shared_ptr<Decoder> decoder_;
+ const srd_channel *pdch_;
+};
+
+struct DecoderLogicOutputChannel {
+ DecoderLogicOutputChannel (QString id, QString desc) :
+ id(id), desc(desc) {};
+ QString id, desc;
+};
+
+struct DecodeBinaryClassInfo
+{
+ uint32_t bin_class_id;
+ char* name;
+ char* description;
+};
+
+
+class Decoder : public QObject
+{
+ Q_OBJECT
+
+public:
+ Decoder(const srd_decoder *const dec, uint8_t stack_level);
virtual ~Decoder();
- const srd_decoder* decoder() const;
+ const srd_decoder* get_srd_decoder() const;
- bool shown() const;
- void show(bool show = true);
+ uint8_t get_stack_level() const;
- const map<const srd_channel*,
- shared_ptr<data::SignalBase> >& channels() const;
- void set_channels(map<const srd_channel*,
- shared_ptr<data::SignalBase> > channels);
+ const char* name() const;
- void set_initial_pins(GArray *initial_pins);
+ bool visible() const;
+ void set_visible(bool visible);
- GArray *initial_pins() const;
+ const vector<DecodeChannel*>& channels() const;
+ void set_channels(vector<DecodeChannel*> channels);
const map<string, GVariant*>& options() const;
-
void set_option(const char *id, GVariant *value);
+ void apply_all_options();
+
bool have_required_channels() const;
- srd_decoder_inst* create_decoder_inst(srd_session *session) const;
+ srd_decoder_inst* create_decoder_inst(srd_session *session);
+ void invalidate_decoder_inst();
+
+ vector<Row*> get_rows();
+ Row* get_row_by_id(size_t id);
+
+ vector<const AnnotationClass*> ann_classes() const;
+ vector<AnnotationClass*> ann_classes();
+ AnnotationClass* get_ann_class_by_id(size_t id);
+ const AnnotationClass* get_ann_class_by_id(size_t id) const;
+
+ uint32_t get_binary_class_count() const;
+ const DecodeBinaryClassInfo* get_binary_class(uint32_t id) const;
+
+ bool has_logic_output() const;
+ const vector<DecoderLogicOutputChannel> logic_output_channels() const;
+
+Q_SIGNALS:
+ void annotation_visibility_changed();
- set< shared_ptr<pv::data::Logic> > get_data();
+private Q_SLOTS:
+ void on_row_visibility_changed();
+ void on_class_visibility_changed();
private:
- const srd_decoder *const decoder_;
+ const srd_decoder* const srd_decoder_;
+ uint8_t stack_level_;
- bool shown_;
+ bool visible_;
- map<const srd_channel*, shared_ptr<pv::data::SignalBase> > channels_;
- GArray *initial_pins_;
+ vector<DecodeChannel*> channels_;
+ deque<Row> rows_;
+ deque<AnnotationClass> ann_classes_;
+ vector<DecodeBinaryClassInfo> bin_classes_;
map<string, GVariant*> options_;
+ srd_decoder_inst *decoder_inst_;
};
} // namespace decode