X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=e258f6db8e189fb410bcd696d123f31fb295f40e;hp=f96fc869ecad613816196072409c4d1458e198ad;hb=06b6ce26694bdde31c7d5b703c4dda36f4a25938;hpb=477472187338948c83bea5d790ead66034008296 diff --git a/pv/session.cpp b/pv/session.cpp index f96fc869..e258f6db 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -91,6 +91,9 @@ using sigrok::Session; using Glib::VariantBase; namespace pv { + +shared_ptr Session::sr_context; + Session::Session(DeviceManager &device_manager, QString name) : device_manager_(device_manager), default_name_(name), @@ -316,9 +319,9 @@ void Session::restore_settings(QSettings &settings) int decode_signals = settings.value("decode_signals").toInt(); for (int i = 0; i < decode_signals; i++) { - settings.beginGroup("decode_signal" + QString::number(i++)); - // TODO Split up add_decoder() into add_decode_signal() and add_decoder(), - // then call add_decode_signal() and signal->restore_settings() here + settings.beginGroup("decode_signal" + QString::number(i)); + shared_ptr signal = add_decode_signal(); + signal->restore_settings(settings); settings.endGroup(); } #endif @@ -597,7 +600,44 @@ void Session::register_view(shared_ptr view) views_.push_back(view); + // Add all device signals update_signals(); + + // Add all other signals + unordered_set< shared_ptr > view_signalbases = + view->signalbases(); + + views::trace::View *trace_view = + qobject_cast(view.get()); + + if (trace_view) { + for (shared_ptr signalbase : signalbases_) { + const int sb_exists = count_if( + view_signalbases.cbegin(), view_signalbases.cend(), + [&](const shared_ptr &sb) { + return sb == signalbase; + }); + // Add the signal to the view as it doesn't have it yet + if (!sb_exists) + switch (signalbase->type()) { + case data::SignalBase::AnalogChannel: + case data::SignalBase::LogicChannel: + case data::SignalBase::A2LChannel: + break; + case data::SignalBase::DecodeChannel: +#ifdef ENABLE_DECODE + trace_view->add_decode_signal( + dynamic_pointer_cast(signalbase)); +#endif + break; + case data::SignalBase::MathChannel: + // TBD + break; + } + } + } + + signals_changed(); } void Session::deregister_view(shared_ptr view) @@ -645,31 +685,27 @@ const unordered_set< shared_ptr > Session::signalbases() const } #ifdef ENABLE_DECODE -bool Session::add_decoder(srd_decoder *const dec) +shared_ptr Session::add_decode_signal() { - if (!dec) - return false; + shared_ptr signal; try { // Create the decode signal - shared_ptr signal = - make_shared(*this); + signal = make_shared(*this); signalbases_.insert(signal); // Add the decode signal to all views for (shared_ptr view : views_) view->add_decode_signal(signal); - - // Add decoder - signal->stack_decoder(dec); } catch (runtime_error e) { - return false; + remove_decode_signal(signal); + return nullptr; } signals_changed(); - return true; + return signal; } void Session::remove_decode_signal(shared_ptr signal)