X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Ftrace%2Fanalogsignal.cpp;h=cddf59c15059cdda26a209b4781032f73fdd9bce;hb=9510aea0fca1c7438be30a4f43988c001b5f0b11;hp=07fc7cf72add70fda687d3bc9b304bcfdf1d72fc;hpb=03d2a4f8cacda8ad1d79b4e6a312ebe30b835a55;p=pulseview.git diff --git a/pv/views/trace/analogsignal.cpp b/pv/views/trace/analogsignal.cpp index 07fc7cf7..cddf59c1 100644 --- a/pv/views/trace/analogsignal.cpp +++ b/pv/views/trace/analogsignal.cpp @@ -28,6 +28,7 @@ #include #include #include +#include #include #include #include @@ -54,6 +55,7 @@ using std::max; using std::make_pair; using std::min; using std::numeric_limits; +using std::out_of_range; using std::pair; using std::placeholders::_1; using std::shared_ptr; @@ -271,8 +273,13 @@ void AnalogSignal::paint_mid(QPainter &p, ViewItemPaintParams &pp) if (segments.empty()) return; - const shared_ptr &segment = - segments.front(); + shared_ptr segment; + try { + segment = segments.at(current_segment_); + } catch (out_of_range) { + qDebug() << "Current analog segment out of range for signal" << base_->name(); + return; + } const double pixels_offset = pp.pixels_offset(); const double samplerate = max(1.0, segment->samplerate()); @@ -538,8 +545,13 @@ void AnalogSignal::paint_logic_mid(QPainter &p, ViewItemPaintParams &pp) if (segments.empty()) return; - const shared_ptr &segment = - segments.front(); + shared_ptr segment; + try { + segment = segments.at(current_segment_); + } catch (out_of_range) { + qDebug() << "Current logic segment out of range for signal" << base_->name(); + return; + } double samplerate = segment->samplerate();