From decae25ea4424a69a0e11d0da95b06748697b035 Mon Sep 17 00:00:00 2001 From: levlam Date: Tue, 26 Nov 2019 19:18:57 +0300 Subject: [PATCH] Add MessageId.cpp. GitOrigin-RevId: cef61aa16eec0dfde026a611535487012e89f50f --- CMakeLists.txt | 1 + td/telegram/MessageId.cpp | 99 +++++++++++++++++++++++++++++++++++++++ td/telegram/MessageId.h | 88 ++-------------------------------- 3 files changed, 105 insertions(+), 83 deletions(-) create mode 100644 td/telegram/MessageId.cpp diff --git a/CMakeLists.txt b/CMakeLists.txt index 48b524f0..e1200ed1 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -411,6 +411,7 @@ set(TDLIB_SOURCE td/telegram/Logging.cpp td/telegram/MessageContent.cpp td/telegram/MessageEntity.cpp + td/telegram/MessageId.cpp td/telegram/MessagesDb.cpp td/telegram/MessagesManager.cpp td/telegram/misc.cpp diff --git a/td/telegram/MessageId.cpp b/td/telegram/MessageId.cpp new file mode 100644 index 00000000..0f05066b --- /dev/null +++ b/td/telegram/MessageId.cpp @@ -0,0 +1,99 @@ +// +// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2019 +// +// Distributed under the Boost Software License, Version 1.0. (See accompanying +// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) +// +#include "td/telegram/MessageId.h" + +#include "td/utils/logging.h" +#include "td/utils/misc.h" + +namespace td { + +MessageId MessageId::get_scheduled_message_id(int32 server_message_id, int32 send_date) { + if (send_date <= (1 << 30)) { + LOG(ERROR) << "Scheduled message send date " << send_date << " is in the past"; + return MessageId(); + } + if (server_message_id <= 0) { + LOG(ERROR) << "Scheduled message ID " << server_message_id << " is non-positive"; + return MessageId(); + } + if (server_message_id >= (1 << 18)) { + LOG(ERROR) << "Scheduled message ID " << server_message_id << " is too big"; + return MessageId(); + } + return MessageId((static_cast(send_date - (1 << 30)) << 21) | (server_message_id << 3) | SCHEDULED_MASK); +} + +bool MessageId::is_valid() const { + if (id <= 0 || id > max().get()) { + return false; + } + if ((id & FULL_TYPE_MASK) == 0) { + return true; + } + int32 type = (id & TYPE_MASK); + return type == TYPE_YET_UNSENT || type == TYPE_LOCAL; +} + +bool MessageId::is_valid_scheduled() const { + if (id <= 0 || id > max().get()) { + return false; + } + int32 type = (id & TYPE_MASK); + return type == SCHEDULED_MASK || type == (SCHEDULED_MASK | TYPE_YET_UNSENT) || type == (SCHEDULED_MASK | TYPE_LOCAL); +} + +MessageType MessageId::get_type() const { + if (id <= 0 || id > max().get()) { + return MessageType::None; + } + if ((id & FULL_TYPE_MASK) == 0) { + return MessageType::Server; + } + switch (id & TYPE_MASK) { + case TYPE_YET_UNSENT: + return MessageType::YetUnsent; + case TYPE_LOCAL: + return MessageType::Local; + default: + return MessageType::None; + } +} + +MessageId MessageId::get_next_message_id(MessageType type) const { + switch (type) { + case MessageType::Server: + return get_next_server_message_id(); + case MessageType::Local: + return MessageId(((id + TYPE_MASK + 1 - TYPE_LOCAL) & ~TYPE_MASK) + TYPE_LOCAL); + case MessageType::YetUnsent: + return MessageId(((id + TYPE_MASK + 1 - TYPE_YET_UNSENT) & ~TYPE_MASK) + TYPE_YET_UNSENT); + case MessageType::None: + default: + UNREACHABLE(); + return MessageId(); + } +} + +StringBuilder &operator<<(StringBuilder &string_builder, MessageId message_id) { + if (!message_id.is_valid()) { + return string_builder << "invalid message " << message_id.get(); + } + if (message_id.is_server()) { + return string_builder << "server message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT); + } + if (message_id.is_local()) { + return string_builder << "local message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT) << '.' + << (message_id.get() & MessageId::FULL_TYPE_MASK); + } + if (message_id.is_yet_unsent()) { + return string_builder << "yet unsent message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT) << '.' + << (message_id.get() & MessageId::FULL_TYPE_MASK); + } + return string_builder << "bugged message " << message_id.get(); +} + +} // namespace td diff --git a/td/telegram/MessageId.h b/td/telegram/MessageId.h index 6c0f657e..8632487b 100644 --- a/td/telegram/MessageId.h +++ b/td/telegram/MessageId.h @@ -9,8 +9,6 @@ #include "td/telegram/DialogId.h" #include "td/utils/common.h" -#include "td/utils/logging.h" -#include "td/utils/misc.h" #include "td/utils/StringBuilder.h" #include "td/utils/tl_helpers.h" @@ -88,21 +86,7 @@ class MessageId { : id(static_cast(server_message_id.get()) << SERVER_ID_SHIFT) { } - static MessageId get_scheduled_message_id(int32 server_message_id, int32 send_date) { - if (send_date <= (1 << 30)) { - LOG(ERROR) << "Scheduled message send date " << send_date << " is in the past"; - return MessageId(); - } - if (server_message_id <= 0) { - LOG(ERROR) << "Scheduled message ID " << server_message_id << " is non-positive"; - return MessageId(); - } - if (server_message_id >= (1 << 18)) { - LOG(ERROR) << "Scheduled message ID " << server_message_id << " is too big"; - return MessageId(); - } - return MessageId((static_cast(send_date - (1 << 30)) << 21) | (server_message_id << 3) | SCHEDULED_MASK); - } + static MessageId get_scheduled_message_id(int32 server_message_id, int32 send_date); explicit constexpr MessageId(int64 message_id) : id(message_id) { } @@ -116,46 +100,15 @@ class MessageId { return MessageId(static_cast(std::numeric_limits::max()) << SERVER_ID_SHIFT); } - bool is_valid() const { - if (id <= 0 || id > max().get()) { - return false; - } - if ((id & FULL_TYPE_MASK) == 0) { - return true; - } - int32 type = (id & TYPE_MASK); - return type == TYPE_YET_UNSENT || type == TYPE_LOCAL; - } + bool is_valid() const; - bool is_valid_scheduled() const { - if (id <= 0 || id > max().get()) { - return false; - } - int32 type = (id & TYPE_MASK); - return type == SCHEDULED_MASK || type == (SCHEDULED_MASK | TYPE_YET_UNSENT) || - type == (SCHEDULED_MASK | TYPE_LOCAL); - } + bool is_valid_scheduled() const; int64 get() const { return id; } - MessageType get_type() const { - if (id <= 0 || id > max().get()) { - return MessageType::None; - } - if ((id & FULL_TYPE_MASK) == 0) { - return MessageType::Server; - } - switch (id & TYPE_MASK) { - case TYPE_YET_UNSENT: - return MessageType::YetUnsent; - case TYPE_LOCAL: - return MessageType::Local; - default: - return MessageType::None; - } - } + MessageType get_type() const; bool is_scheduled() const { return (id & SCHEDULED_MASK) != 0; @@ -196,20 +149,7 @@ class MessageId { return MessageId((id + FULL_TYPE_MASK) & ~FULL_TYPE_MASK); } - MessageId get_next_message_id(MessageType type) const { - switch (type) { - case MessageType::Server: - return get_next_server_message_id(); - case MessageType::Local: - return MessageId(((id + TYPE_MASK + 1 - TYPE_LOCAL) & ~TYPE_MASK) + TYPE_LOCAL); - case MessageType::YetUnsent: - return MessageId(((id + TYPE_MASK + 1 - TYPE_YET_UNSENT) & ~TYPE_MASK) + TYPE_YET_UNSENT); - case MessageType::None: - default: - UNREACHABLE(); - return MessageId(); - } - } + MessageId get_next_message_id(MessageType type) const; int32 get_scheduled_server_message_id() const { CHECK(is_scheduled_server()); @@ -241,24 +181,6 @@ struct MessageIdHash { } }; -inline StringBuilder &operator<<(StringBuilder &string_builder, MessageId message_id) { - if (!message_id.is_valid()) { - return string_builder << "invalid message " << message_id.get(); - } - if (message_id.is_server()) { - return string_builder << "server message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT); - } - if (message_id.is_local()) { - return string_builder << "local message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT) << '.' - << (message_id.get() & MessageId::FULL_TYPE_MASK); - } - if (message_id.is_yet_unsent()) { - return string_builder << "yet unsent message " << (message_id.get() >> MessageId::SERVER_ID_SHIFT) << '.' - << (message_id.get() & MessageId::FULL_TYPE_MASK); - } - return string_builder << "bugged message " << message_id.get(); -} - struct FullMessageId { private: DialogId dialog_id;