X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fdata%2Fsignalbase.hpp;h=54d9ee0adc2d337a87e9b3195a5223099e46e4c6;hp=db1af1c718e4ddb0b8262b6790b5e2fd9afea2da;hb=f420385094dc7392e6bcec494d800f1d4b34f082;hpb=bf0edd2b0cbb5f4bd5d69b0f00bcea7d037e2287 diff --git a/pv/data/signalbase.hpp b/pv/data/signalbase.hpp index db1af1c7..54d9ee0a 100644 --- a/pv/data/signalbase.hpp +++ b/pv/data/signalbase.hpp @@ -24,6 +24,7 @@ #include #include +#include #include #include @@ -37,6 +38,11 @@ class ChannelType; namespace pv { namespace data { +class Analog; +class DecoderStack; +class Logic; +class SignalData; + class SignalBase : public QObject { Q_OBJECT @@ -80,6 +86,11 @@ public: */ QString name() const; + /** + * Gets the internal name of this signal, i.e. how the device calls it. + */ + QString internal_name() const; + /** * Sets the name of the signal. */ @@ -100,6 +111,34 @@ public: */ QColor bgcolour() const; + /** + * Sets the internal data object. + */ + void set_data(std::shared_ptr data); + + /** + * Get the internal data as analog data object in case of analog type. + */ + std::shared_ptr analog_data() const; + + /** + * Get the internal data as logic data object in case of logic type. + */ + std::shared_ptr logic_data() const; + +#ifdef ENABLE_DECODE + bool is_decode_signal() const; + + std::shared_ptr decoder_stack() const; + + void set_decoder_stack(std::shared_ptr + decoder_stack); +#endif + + void save_settings(QSettings &settings) const; + + void restore_settings(QSettings &settings); + Q_SIGNALS: void enabled_changed(const bool &value); @@ -109,7 +148,13 @@ Q_SIGNALS: private: std::shared_ptr channel_; - QString name_; + std::shared_ptr data_; + +#ifdef ENABLE_DECODE + std::shared_ptr decoder_stack_; +#endif + + QString internal_name_, name_; QColor colour_, bgcolour_; };