Move yet_unsent_message_id_to_persistent_message_id out of each Dialog.

This commit is contained in:
levlam 2023-03-15 16:50:56 +03:00
parent 5ee1c751f9
commit 78d5146188
2 changed files with 10 additions and 10 deletions

View File

@ -25952,15 +25952,15 @@ Status MessagesManager::can_send_message(DialogId dialog_id) const {
return Status::OK(); return Status::OK();
} }
MessageId MessagesManager::get_persistent_message_id(const Dialog *d, MessageId message_id) { MessageId MessagesManager::get_persistent_message_id(const Dialog *d, MessageId message_id) const {
if (!message_id.is_valid() && !message_id.is_valid_scheduled()) { if (!message_id.is_valid() && !message_id.is_valid_scheduled()) {
return MessageId(); return MessageId();
} }
if (message_id.is_yet_unsent()) { if (message_id.is_yet_unsent()) {
// it is possible that user tries to do something with an already sent message by its temporary identifier // it is possible that user tries to do something with an already sent message by its temporary identifier
// we need to use real message in this case and transparently replace message_id // we need to use real message in this case and transparently replace message_id
auto it = d->yet_unsent_message_id_to_persistent_message_id.find(message_id); auto it = yet_unsent_full_message_id_to_persistent_message_id_.find({d->dialog_id, message_id});
if (it != d->yet_unsent_message_id_to_persistent_message_id.end()) { if (it != yet_unsent_full_message_id_to_persistent_message_id_.end()) {
return it->second; return it->second;
} }
} }
@ -31506,11 +31506,11 @@ void MessagesManager::remove_message_dialog_notifications(Dialog *d, MessageId m
NotificationId(), max_notification_message_id, 0, true, Promise<Unit>()); NotificationId(), max_notification_message_id, 0, true, Promise<Unit>());
} }
void MessagesManager::send_update_message_send_succeeded(Dialog *d, MessageId old_message_id, const Message *m) const { void MessagesManager::send_update_message_send_succeeded(const Dialog *d, MessageId old_message_id, const Message *m) {
CHECK(m != nullptr); CHECK(m != nullptr);
CHECK(d->is_update_new_chat_sent); CHECK(d->is_update_new_chat_sent);
if (!td_->auth_manager_->is_bot()) { if (!td_->auth_manager_->is_bot()) {
d->yet_unsent_message_id_to_persistent_message_id.emplace(old_message_id, m->message_id); yet_unsent_full_message_id_to_persistent_message_id_.emplace({d->dialog_id, old_message_id}, m->message_id);
} }
send_closure(G()->td(), &Td::send_update, send_closure(G()->td(), &Td::send_update,
make_tl_object<td_api::updateMessageSendSucceeded>( make_tl_object<td_api::updateMessageSendSucceeded>(
@ -32707,7 +32707,7 @@ void MessagesManager::fail_send_message(FullMessageId full_message_id, int error
LOG(INFO) << "Send updateMessageSendFailed for " << full_message_id; LOG(INFO) << "Send updateMessageSendFailed for " << full_message_id;
if (!td_->auth_manager_->is_bot()) { if (!td_->auth_manager_->is_bot()) {
d->yet_unsent_message_id_to_persistent_message_id.emplace(old_message_id, m->message_id); yet_unsent_full_message_id_to_persistent_message_id_.emplace({dialog_id, old_message_id}, m->message_id);
} }
send_closure(G()->td(), &Td::send_update, send_closure(G()->td(), &Td::send_update,
make_tl_object<td_api::updateMessageSendFailed>(get_message_object(dialog_id, m, "fail_send_message"), make_tl_object<td_api::updateMessageSendFailed>(get_message_object(dialog_id, m, "fail_send_message"),

View File

@ -1424,8 +1424,6 @@ class MessagesManager final : public Actor {
FlatHashMap<ScheduledServerMessageId, int32, ScheduledServerMessageIdHash> scheduled_message_date; FlatHashMap<ScheduledServerMessageId, int32, ScheduledServerMessageIdHash> scheduled_message_date;
FlatHashMap<MessageId, MessageId, MessageIdHash> yet_unsent_message_id_to_persistent_message_id;
FlatHashMap<int32, MessageId> last_assigned_scheduled_message_id; // date -> message_id FlatHashMap<int32, MessageId> last_assigned_scheduled_message_id; // date -> message_id
WaitFreeHashSet<MessageId, MessageIdHash> deleted_message_ids; WaitFreeHashSet<MessageId, MessageIdHash> deleted_message_ids;
@ -1948,7 +1946,7 @@ class MessagesManager final : public Actor {
bool was_uploaded, bool was_thumbnail_uploaded, string file_reference, bool was_uploaded, bool was_thumbnail_uploaded, string file_reference,
int32 schedule_date, uint64 generation, Result<int32> &&result); int32 schedule_date, uint64 generation, Result<int32> &&result);
static MessageId get_persistent_message_id(const Dialog *d, MessageId message_id); MessageId get_persistent_message_id(const Dialog *d, MessageId message_id) const;
static FullMessageId get_replied_message_id(DialogId dialog_id, const Message *m); static FullMessageId get_replied_message_id(DialogId dialog_id, const Message *m);
@ -2502,7 +2500,7 @@ class MessagesManager final : public Actor {
bool need_skip_bot_commands(DialogId dialog_id, const Message *m) const; bool need_skip_bot_commands(DialogId dialog_id, const Message *m) const;
void send_update_message_send_succeeded(Dialog *d, MessageId old_message_id, const Message *m) const; void send_update_message_send_succeeded(const Dialog *d, MessageId old_message_id, const Message *m);
void send_update_message_content(const Dialog *d, Message *m, bool is_message_in_dialog, const char *source); void send_update_message_content(const Dialog *d, Message *m, bool is_message_in_dialog, const char *source);
@ -3756,6 +3754,8 @@ class MessagesManager final : public Actor {
FlatHashMap<DialogId, MessageId, DialogIdHash> previous_repaired_read_inbox_max_message_id_; FlatHashMap<DialogId, MessageId, DialogIdHash> previous_repaired_read_inbox_max_message_id_;
FlatHashMap<FullMessageId, MessageId, FullMessageIdHash> yet_unsent_full_message_id_to_persistent_message_id_;
struct PendingReaction { struct PendingReaction {
int32 query_count = 0; int32 query_count = 0;
bool was_updated = false; bool was_updated = false;