]> sigrok.org Git - pulseview.git/blobdiff - pv/data/signalbase.cpp
SignalBase: Add internal name
[pulseview.git] / pv / data / signalbase.cpp
index 55397edfc4177bd7fb60d264f43d49791db80523..d2dd75ab60f684b65a02611a24c6b4b6283baedb 100644 (file)
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
  */
 
+#include "analog.hpp"
+#include "logic.hpp"
 #include "signalbase.hpp"
+#include "signaldata.hpp"
+#include "decode/row.hpp"
 
+#include <pv/binding/decoder.hpp>
+
+using std::dynamic_pointer_cast;
 using std::shared_ptr;
 
 using sigrok::Channel;
@@ -34,6 +41,8 @@ const int SignalBase::ColourBGAlpha = 8*256/100;
 SignalBase::SignalBase(shared_ptr<sigrok::Channel> channel) :
        channel_(channel)
 {
+       if (channel_)
+               internal_name_ = QString::fromStdString(channel_->name());
 }
 
 shared_ptr<sigrok::Channel> SignalBase::channel() const
@@ -46,6 +55,11 @@ QString SignalBase::name() const
        return (channel_) ? QString::fromStdString(channel_->name()) : name_;
 }
 
+QString SignalBase::internal_name() const
+{
+       return internal_name_;
+}
+
 void SignalBase::set_name(QString name)
 {
        if (channel_)
@@ -99,5 +113,44 @@ QColor SignalBase::bgcolour() const
        return bgcolour_;
 }
 
+void SignalBase::set_data(shared_ptr<pv::data::SignalData> data)
+{
+       data_ = data;
+}
+
+shared_ptr<data::Analog> SignalBase::analog_data() const
+{
+       if (type() == ChannelType::ANALOG)
+               return dynamic_pointer_cast<data::Analog>(data_);
+       else
+               return shared_ptr<data::Analog>();
+}
+
+shared_ptr<data::Logic> SignalBase::logic_data() const
+{
+       if (type() == ChannelType::LOGIC)
+               return dynamic_pointer_cast<data::Logic>(data_);
+       else
+               return shared_ptr<data::Logic>();
+}
+
+#ifdef ENABLE_DECODE
+bool SignalBase::is_decode_signal() const
+{
+       return (decoder_stack_ != nullptr);
+}
+
+std::shared_ptr<pv::data::DecoderStack> SignalBase::decoder_stack() const
+{
+       return decoder_stack_;
+}
+
+void SignalBase::set_decoder_stack(std::shared_ptr<pv::data::DecoderStack>
+       decoder_stack)
+{
+       decoder_stack_ = decoder_stack;
+}
+#endif
+
 } // namespace data
 } // namespace pv