X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fsession.cpp;h=07ee594d7c1ca0390e5af1cef6ca6d24c2f4b22e;hb=bc93f1ef2f89b6309b23b4984c237dcc458f1446;hp=ad4c17e246f0609079e470750c9c3f979d3f20cd;hpb=837bb15a1c1b668640da474522f174da462d6d61;p=pulseview.git diff --git a/pv/session.cpp b/pv/session.cpp index ad4c17e..07ee594 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -677,6 +677,17 @@ double Session::get_samplerate() const return samplerate; } +int Session::get_segment_count() const +{ + int min_val = INT_MAX; + + for (shared_ptr data : all_signal_data_) + if (data->get_segment_count() < min_val) + min_val = data->get_segment_count(); + + return min_val; +} + const unordered_set< shared_ptr > Session::signalbases() const { return signalbases_; @@ -941,7 +952,7 @@ void Session::free_unused_memory() void Session::feed_in_header() { - cur_samplerate_ = device_->read_config(ConfigKey::SAMPLERATE); + // Nothing to do here for now } void Session::feed_in_meta(shared_ptr meta) @@ -1012,6 +1023,9 @@ void Session::feed_in_frame_end() void Session::feed_in_logic(shared_ptr logic) { + if (!cur_samplerate_) + cur_samplerate_ = device_->read_config(ConfigKey::SAMPLERATE); + lock_guard lock(data_mutex_); if (!logic_data_) { @@ -1044,6 +1058,9 @@ void Session::feed_in_logic(shared_ptr logic) void Session::feed_in_analog(shared_ptr analog) { + if (!cur_samplerate_) + cur_samplerate_ = device_->read_config(ConfigKey::SAMPLERATE); + lock_guard lock(data_mutex_); const vector> channels = analog->channels();