2018-12-31 20:04:05 +01:00
|
|
|
//
|
2024-01-01 01:07:21 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
2018-07-03 21:29:04 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/db/binlog/BinlogEvent.h"
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
namespace detail {
|
2019-10-22 01:12:58 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
class BinlogEventsBuffer {
|
|
|
|
public:
|
|
|
|
void add_event(BinlogEvent &&event);
|
|
|
|
|
|
|
|
bool need_flush() const;
|
|
|
|
|
|
|
|
template <class CallbackT>
|
|
|
|
void flush(CallbackT &&callback) {
|
|
|
|
for (size_t i = 0; i < ids_.size(); i++) {
|
|
|
|
auto &event = events_[i];
|
|
|
|
if (i + 1 != ids_.size() && (event.flags_ & BinlogEvent::Flags::Partial) == 0) {
|
|
|
|
callback(BinlogEvent(BinlogEvent::create_raw(event.id_, event.type_, event.flags_ | BinlogEvent::Flags::Partial,
|
2023-02-02 01:08:26 +01:00
|
|
|
create_storer(event.get_data())),
|
2018-06-28 19:00:11 +02:00
|
|
|
BinlogDebugInfo{__FILE__, __LINE__}));
|
2018-12-31 20:04:05 +01:00
|
|
|
} else {
|
|
|
|
callback(std::move(event));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
clear();
|
|
|
|
}
|
|
|
|
size_t size() const {
|
|
|
|
return size_;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
vector<uint64> ids_;
|
|
|
|
vector<BinlogEvent> events_;
|
|
|
|
size_t total_events_{0};
|
|
|
|
size_t size_{0};
|
|
|
|
|
|
|
|
void do_event(BinlogEvent &&event);
|
|
|
|
void clear();
|
|
|
|
};
|
2019-10-22 01:12:58 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
} // namespace detail
|
|
|
|
} // namespace td
|