aboutsummaryrefslogtreecommitdiff
path: root/src/crepe/api/EventManager.h
diff options
context:
space:
mode:
authorWBoerenkamps <wrj.boerenkamps@student.avans.nl>2024-11-11 16:12:09 +0100
committerWBoerenkamps <wrj.boerenkamps@student.avans.nl>2024-11-11 16:12:09 +0100
commit80c74b90a3e44e25a4fa9fdd25bf0aa9efbaf6fd (patch)
tree1ac04e3434c8e775318b6f8519c6674bb2a3298d /src/crepe/api/EventManager.h
parent880a7b1fb233a67303ad5a4155dc459f79734762 (diff)
interfaces working but unsubscribe broken
Diffstat (limited to 'src/crepe/api/EventManager.h')
-rw-r--r--src/crepe/api/EventManager.h39
1 files changed, 38 insertions, 1 deletions
diff --git a/src/crepe/api/EventManager.h b/src/crepe/api/EventManager.h
index 8c0685a..88a386a 100644
--- a/src/crepe/api/EventManager.h
+++ b/src/crepe/api/EventManager.h
@@ -20,7 +20,8 @@ public:
}
template <typename EventType>
void subscribe(EventHandler<EventType> && callback, int channel = 0);
- void unsubscribe(std::type_index eventType, const std::string & handlerName,int channel);
+ template <typename EventType>
+ void unsubscribe(const EventHandler<EventType> &, int eventId);
template <typename EventType>
void trigger_event(const EventType & event, int channel);
void queue_event(std::unique_ptr<Event> && event, int channel);
@@ -74,3 +75,39 @@ void EventManager::trigger_event(const EventType & event, int eventId) {
}
}
}
+template <typename EventType>
+void EventManager::unsubscribe(const EventHandler<EventType> & callback, int channel) {
+ std::type_index event_type(typeid(EventType));
+ std::string handler_name(callback.target_type().name());
+ std::cout << "unsubcribe name: " << handler_name << std::endl;
+
+ if (channel) {
+ auto subscriber_list = subscribers_by_event_id.find(event_type);
+ if (subscriber_list != subscribers_by_event_id.end()) {
+ auto& handlers_map = subscriber_list->second;
+ auto handlers = handlers_map.find(channel);
+ if (handlers != handlers_map.end()) {
+ auto& callbacks = handlers->second;
+ for (auto it = callbacks.begin(); it != callbacks.end(); ++it) {
+ if ((*it)->get_type() == handler_name) {
+ std::cout << "successfully erased an event" << std::endl;
+ it = callbacks.erase(it);
+ return;
+ }
+ }
+ }
+ }
+ } else {
+ auto handlers_it = subscribers.find(event_type);
+ if (handlers_it != subscribers.end()) {
+ auto& handlers = handlers_it->second;
+ for (auto it = handlers.begin(); it != handlers.end(); ++it) {
+ if ((*it)->get_type() == handler_name) {
+ std::cout << "successfully erased an event" << std::endl;
+ it = handlers.erase(it);
+ return;
+ }
+ }
+ }
+ }
+}