]> sigrok.org Git - pulseview.git/blobdiff - pv/data/signalbase.hpp
Move view-independent data from view::DecodeTrace to SignalBase
[pulseview.git] / pv / data / signalbase.hpp
index db1af1c718e4ddb0b8262b6790b5e2fd9afea2da..a682a56e1f52cadbb60a8a3a1dba9a80e2eacbc2 100644 (file)
@@ -37,6 +37,11 @@ class ChannelType;
 namespace pv {
 namespace data {
 
+class Analog;
+class DecoderStack;
+class Logic;
+class SignalData;
+
 class SignalBase : public QObject
 {
        Q_OBJECT
@@ -100,6 +105,30 @@ public:
         */
        QColor bgcolour() const;
 
+       /**
+        * Sets the internal data object.
+        */
+       void set_data(std::shared_ptr<pv::data::SignalData> data);
+
+       /**
+        * Get the internal data as analog data object in case of analog type.
+        */
+       std::shared_ptr<pv::data::Analog> analog_data() const;
+
+       /**
+        * Get the internal data as logic data object in case of logic type.
+        */
+       std::shared_ptr<pv::data::Logic> logic_data() const;
+
+#ifdef ENABLE_DECODE
+       bool is_decode_signal() const;
+
+       std::shared_ptr<pv::data::DecoderStack> decoder_stack() const;
+
+       void set_decoder_stack(std::shared_ptr<pv::data::DecoderStack>
+               decoder_stack);
+#endif
+
 Q_SIGNALS:
        void enabled_changed(const bool &value);
 
@@ -109,6 +138,12 @@ Q_SIGNALS:
 
 private:
        std::shared_ptr<sigrok::Channel> channel_;
+       std::shared_ptr<pv::data::SignalData> data_;
+
+#ifdef ENABLE_DECODE
+       std::shared_ptr<pv::data::DecoderStack> decoder_stack_;
+#endif
+
        QString name_;
        QColor colour_, bgcolour_;
 };