X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.cpp;h=ecdefdcde294a68f188336f8b47180155057ab9e;hp=da455ed30ca4f8db3e4651baf5748df6ce1d8863;hb=HEAD;hpb=03408f5f5b62ce74016d91d60bdadce8dbddd46b diff --git a/pv/views/viewbase.cpp b/pv/views/viewbase.cpp index da455ed3..ff3a4fdb 100644 --- a/pv/views/viewbase.cpp +++ b/pv/views/viewbase.cpp @@ -36,7 +36,8 @@ namespace views { const char* ViewTypeNames[ViewTypeCount] = { "Trace View", #ifdef ENABLE_DECODE - "Decoder Output View" + "Binary Decoder Output View", + "Tabular Decoder Output View" #endif }; @@ -63,6 +64,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; @@ -78,12 +84,7 @@ const Session& ViewBase::session() const return session_; } -void ViewBase::clear_signals() -{ - clear_signalbases(); -} - -unordered_set< shared_ptr > ViewBase::signalbases() const +vector< shared_ptr > ViewBase::signalbases() const { return signalbases_; } @@ -102,7 +103,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())); @@ -110,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() { @@ -118,12 +131,15 @@ void ViewBase::clear_decode_signals() void ViewBase::add_decode_signal(shared_ptr signal) { - decode_signals_.insert(signal); + decode_signals_.push_back(signal); } void ViewBase::remove_decode_signal(shared_ptr signal) { - decode_signals_.erase(signal); + decode_signals_.erase(std::remove_if( + decode_signals_.begin(), decode_signals_.end(), + [&](shared_ptr s) { return s == signal; }), + decode_signals_.end()); } #endif @@ -137,6 +153,12 @@ void ViewBase::restore_settings(QSettings &settings) (void)settings; } +void ViewBase::focus_on_range(uint64_t start_sample, uint64_t end_sample) +{ + (void)start_sample; + (void)end_sample; +} + void ViewBase::trigger_event(int segment_id, util::Timestamp location) { (void)segment_id;