summaryrefslogtreecommitdiff
path: root/include/tgbot/EventBroadcaster.h
diff options
context:
space:
mode:
authorOleg Morozenkov <omorozenkov@gmail.com>2016-04-03 00:09:06 +0400
committerOleg Morozenkov <omorozenkov@gmail.com>2016-04-03 00:09:06 +0400
commitb6fd8d8ff899240580c5973bd75d74c5167b8d3d (patch)
treeb24d43cd2a13ba923de495961bf9a5e613ae683a /include/tgbot/EventBroadcaster.h
parent2195ce0768fa8903633164c0c45060c412cd5670 (diff)
parentb937e88dd43a7708f40af6a3c333046e3121a77a (diff)
Merge pull request #19 from aadeg/master
Implementing inline mode BIS
Diffstat (limited to 'include/tgbot/EventBroadcaster.h')
-rw-r--r--include/tgbot/EventBroadcaster.h44
1 files changed, 35 insertions, 9 deletions
diff --git a/include/tgbot/EventBroadcaster.h b/include/tgbot/EventBroadcaster.h
index 3ec8865..d97dbbb 100644
--- a/include/tgbot/EventBroadcaster.h
+++ b/include/tgbot/EventBroadcaster.h
@@ -29,6 +29,8 @@
#include <map>
#include "tgbot/types/Message.h"
+#include "tgbot/types/InlineQuery.h"
+#include "tgbot/types/ChosenInlineResult.h"
namespace TgBot {
@@ -44,6 +46,8 @@ friend EventHandler;
public:
typedef std::function<void (const Message::Ptr&)> MessageListener;
+ typedef std::function<void (const InlineQuery::Ptr&)> InlineQueryListener;
+ typedef std::function<void (const ChosenInlineResult::Ptr&)> ChosenInlineResultListener;
/**
* Registers listener which receives all messages which the bot can ever receive.
@@ -78,13 +82,29 @@ public:
_onNonCommandMessageListeners.push_back(listener);
}
+ inline void onInlineQuery(const InlineQueryListener& listener) {
+ _onInlineQueryListeners.push_back(listener);
+ }
+
+ inline void onChosenInlineResult(const ChosenInlineResultListener& listener){
+ _onChosenInlineResultListeners.push_back(listener);
+ }
+
private:
- inline void broadcastAnyMessage(const Message::Ptr& message) const {
- for (const MessageListener& item : _onAnyMessageListeners) {
- item(message);
+ template<typename ListenerType, typename ObjectType>
+ inline void broadcast(const std::vector<ListenerType>& listeners, const ObjectType& object) const {
+ if (!object)
+ return;
+
+ for (const ListenerType& item : listeners) {
+ item(object);
}
}
+ inline void broadcastAnyMessage(const Message::Ptr& message) const {
+ broadcast<MessageListener, Message::Ptr>(_onAnyMessageListeners, message);
+ }
+
inline bool broadcastCommand(const std::string command, const Message::Ptr& message) const {
std::map<std::string, MessageListener>::const_iterator iter = _onCommandListeners.find(command);
if (iter == _onCommandListeners.end()) {
@@ -95,21 +115,27 @@ private:
}
inline void broadcastUnknownCommand(const Message::Ptr& message) const {
- for (const MessageListener& item : _onUnknownCommandListeners) {
- item(message);
- }
+ broadcast<MessageListener, Message::Ptr>(_onUnknownCommandListeners, message);
}
inline void broadcastNonCommandMessage(const Message::Ptr& message) const {
- for (const MessageListener& item : _onNonCommandMessageListeners) {
- item(message);
- }
+ broadcast<MessageListener, Message::Ptr>(_onNonCommandMessageListeners, message);
+ }
+
+ inline void broadcastInlineQuery(const InlineQuery::Ptr& query) const {
+ broadcast<InlineQueryListener, InlineQuery::Ptr>(_onInlineQueryListeners, query);
+ }
+
+ inline void broadcastChosenInlineResult(const ChosenInlineResult::Ptr& result) const {
+ broadcast<ChosenInlineResultListener, ChosenInlineResult::Ptr>(_onChosenInlineResultListeners, result);
}
std::vector<MessageListener> _onAnyMessageListeners;
std::map<std::string, MessageListener> _onCommandListeners;
std::vector<MessageListener> _onUnknownCommandListeners;
std::vector<MessageListener> _onNonCommandMessageListeners;
+ std::vector<InlineQueryListener> _onInlineQueryListeners;
+ std::vector<ChosenInlineResultListener> _onChosenInlineResultListeners;
};
}