X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.cpp;h=26b4ef1f893ca882abf563b5f026a9aba55766f5;hb=533b67b7af83c96af2692bac127b0023cca4dbe7;hp=69be61c892b67a5815b0096db1d78ea516ef4eac;hpb=a24412db987328f80cf32d8299d82b72a441c239;p=pulseview.git diff --git a/pv/views/viewbase.cpp b/pv/views/viewbase.cpp index 69be61c8..26b4ef1f 100644 --- a/pv/views/viewbase.cpp +++ b/pv/views/viewbase.cpp @@ -34,9 +34,9 @@ namespace pv { namespace views { const char* ViewTypeNames[ViewTypeCount] = { - "Trace View", + "Trace View", #ifdef ENABLE_DECODE - "Decoder Output View" + "Decoder Output View" #endif }; @@ -63,6 +63,11 @@ ViewBase::ViewBase(Session &session, bool is_main_view, QMainWindow *parent) : delayed_view_updater_.setInterval(1000 / MaxViewAutoUpdateRate); } +bool ViewBase::is_main_view() const +{ + return is_main_view_; +} + void ViewBase::reset_view_state() { current_segment_ = 0; @@ -80,9 +85,10 @@ const Session& ViewBase::session() const void ViewBase::clear_signals() { + clear_signalbases(); } -unordered_set< shared_ptr > ViewBase::signalbases() const +vector< shared_ptr > ViewBase::signalbases() const { return signalbases_; } @@ -101,7 +107,7 @@ void ViewBase::clear_signalbases() void ViewBase::add_signalbase(const shared_ptr signalbase) { - signalbases_.insert(signalbase); + signalbases_.push_back(signalbase); connect(signalbase.get(), SIGNAL(samples_cleared()), this, SLOT(on_data_updated())); @@ -112,16 +118,20 @@ void ViewBase::add_signalbase(const shared_ptr signalbase) #ifdef ENABLE_DECODE void ViewBase::clear_decode_signals() { + decode_signals_.clear(); } void ViewBase::add_decode_signal(shared_ptr signal) { - (void)signal; + decode_signals_.push_back(signal); } void ViewBase::remove_decode_signal(shared_ptr signal) { - (void)signal; + decode_signals_.erase(std::remove_if( + decode_signals_.begin(), decode_signals_.end(), + [&](shared_ptr s) { return s == signal; }), + decode_signals_.end()); } #endif