* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include "analog.hpp"
using std::shared_ptr;
using sigrok::Channel;
-using sigrok::ChannelType;
namespace pv {
namespace data {
const int SignalBase::ColourBGAlpha = 8*256/100;
-SignalBase::SignalBase(shared_ptr<sigrok::Channel> channel) :
- channel_(channel)
+SignalBase::SignalBase(shared_ptr<sigrok::Channel> channel, ChannelType channel_type) :
+ channel_(channel),
+ channel_type_(channel_type)
{
if (channel_)
internal_name_ = QString::fromStdString(channel_->name());
}
}
-const ChannelType *SignalBase::type() const
+SignalBase::ChannelType SignalBase::type() const
{
- return (channel_) ? channel_->type() : nullptr;
+ return channel_type_;
}
unsigned int SignalBase::index() const
shared_ptr<data::Analog> SignalBase::analog_data() const
{
- if (type() == ChannelType::ANALOG)
+ if (channel_type_ == AnalogChannel)
return dynamic_pointer_cast<data::Analog>(data_);
else
- return shared_ptr<data::Analog>();
+ return nullptr;
}
shared_ptr<data::Logic> SignalBase::logic_data() const
{
- if (type() == ChannelType::LOGIC)
+ if (channel_type_ == LogicChannel)
return dynamic_pointer_cast<data::Logic>(data_);
else
- return shared_ptr<data::Logic>();
+ return nullptr;
}
#ifdef ENABLE_DECODE
return (decoder_stack_ != nullptr);
}
-std::shared_ptr<pv::data::DecoderStack> SignalBase::decoder_stack() const
+shared_ptr<pv::data::DecoderStack> SignalBase::decoder_stack() const
{
return decoder_stack_;
}
-void SignalBase::set_decoder_stack(std::shared_ptr<pv::data::DecoderStack>
+void SignalBase::set_decoder_stack(shared_ptr<pv::data::DecoderStack>
decoder_stack)
{
decoder_stack_ = decoder_stack;