Improve send_update_chat_active_stories.

This commit is contained in:
levlam 2023-07-14 16:30:49 +03:00
parent fecb4a2d23
commit 88832bb2c7
2 changed files with 15 additions and 12 deletions

View File

@ -2572,7 +2572,7 @@ void StoryManager::on_update_active_stories(DialogId owner_dialog_id, StoryId ma
update_story_list_sent_total_count(active_stories->story_list_id_); update_story_list_sent_total_count(active_stories->story_list_id_);
} }
active_stories_.erase(owner_dialog_id); active_stories_.erase(owner_dialog_id);
send_update_chat_active_stories(owner_dialog_id); send_update_chat_active_stories(owner_dialog_id, nullptr);
} else { } else {
max_read_story_ids_.erase(owner_dialog_id); max_read_story_ids_.erase(owner_dialog_id);
} }
@ -2602,9 +2602,9 @@ void StoryManager::on_update_active_stories(DialogId owner_dialog_id, StoryId ma
active_stories->max_read_story_id_ = max_read_story_id; active_stories->max_read_story_id_ = max_read_story_id;
active_stories->story_ids_ = std::move(story_ids); active_stories->story_ids_ = std::move(story_ids);
update_active_stories_order(owner_dialog_id, active_stories.get()); update_active_stories_order(owner_dialog_id, active_stories.get());
send_update_chat_active_stories(owner_dialog_id); send_update_chat_active_stories(owner_dialog_id, active_stories.get());
} else if (update_active_stories_order(owner_dialog_id, active_stories.get())) { } else if (update_active_stories_order(owner_dialog_id, active_stories.get())) {
send_update_chat_active_stories(owner_dialog_id); send_update_chat_active_stories(owner_dialog_id, active_stories.get());
} }
} }
@ -2692,12 +2692,14 @@ void StoryManager::send_update_story(StoryFullId story_full_id, const Story *sto
} }
td_api::object_ptr<td_api::updateChatActiveStories> StoryManager::get_update_chat_active_stories( td_api::object_ptr<td_api::updateChatActiveStories> StoryManager::get_update_chat_active_stories(
DialogId owner_dialog_id) const { DialogId owner_dialog_id, const ActiveStories *active_stories) const {
return td_api::make_object<td_api::updateChatActiveStories>(get_chat_active_stories_object(owner_dialog_id)); return td_api::make_object<td_api::updateChatActiveStories>(
get_chat_active_stories_object(owner_dialog_id, active_stories));
} }
void StoryManager::send_update_chat_active_stories(DialogId owner_dialog_id) { void StoryManager::send_update_chat_active_stories(DialogId owner_dialog_id,
send_closure(G()->td(), &Td::send_update, get_update_chat_active_stories(owner_dialog_id)); const ActiveStories *active_stories) const {
send_closure(G()->td(), &Td::send_update, get_update_chat_active_stories(owner_dialog_id, active_stories));
} }
bool StoryManager::on_update_read_stories(DialogId owner_dialog_id, StoryId max_read_story_id) { bool StoryManager::on_update_read_stories(DialogId owner_dialog_id, StoryId max_read_story_id) {
@ -2781,7 +2783,7 @@ void StoryManager::on_dialog_active_stories_order_updated(DialogId owner_dialog_
LOG(INFO) << "Update order of active stories in " << owner_dialog_id << " from " << source; LOG(INFO) << "Update order of active stories in " << owner_dialog_id << " from " << source;
auto active_stories = get_active_stories_editable(owner_dialog_id); auto active_stories = get_active_stories_editable(owner_dialog_id);
if (active_stories != nullptr && update_active_stories_order(owner_dialog_id, active_stories)) { if (active_stories != nullptr && update_active_stories_order(owner_dialog_id, active_stories)) {
send_update_chat_active_stories(owner_dialog_id); send_update_chat_active_stories(owner_dialog_id, active_stories);
} }
} }
@ -3418,8 +3420,8 @@ void StoryManager::remove_story_notifications_by_story_ids(DialogId dialog_id, c
void StoryManager::get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates) const { void StoryManager::get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates) const {
if (!td_->auth_manager_->is_bot()) { if (!td_->auth_manager_->is_bot()) {
active_stories_.foreach([&](const DialogId &dialog_id, const unique_ptr<ActiveStories> &) { active_stories_.foreach([&](const DialogId &dialog_id, const unique_ptr<ActiveStories> &active_stories) {
updates.push_back(get_update_chat_active_stories(dialog_id)); updates.push_back(get_update_chat_active_stories(dialog_id, active_stories.get()));
}); });
for (auto story_list_id : {StoryListId::main(), StoryListId::archive()}) { for (auto story_list_id : {StoryListId::main(), StoryListId::archive()}) {
const auto &story_list = get_story_list(story_list_id); const auto &story_list = get_story_list(story_list_id);

View File

@ -415,9 +415,10 @@ class StoryManager final : public Actor {
void send_update_story(StoryFullId story_full_id, const Story *story); void send_update_story(StoryFullId story_full_id, const Story *story);
td_api::object_ptr<td_api::updateChatActiveStories> get_update_chat_active_stories(DialogId owner_dialog_id) const; td_api::object_ptr<td_api::updateChatActiveStories> get_update_chat_active_stories(
DialogId owner_dialog_id, const ActiveStories *active_stories) const;
void send_update_chat_active_stories(DialogId owner_dialog_id); void send_update_chat_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories) const;
void increment_story_views(DialogId owner_dialog_id, PendingStoryViews &story_views); void increment_story_views(DialogId owner_dialog_id, PendingStoryViews &story_views);