diff --git a/src/hook_manager.cc b/src/hook_manager.cc index 5e538681..b08377e5 100644 --- a/src/hook_manager.cc +++ b/src/hook_manager.cc @@ -13,6 +13,17 @@ namespace Kakoune { +struct HookManager::Hook +{ + String group; + Regex filter; + String commands; +}; + +HookManager::HookManager() : m_parent(nullptr) {} +HookManager::HookManager(HookManager& parent) : SafeCountable{}, m_parent(&parent) {} +HookManager::~HookManager() = default; + void HookManager::add_hook(StringView hook_name, String group, Regex filter, String commands) { auto& hooks = m_hooks[hook_name]; diff --git a/src/hook_manager.hh b/src/hook_manager.hh index 66baecf3..215cdeb8 100644 --- a/src/hook_manager.hh +++ b/src/hook_manager.hh @@ -4,17 +4,18 @@ #include "hash_map.hh" #include "completion.hh" #include "safe_ptr.hh" -#include "regex.hh" namespace Kakoune { class Context; +class Regex; class HookManager : public SafeCountable { public: - HookManager(HookManager& parent) : SafeCountable{}, m_parent(&parent) {} + HookManager(HookManager& parent); + ~HookManager(); void add_hook(StringView hook_name, String group, Regex filter, String commands); void remove_hooks(StringView group); @@ -23,17 +24,11 @@ public: Context& context) const; private: - HookManager() - : m_parent(nullptr) {} + HookManager(); // the only one allowed to construct a root hook manager friend class Scope; - struct Hook - { - String group; - Regex filter; - String commands; - }; + struct Hook; SafePtr m_parent; HashMap, MemoryDomain::Hooks>, MemoryDomain::Hooks> m_hooks;