32 lines
825 B
C++
Raw Permalink Normal View History

2024-12-06 14:11:06 +01:00
#pragma once
#include <algorithm>
#include <cstdint>
#include <iostream>
// perform binary search to find the first message not newer than ts_start
template<typename View>
auto find_start_by_ts(const View& view, uint64_t ts_start) {
2024-12-11 23:23:05 +01:00
//std::cout << "!!!! starting msg ts search, ts_start:" << ts_start << "\n";
2024-12-06 14:11:06 +01:00
// -> first value smaller than start ts
auto res = std::lower_bound(
view.begin(), view.end(),
ts_start,
[&view](const auto& a, const auto& b) {
const auto& [a_comp] = view.get(a);
return a_comp.ts > b; // > bc ts is sorted high to low?
}
);
if (res != view.end()) {
const auto& [ts_comp] = view.get(*res);
2024-12-11 23:23:05 +01:00
//std::cout << "!!!! first value not newer than start ts is " << ts_comp.ts << "\n";
2024-12-06 14:11:06 +01:00
} else {
2024-12-11 23:23:05 +01:00
//std::cout << "!!!! no first value not newer than start ts\n";
2024-12-06 14:11:06 +01:00
}
return res;
}