tdlight/td/telegram/OrderedMessage.h

40 lines
881 B
C
Raw Normal View History

//
// 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 17:04:54 +02:00
OrderedMessage *insert(MessageId message_id);
2023-05-02 17:04:54 +02:00
void erase(MessageId message_id);
vector<MessageId> find_older_messages(MessageId max_message_id) const;
vector<MessageId> find_newer_messages(MessageId min_message_id) const;
};
} // namespace td