From b79bd701400fb8bf8a845f8a24d78e82f182bb2f Mon Sep 17 00:00:00 2001 From: JellyBrick Date: Sat, 26 May 2018 17:46:51 +0900 Subject: Improve performance --- include/tgbot/Api.h | 38 ++++++------ include/tgbot/TgTypeParser.h | 2 +- include/tgbot/net/HttpServer.h | 4 +- include/tgbot/net/TgWebhookLocalServer.h | 2 +- src/EventHandler.cpp | 6 +- src/TgTypeParser.cpp | 102 +++++++++++++++---------------- src/types/InputFile.cpp | 2 +- 7 files changed, 78 insertions(+), 78 deletions(-) diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h index e5b8c5e..4eb63c7 100644 --- a/include/tgbot/Api.h +++ b/include/tgbot/Api.h @@ -75,7 +75,7 @@ public: * @param disableNotification Optional. Sends the message silenty. * @return On success, the sent message is returned. */ - Message::Ptr sendMessage(int64_t chatId, const std::string& text, bool disableWebPagePreview = false, int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), const std::string& parseMode = "", bool disableNotification = false) const; + Message::Ptr sendMessage(int64_t chatId, const std::string& text, bool disableWebPagePreview = false, int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = std::make_shared(), const std::string& parseMode = "", bool disableNotification = false) const; /** * Use this method to forward messages of any kind. @@ -98,7 +98,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendPhoto(int64_t chatId, const InputFile::Ptr photo, const std::string& caption = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send photos. @@ -111,7 +111,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendPhoto(int64_t chatId, const std::string& photoId, const std::string& caption = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document). @@ -128,7 +128,7 @@ public: */ Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr audio, const std::string &caption = "", int32_t duration = 0, const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document). @@ -145,7 +145,7 @@ public: */ Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, const std::string &caption = "", int32_t duration = 0, const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send general files. @@ -158,7 +158,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendDocument(int64_t chatId, const InputFile::Ptr document, const std::string &caption = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send general files. @@ -171,7 +171,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendDocument(int64_t chatId, const std::string& documentId, const std::string &caption = "", int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send .webp stickers. @@ -183,7 +183,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendSticker(int64_t chatId, const InputFile::Ptr sticker, int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send .webp stickers. @@ -195,7 +195,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendSticker(int64_t chatId, const std::string& stickerId, int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document). @@ -211,7 +211,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendVideo(int64_t chatId, const InputFile::Ptr video, int32_t duration = 0, int32_t width = 0, int32_t height = 0, const std::string &caption = "", - int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document). @@ -227,7 +227,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendVideo(int64_t chatId, const std::string& videoId, int32_t duration = 0, int32_t width = 0, int32_t height = 0, const std::string &caption = "", - int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. @@ -241,7 +241,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendVoice(int64_t chatId, const InputFile::Ptr voice, const std::string &caption = "", int duration = 0, int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. @@ -255,7 +255,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendVoice(int64_t chatId, const std::string& voiceId, const std::string &caption = "", int duration = 0, int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send point on the map. @@ -268,7 +268,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendLocation(int64_t chatId, float latitude, float longitude, int32_t replyToMessageId = 0, - const GenericReply::Ptr replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const; + const GenericReply::Ptr replyMarkup = std::make_shared(), bool disableNotification = false) const; /** * Use this method to send information about a venue. On success, the sent Message is returned. @@ -284,7 +284,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendVenue(int64_t chatId, float latitude, float longitude, std::string title, std::string address, std::string foursquareId = "", - bool disableNotification = false, int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = GenericReply::Ptr()) const; + bool disableNotification = false, int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = std::make_shared()) const; /** * Use this method to send phone contacts. On success, the sent Message is returned. @@ -298,7 +298,7 @@ public: * @return On success, the sent message is returned. */ Message::Ptr sendContact(int64_t chatId, std::string phoneNumber, std::string firstName, std::string lastName = "", bool disableNotification = false, - int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = GenericReply::Ptr()) const; + int32_t replyToMessageId = 0, const GenericReply::Ptr replyMarkup = std::make_shared()) const; /** * Use this method when you need to tell the user that something is happening on the bot's side. The status is set for 5 seconds or less (when a message arrives from your bot, Telegram clients clear its typing status). @@ -384,7 +384,7 @@ public: * @return Message object on success, otherwise nullptr */ Message::Ptr editMessageText(const std::string& text, int64_t chatId=0, int32_t messageId=0, const std::string& inlineMessageId="", - const std::string& parseMode = "", bool disableWebPagePreview = false, const GenericReply::Ptr replyMarkup = GenericReply::Ptr()) const; + const std::string& parseMode = "", bool disableWebPagePreview = false, const GenericReply::Ptr replyMarkup = std::make_shared()) const; /** * Use this method to edit captions of messages sent by the bot or via the bot (for inline bots). @@ -396,7 +396,7 @@ public: * @return Message object on success, otherwise nullptr */ Message::Ptr editMessageCaption(int64_t chatId = 0, int32_t messageId = 0, const std::string& caption = "", - const std::string& inlineMessageId = "", const GenericReply::Ptr replyMarkup = GenericReply::Ptr()) const; + const std::string& inlineMessageId = "", const GenericReply::Ptr replyMarkup = std::make_shared()) const; /** * Use this method to edit only the reply markup of messages sent by the bot or via the bot (for inline bots). @@ -407,7 +407,7 @@ public: * @return Message object on success, otherwise nullptr */ Message::Ptr editMessageReplyMarkup(int64_t chatId = 0, int32_t messageId = 0, const std::string& inlineMessageId = "", - const GenericReply::Ptr replyMarkup = GenericReply::Ptr()) const; + const GenericReply::Ptr replyMarkup = std::make_shared()) const; /** * Use this method to delete messages sent by bot (or by other users if bot is admin). diff --git a/include/tgbot/TgTypeParser.h b/include/tgbot/TgTypeParser.h index 2faaf45..9f56b8e 100644 --- a/include/tgbot/TgTypeParser.h +++ b/include/tgbot/TgTypeParser.h @@ -245,7 +245,7 @@ public: std::shared_ptr tryParseJson(JsonToTgTypeFunc parseFunc, const boost::property_tree::ptree& data, const std::string& keyName) const { auto treeItem = data.find(keyName); if (treeItem == data.not_found()) { - return std::shared_ptr(); + return std::make_shared(); } return (this->*parseFunc)(treeItem->second); } diff --git a/include/tgbot/net/HttpServer.h b/include/tgbot/net/HttpServer.h index 164bd2b..d68599f 100644 --- a/include/tgbot/net/HttpServer.h +++ b/include/tgbot/net/HttpServer.h @@ -51,8 +51,8 @@ public: * Starts receiving new connections. */ void start() { - std::shared_ptr> socket(new boost::asio::basic_stream_socket(_acceptor->get_io_service())); - std::shared_ptr connection(new Connection(socket, _handler)); + auto socket(std::make_shared>(_acceptor->get_io_service())); + auto connection(std::make_shared(socket, _handler)); _acceptor->async_accept(*connection->socket, [this, connection]() { connection->start(); start(); diff --git a/include/tgbot/net/TgWebhookLocalServer.h b/include/tgbot/net/TgWebhookLocalServer.h index 67268f5..99a0fba 100644 --- a/include/tgbot/net/TgWebhookLocalServer.h +++ b/include/tgbot/net/TgWebhookLocalServer.h @@ -39,7 +39,7 @@ public: TgWebhookLocalServer(std::shared_ptr>& acceptor, const std::string& path, EventHandler* eventHandler) = delete; TgWebhookLocalServer(const std::string& path, const EventHandler* eventHandler) : - TgWebhookServer(std::shared_ptr>(new boost::asio::local::stream_protocol::acceptor(_ioService, boost::asio::local::stream_protocol::endpoint(path))), path, eventHandler) + TgWebhookServer(std::make_shared>(_ioService, boost::asio::local::stream_protocol::endpoint(path)), path, eventHandler) { } diff --git a/src/EventHandler.cpp b/src/EventHandler.cpp index d679683..32efe3e 100644 --- a/src/EventHandler.cpp +++ b/src/EventHandler.cpp @@ -26,9 +26,9 @@ void EventHandler::handleMessage(const Message::Ptr message) const { _broadcaster->broadcastAnyMessage(message); if (StringTools::startsWith(message->text, "/")) { - unsigned long splitPosition; - unsigned long spacePosition = message->text.find(' '); - unsigned long atSymbolPosition = message->text.find('@'); + uint32_t splitPosition; + uint32_t spacePosition = message->text.find(' '); + uint32_t atSymbolPosition = message->text.find('@'); if (spacePosition == message->text.npos) { if (atSymbolPosition == message->text.npos) { splitPosition = message->text.size(); diff --git a/src/TgTypeParser.cpp b/src/TgTypeParser.cpp index 84a83df..1b80d7f 100644 --- a/src/TgTypeParser.cpp +++ b/src/TgTypeParser.cpp @@ -33,7 +33,7 @@ TgTypeParser& TgTypeParser::getInstance() { } Chat::Ptr TgTypeParser::parseJsonAndGetChat(const ptree& data) const { - Chat::Ptr result(new Chat); + auto result(make_shared()); result->id = data.get("id"); string type = data.get("type"); if (type == "private") { @@ -80,7 +80,7 @@ string TgTypeParser::parseChat(const Chat::Ptr& object) const { } User::Ptr TgTypeParser::parseJsonAndGetUser(const ptree& data) const { - User::Ptr result(new User); + auto result(make_shared()); result->id = data.get("id"); result->firstName = data.get("first_name"); result->lastName = data.get("last_name", ""); @@ -104,7 +104,7 @@ string TgTypeParser::parseUser(const User::Ptr& object) const { } MessageEntity::Ptr TgTypeParser::parseJsonAndGetEntity(const ptree& data) const{ - MessageEntity::Ptr result(new MessageEntity); + auto result(make_shared()); result->type=data.get("type"); result->offset=data.get("offset"); result->length=data.get("length"); @@ -114,7 +114,7 @@ MessageEntity::Ptr TgTypeParser::parseJsonAndGetEntity(const ptree& data) const{ } Message::Ptr TgTypeParser::parseJsonAndGetMessage(const ptree& data) const { - Message::Ptr result(new Message); + auto result(make_shared()); result->messageId = data.get("message_id"); result->from = tryParseJson(&TgTypeParser::parseJsonAndGetUser, data, "from"); result->date = data.get("date"); @@ -189,7 +189,7 @@ string TgTypeParser::parseMessage(const Message::Ptr& object) const { } PhotoSize::Ptr TgTypeParser::parseJsonAndGetPhotoSize(const ptree& data) const { - PhotoSize::Ptr result(new PhotoSize); + auto result(make_shared()); result->fileId = data.get("file_id"); result->width = data.get("width"); result->height = data.get("height"); @@ -213,7 +213,7 @@ string TgTypeParser::parsePhotoSize(const PhotoSize::Ptr& object) const { } Audio::Ptr TgTypeParser::parseJsonAndGetAudio(const ptree& data) const { - Audio::Ptr result(new Audio); + auto result(make_shared