From e6644d6b235005de9ba1b9884472fa5f5d8d6074 Mon Sep 17 00:00:00 2001 From: HampusM Date: Sun, 20 Mar 2022 18:49:49 +0100 Subject: refactor: update event system terminology & structure --- src/engine/user/input.hpp | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) (limited to 'src/engine/user/input.hpp') diff --git a/src/engine/user/input.hpp b/src/engine/user/input.hpp index d2aa447..7a3c88e 100644 --- a/src/engine/user/input.hpp +++ b/src/engine/user/input.hpp @@ -1,9 +1,8 @@ #pragma once #include "DI/auto_wirable.hpp" -#include "interfaces/command.hpp" #include "interfaces/input.hpp" -#include "interfaces/observable.hpp" +#include "interfaces/subscriber.hpp" #include #include @@ -18,21 +17,23 @@ public: void listen() const noexcept override; - void attach(const char &key, - const std::shared_ptr &command) noexcept override; + void + subscribe(const Event &event, + const std::shared_ptr> &subscriber) noexcept override; - void notify(const char &key) const noexcept override; + void notify_subscribers(const Event &event, + const Context &context) const noexcept override; void enter_raw_mode() noexcept override; void leave_raw_mode() noexcept override; private: - std::array>, CHAR_MAX> _key_commands; + std::array>>, CHAR_MAX> _subscribers; std::shared_ptr _original_termios = nullptr; - using _KeyCommandsSizeType = decltype(_key_commands)::size_type; + using _SubscribersSizeType = decltype(_subscribers)::size_type; - static _KeyCommandsSizeType _key_as_index(const char &key) noexcept; + static _SubscribersSizeType _event_as_index(const Event &event) noexcept; }; -- cgit v1.2.3-18-g5258