2023-05-02 16:38:55 +02:00
|
|
|
//
|
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
|
|
|
//
|
|
|
|
// 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
|
|
|
|
|
|
|
|
#include "td/telegram/MessageId.h"
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
struct OrderedMessage {
|
|
|
|
int32 random_y = 0;
|
|
|
|
|
|
|
|
bool have_previous = false;
|
|
|
|
bool have_next = false;
|
|
|
|
|
|
|
|
MessageId message_id;
|
|
|
|
|
|
|
|
unique_ptr<OrderedMessage> left;
|
|
|
|
unique_ptr<OrderedMessage> right;
|
2023-05-02 17:04:54 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct OrderedMessages {
|
|
|
|
unique_ptr<OrderedMessage> messages_;
|
2023-05-02 16:38:55 +02:00
|
|
|
|
2023-05-02 17:04:54 +02:00
|
|
|
OrderedMessage *insert(MessageId message_id);
|
2023-05-02 16:38:55 +02:00
|
|
|
|
2023-05-02 17:04:54 +02:00
|
|
|
void erase(MessageId message_id);
|
2023-05-02 17:11:37 +02:00
|
|
|
|
|
|
|
vector<MessageId> find_older_messages(MessageId max_message_id) const;
|
2023-05-02 17:17:06 +02:00
|
|
|
|
|
|
|
vector<MessageId> find_newer_messages(MessageId min_message_id) const;
|
2023-05-02 16:38:55 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace td
|