X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.cpp;h=ff3a4fdbbb3e30be432667338dba559f0806e0bd;hp=7be8822263c12111ec1bb0a6bb2e78ef7c88e607;hb=999869aa676f7077b7181355eee28e9b025d4cea;hpb=9a35b05d2f2e5329f1ecaddb04289d4adeea2752 diff --git a/pv/views/viewbase.cpp b/pv/views/viewbase.cpp index 7be88222..ff3a4fdb 100644 --- a/pv/views/viewbase.cpp +++ b/pv/views/viewbase.cpp @@ -84,11 +84,6 @@ const Session& ViewBase::session() const return session_; } -void ViewBase::clear_signals() -{ - clear_signalbases(); -} - vector< shared_ptr > ViewBase::signalbases() const { return signalbases_; @@ -116,6 +111,18 @@ void ViewBase::add_signalbase(const shared_ptr signalbase) this, SLOT(on_samples_added(uint64_t, uint64_t, uint64_t))); } +void ViewBase::remove_signalbase(const shared_ptr signalbase) +{ + disconnect(signalbase.get(), SIGNAL(samples_cleared()), + this, SLOT(on_data_updated())); + disconnect(signalbase.get(), SIGNAL(samples_added(uint64_t, uint64_t, uint64_t)), + this, SLOT(on_samples_added(uint64_t, uint64_t, uint64_t))); + + signalbases_.erase(std::remove_if(signalbases_.begin(), signalbases_.end(), + [&](shared_ptr s) { return s == signalbase; }), + signalbases_.end()); +} + #ifdef ENABLE_DECODE void ViewBase::clear_decode_signals() {