From 82b9d3493e151f78580219bf1f2aa569dced079e Mon Sep 17 00:00:00 2001 From: levlam Date: Mon, 21 Nov 2022 19:11:38 +0300 Subject: [PATCH] Adjust last_read_inbox_message_id in MessageReplyInfo by last read chat message. --- td/telegram/MessageReplyInfo.cpp | 9 +++++++-- td/telegram/MessageReplyInfo.h | 3 ++- td/telegram/MessagesManager.cpp | 7 +++++-- 3 files changed, 14 insertions(+), 5 deletions(-) diff --git a/td/telegram/MessageReplyInfo.cpp b/td/telegram/MessageReplyInfo.cpp index 61472912f..226abc010 100644 --- a/td/telegram/MessageReplyInfo.cpp +++ b/td/telegram/MessageReplyInfo.cpp @@ -196,7 +196,8 @@ bool MessageReplyInfo::need_reget(const Td *td) const { return false; } -td_api::object_ptr MessageReplyInfo::get_message_reply_info_object(Td *td) const { +td_api::object_ptr MessageReplyInfo::get_message_reply_info_object( + Td *td, MessageId dialog_last_read_inbox_message_id) const { if (is_empty()) { return nullptr; } @@ -208,8 +209,12 @@ td_api::object_ptr MessageReplyInfo::get_message_reply recent_repliers.push_back(std::move(recent_replier)); } } + auto last_read_inbox_message_id = last_read_inbox_message_id_; + if (last_read_inbox_message_id.is_valid() && last_read_inbox_message_id < dialog_last_read_inbox_message_id) { + last_read_inbox_message_id = min(dialog_last_read_inbox_message_id, max_message_id_); + } return td_api::make_object(reply_count_, std::move(recent_repliers), - last_read_inbox_message_id_.get(), + last_read_inbox_message_id.get(), last_read_outbox_message_id_.get(), max_message_id_.get()); } diff --git a/td/telegram/MessageReplyInfo.h b/td/telegram/MessageReplyInfo.h index 88b94acb1..1daf72168 100644 --- a/td/telegram/MessageReplyInfo.h +++ b/td/telegram/MessageReplyInfo.h @@ -59,7 +59,8 @@ struct MessageReplyInfo { bool need_reget(const Td *td) const; - td_api::object_ptr get_message_reply_info_object(Td *td) const; + td_api::object_ptr get_message_reply_info_object( + Td *td, MessageId dialog_last_read_inbox_message_id) const; template void store(StorerT &storer) const; diff --git a/td/telegram/MessagesManager.cpp b/td/telegram/MessagesManager.cpp index 894a03873..f5268db72 100644 --- a/td/telegram/MessagesManager.cpp +++ b/td/telegram/MessagesManager.cpp @@ -7189,7 +7189,10 @@ td_api::object_ptr MessagesManager::get_message_ td_api::object_ptr reply_info; if (is_visible_reply_info) { - reply_info = m->reply_info.get_message_reply_info_object(td_); + auto expected_dialog_id = m->reply_info.is_comment_ ? DialogId(m->reply_info.channel_id_) : dialog_id; + const Dialog *d = get_dialog(expected_dialog_id); + reply_info = + m->reply_info.get_message_reply_info_object(td_, d != nullptr ? d->last_read_inbox_message_id : MessageId()); CHECK(reply_info != nullptr); } @@ -18773,7 +18776,7 @@ td_api::object_ptr MessagesManager::get_message_threa auto message = get_message_object(d->dialog_id, m, "get_message_thread_info_object"); if (message != nullptr) { if (message->interaction_info_ != nullptr && message->interaction_info_->reply_info_ != nullptr) { - reply_info = m->reply_info.get_message_reply_info_object(td_); + reply_info = m->reply_info.get_message_reply_info_object(td_, d->last_read_inbox_message_id); CHECK(reply_info != nullptr); } is_forum_topic = message->is_topic_message_;