X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fsession.cpp;h=732f4a8cbf55b69c7befe816cba3921f23fb80ec;hb=c8e60bdf0f33b3005e695a6b256b559dbc7b8576;hp=b022bd02c0c02681bd576a06fff085b89f27e0c8;hpb=f5a5b019c5679dbe6b4bc6f956c3820f47869bc1;p=pulseview.git diff --git a/pv/session.cpp b/pv/session.cpp index b022bd0..732f4a8 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -317,8 +317,8 @@ void Session::restore_settings(QSettings &settings) 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 + shared_ptr signal = add_decode_signal(); + signal->restore_settings(settings); settings.endGroup(); } #endif @@ -682,31 +682,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)