X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=ebef90cbb6590fb9961fad97f73047e56e8acc79;hp=9fd8fb3eb9b5bdf6a1c03cf5f457e9b5113de493;hb=03cc651d78a85308107e0ef3e5e514503d7c723c;hpb=39ccf9c39ec5c1ddeb5ba62f77cc811a2598bf72 diff --git a/pv/session.cpp b/pv/session.cpp index 9fd8fb3e..ebef90cb 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -138,6 +138,13 @@ void Session::set_device(shared_ptr device) if (device_) device_->close(); + device_.reset(); + + // Remove all traces + signals_.clear(); + decode_traces_.clear(); + signals_changed(); + device_ = std::move(device); device_->open(); device_->session()->add_datafeed_callback([=] @@ -145,8 +152,6 @@ void Session::set_device(shared_ptr device) data_feed_in(device, packet); }); - decode_traces_.clear(); - update_signals(); device_selected(); } @@ -333,7 +338,11 @@ void Session::set_capture_state(capture_state state) void Session::update_signals() { - assert(device_); + if (!device_) { + signals_.clear(); + logic_data_.reset(); + return; + } lock_guard lock(data_mutex_);