From 9b247ce5ed96d2bda38b9de98a3002dff5bf8c39 Mon Sep 17 00:00:00 2001 From: John Preston Date: Mon, 25 Mar 2019 16:47:19 +0400 Subject: [PATCH] Version 1.6.4: Fix leaving + rejoining for channels. --- Telegram/SourceFiles/history/history.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/Telegram/SourceFiles/history/history.cpp b/Telegram/SourceFiles/history/history.cpp index e84a82979..960df9126 100644 --- a/Telegram/SourceFiles/history/history.cpp +++ b/Telegram/SourceFiles/history/history.cpp @@ -2897,7 +2897,13 @@ void History::clearBlocks(bool leaveItems) { if (leaveItems) { _owner->notifyHistoryUnloaded(this); } else { - setLastMessage(nullptr); + if (peer->isChannel()) { + // We left the channel. + _lastMessage = std::nullopt; + } else { + // History was deleted. + setLastMessage(nullptr); + } notifies.clear(); _owner->notifyHistoryCleared(this); } @@ -2909,7 +2915,7 @@ void History::clearBlocks(bool leaveItems) { if (auto channel = peer->asChannel()) { channel->clearPinnedMessage(); if (const auto feed = channel->feed()) { - // Should be after setLastMessage(nullptr); + // Should be after resetting the _lastMessage. feed->historyCleared(this); } }