Improve updating first/last database message IDs in on_get_history.

This commit is contained in:
levlam 2021-01-24 23:27:53 +03:00
parent 08b3ce0aac
commit e63776dbd3

View File

@ -8890,9 +8890,10 @@ void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_
// LOG_IF(ERROR, d->first_message_id.is_valid() && d->first_message_id > first_received_message_id) // LOG_IF(ERROR, d->first_message_id.is_valid() && d->first_message_id > first_received_message_id)
// << "Receive " << first_received_message_id << ", but first chat message is " << d->first_message_id; // << "Receive " << first_received_message_id << ", but first chat message is " << d->first_message_id;
bool intersect_last_database_message_ids =
last_added_message_id >= d->first_database_message_id && d->last_database_message_id >= first_added_message_id;
bool need_update_database_message_ids = bool need_update_database_message_ids =
last_added_message_id.is_valid() && (from_the_end || (last_added_message_id >= d->first_database_message_id && last_added_message_id.is_valid() && (from_the_end || intersect_last_database_message_ids);
d->last_database_message_id >= first_added_message_id));
if (from_the_end) { if (from_the_end) {
if (!d->last_new_message_id.is_valid()) { if (!d->last_new_message_id.is_valid()) {
set_dialog_last_new_message_id( set_dialog_last_new_message_id(
@ -8906,20 +8907,28 @@ void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_
} }
if (need_update_database_message_ids) { if (need_update_database_message_ids) {
if (from_the_end && !intersect_last_database_message_ids) {
set_dialog_first_database_message_id(d, MessageId(), "on_get_history 1");
set_dialog_last_database_message_id(d, MessageId(), "on_get_history 1");
}
if (!d->last_database_message_id.is_valid()) { if (!d->last_database_message_id.is_valid()) {
CHECK(d->last_message_id.is_valid()); CHECK(d->last_message_id.is_valid());
MessagesConstIterator it(d, d->last_message_id); MessagesConstIterator it(d, d->last_message_id);
MessageId new_first_database_message_id;
while (*it != nullptr) { while (*it != nullptr) {
auto message_id = (*it)->message_id; auto message_id = (*it)->message_id;
if (message_id.is_server() || message_id.is_local()) { if (message_id.is_server() || message_id.is_local()) {
if (!d->last_database_message_id.is_valid()) { if (!d->last_database_message_id.is_valid()) {
set_dialog_last_database_message_id(d, message_id, "on_get_history"); set_dialog_last_database_message_id(d, message_id, "on_get_history");
} }
set_dialog_first_database_message_id(d, message_id, "on_get_history"); new_first_database_message_id = message_id;
try_restore_dialog_reply_markup(d, *it); try_restore_dialog_reply_markup(d, *it);
} }
--it; --it;
} }
if (new_first_database_message_id.is_valid()) {
set_dialog_first_database_message_id(d, new_first_database_message_id, "on_get_history");
}
} else { } else {
LOG_CHECK(d->last_new_message_id.is_valid()) LOG_CHECK(d->last_new_message_id.is_valid())
<< dialog_id << " " << from_the_end << " " << d->first_database_message_id << " " << dialog_id << " " << from_the_end << " " << d->first_database_message_id << " "