#ifndef PULSEVIEW_PV_DATA_DECODE_DECODER_HPP
#define PULSEVIEW_PV_DATA_DECODE_DECODER_HPP
+#include <deque>
#include <map>
#include <memory>
#include <set>
#include <glib.h>
+#include <QObject>
+
+#include <pv/data/decode/row.hpp>
+
+using std::deque;
using std::map;
+using std::shared_ptr;
using std::string;
using std::vector;
namespace data {
-struct DecodeChannel;
class Logic;
class SignalBase;
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;
+ const pv::data::SignalBase *assigned_signal;
+ const QString name, desc;
+ int initial_pin_state;
+ const shared_ptr<Decoder> decoder_;
+ const srd_channel *pdch_;
+};
+
+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 vector<data::DecodeChannel*>& channels() const;
- void set_channels(vector<data::DecodeChannel*> channels);
+ const char* name() const;
- const map<string, GVariant*>& options() const;
+ bool visible() const;
+ void set_visible(bool visible);
+
+ 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;
+
+Q_SIGNALS:
+ void annotation_visibility_changed();
+
+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_;
- vector<data::DecodeChannel*> channels_;
+ 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