summaryrefslogtreecommitdiff
path: root/include/tgbot
diff options
context:
space:
mode:
Diffstat (limited to 'include/tgbot')
-rw-r--r--include/tgbot/EventHandler.h16
-rw-r--r--include/tgbot/types/ForceReply.h2
-rw-r--r--include/tgbot/types/ReplyKeyboardHide.h2
3 files changed, 14 insertions, 6 deletions
diff --git a/include/tgbot/EventHandler.h b/include/tgbot/EventHandler.h
index e4fac7a..bb277a8 100644
--- a/include/tgbot/EventHandler.h
+++ b/include/tgbot/EventHandler.h
@@ -38,13 +38,21 @@ public:
inline void handleUpdate(const Update::Ptr& update) const {
_broadcaster->broadcastAnyMessage(update->message);
if (StringTools::startsWith(update->message->text, "/")) {
+ unsigned long splitPosition;
unsigned long spacePosition = update->message->text.find(' ');
- std::string command;
- if (spacePosition != update->message->text.npos) {
- command = update->message->text.substr(1, spacePosition - 1);
+ unsigned long atSymbolPosition = update->message->text.find('@');
+ if (spacePosition == update->message->text.npos) {
+ if (atSymbolPosition == update->message->text.npos) {
+ splitPosition = update->message->text.size();
+ } else {
+ splitPosition = atSymbolPosition;
+ }
+ } else if (atSymbolPosition == update->message->text.npos) {
+ splitPosition = spacePosition;
} else {
- command = update->message->text.substr(1, update->message->text.size() - 1);
+ splitPosition = std::min(spacePosition, atSymbolPosition);
}
+ std::string command = update->message->text.substr(1, splitPosition - 1);
if (!_broadcaster->broadcastCommand(command, update->message)) {
_broadcaster->broadcastUnknownCommand(update->message);
}
diff --git a/include/tgbot/types/ForceReply.h b/include/tgbot/types/ForceReply.h
index f46197a..8a946f8 100644
--- a/include/tgbot/types/ForceReply.h
+++ b/include/tgbot/types/ForceReply.h
@@ -50,7 +50,7 @@ public:
/**
* Optional. Use this parameter if you want to force reply from specific users only. Targets: 1) users that are @mentioned in the text of the Message object; 2) if the bot's message is a reply (has reply_to_message_id), sender of the original message.
*/
- bool selective;
+ bool selective = false;
};
}
diff --git a/include/tgbot/types/ReplyKeyboardHide.h b/include/tgbot/types/ReplyKeyboardHide.h
index e4c4b20..acb0e5c 100644
--- a/include/tgbot/types/ReplyKeyboardHide.h
+++ b/include/tgbot/types/ReplyKeyboardHide.h
@@ -47,7 +47,7 @@ public:
* Optional. Use this parameter if you want to hide keyboard for specific users only. Targets: 1) users that are @mentioned in the text of the Message object; 2) if the bot's message is a reply (has reply_to_message_id), sender of the original message.
* Example: A user votes in a poll, bot returns confirmation message in reply to the vote and hides keyboard for that user, while still showing the keyboard with poll options to users who haven't voted yet.
*/
- bool selective;
+ bool selective = false;
};
}