X-Git-Url: http://git.code-monkey.de/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=9c3a2c259e2a635f2eed79f5a8a607a9c33d490c;hp=73dd339b60fea95259d6fddc7aace7ec9f3ad0e1;hb=bf0edd2b0cbb5f4bd5d69b0f00bcea7d037e2287;hpb=2b05d3110a0a50ce93c8c887a2dc00c1375e92fa diff --git a/pv/session.cpp b/pv/session.cpp index 73dd339..9c3a2c2 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -39,6 +39,7 @@ #include "data/decoderstack.hpp" #include "data/logic.hpp" #include "data/logicsegment.hpp" +#include "data/signalbase.hpp" #include "data/decode/decoder.hpp" #include "devices/hardwaredevice.hpp" @@ -161,7 +162,15 @@ void Session::set_device(shared_ptr device) signals_changed(); device_ = std::move(device); - device_->open(); + + try { + device_->open(); + } catch (const QString &e) { + device_.reset(); + device_selected(); + throw; + } + device_->session()->add_datafeed_callback([=] (shared_ptr device, shared_ptr packet) { data_feed_in(device, packet); @@ -290,7 +299,7 @@ bool Session::add_decoder(srd_decoder *const dec) dynamic_pointer_cast(s); if (l && QString::fromUtf8(pdch->name). toLower().contains( - l->name().toLower())) + s->channel()->name().toLower())) channels[pdch] = l; } @@ -300,8 +309,11 @@ bool Session::add_decoder(srd_decoder *const dec) decoder_stack->stack().front()->set_channels(channels); // Create the decode signal + shared_ptr signalbase = + shared_ptr(new data::SignalBase(nullptr)); + shared_ptr d( - new view::DecodeTrace(*this, decoder_stack, + new view::DecodeTrace(*this, signalbase, decoder_stack, decode_traces_.size())); decode_traces_.push_back(d); } catch (std::runtime_error e) { @@ -393,13 +405,14 @@ void Session::update_signals() signals_.clear(); for (auto channel : sr_dev->channels()) { + shared_ptr signalbase; shared_ptr signal; // Find the channel in the old signals const auto iter = std::find_if( prev_sigs.cbegin(), prev_sigs.cend(), [&](const shared_ptr &s) { - return s->channel() == channel; + return s->channel()->channel() == channel; }); if (iter != prev_sigs.end()) { // Copy the signal from the old set to the new @@ -411,13 +424,16 @@ void Session::update_signals() logic_data_); } else { // Create a new signal + signalbase = shared_ptr( + new data::SignalBase(channel)); + switch(channel->type()->id()) { case SR_CHANNEL_LOGIC: signal = shared_ptr( new view::LogicSignal(*this, - device_, channel, - logic_data_)); + device_, signalbase, logic_data_)); all_signal_data_.insert(logic_data_); + signalbases_.insert(signalbase); break; case SR_CHANNEL_ANALOG: @@ -426,8 +442,9 @@ void Session::update_signals() new data::Analog()); signal = shared_ptr( new view::AnalogSignal( - *this, channel, data)); + *this, signalbase, data)); all_signal_data_.insert(data); + signalbases_.insert(signalbase); break; } @@ -445,16 +462,15 @@ void Session::update_signals() signals_changed(); } -shared_ptr Session::signal_from_channel( - shared_ptr channel) const +shared_ptr Session::signal_from_channel( + shared_ptr channel) const { - lock_guard lock(signals_mutex_); - for (shared_ptr sig : signals_) { + for (shared_ptr sig : signalbases_) { assert(sig); if (sig->channel() == channel) return sig; } - return shared_ptr(); + return shared_ptr(); } void Session::sample_thread_proc(function error_handler)