From bc3f4280984c75f50cc5847dd47772fd815b3bf6 Mon Sep 17 00:00:00 2001 From: Lin Zhihao <59785146+LinZhihao-723@users.noreply.github.com> Date: Thu, 9 Jan 2025 16:44:16 -0500 Subject: [PATCH] fix(core-clp): Advance to the next message when a message has an out-of-range timestamp when searching archives (fixes #659). (#660) Co-authored-by: kirkrodrigues <2454684+kirkrodrigues@users.noreply.github.com> --- .../src/clp/streaming_archive/reader/File.cpp | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/components/core/src/clp/streaming_archive/reader/File.cpp b/components/core/src/clp/streaming_archive/reader/File.cpp index 7de4ccbec..e3b2e6d41 100644 --- a/components/core/src/clp/streaming_archive/reader/File.cpp +++ b/components/core/src/clp/streaming_archive/reader/File.cpp @@ -252,14 +252,21 @@ bool File::find_message_in_time_range( SubQuery const* File::find_message_matching_query(Query const& query, Message& msg) { SubQuery const* matching_sub_query = nullptr; while (m_msgs_ix < m_num_messages && nullptr == matching_sub_query) { - auto logtype_id = m_logtypes[m_msgs_ix]; + auto const curr_msg_ix{m_msgs_ix}; + auto logtype_id = m_logtypes[curr_msg_ix]; // Get number of variables in logtype auto const& logtype_dictionary_entry = m_archive_logtype_dict->get_entry(logtype_id); auto const num_vars = logtype_dictionary_entry.get_num_variables(); + auto const vars_begin_ix{m_variables_ix}; auto const vars_end_ix{m_variables_ix + num_vars}; - auto const timestamp{m_timestamps[m_msgs_ix]}; + + // Advance indices + ++m_msgs_ix; + m_variables_ix = vars_end_ix; + + auto const timestamp{m_timestamps[curr_msg_ix]}; if (false == query.timestamp_is_in_search_time_range(timestamp)) { continue; } @@ -270,7 +277,7 @@ SubQuery const* File::find_message_matching_query(Query const& query, Message& m } msg.clear_vars(); - for (auto vars_ix{m_variables_ix}; vars_ix < vars_end_ix; ++vars_ix) { + for (auto vars_ix{vars_begin_ix}; vars_ix < vars_end_ix; ++vars_ix) { msg.add_var(m_variables[vars_ix]); } if (false == sub_query->matches_vars(msg.get_vars())) { @@ -279,14 +286,10 @@ SubQuery const* File::find_message_matching_query(Query const& query, Message& m msg.set_logtype_id(logtype_id); msg.set_timestamp(timestamp); - msg.set_msg_ix(m_begin_message_ix, m_msgs_ix); + msg.set_msg_ix(m_begin_message_ix, curr_msg_ix); matching_sub_query = sub_query; break; } - - // Advance indices - ++m_msgs_ix; - m_variables_ix += num_vars; } return matching_sub_query;