The Battle for Wesnoth  1.19.8+dev
manager_impl.hpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2003 - 2024
3  by David White <dave@whitevine.net>
4  Part of the Battle for Wesnoth Project https://www.wesnoth.org/
5 
6  This program is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2 of the License, or
9  (at your option) any later version.
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY.
12 
13  See the COPYING file for more details.
14 */
15 
16 #pragma once
17 
18 #include "game_events/fwd.hpp"
19 #include "config.hpp"
20 
21 #include <deque>
22 #include <unordered_map>
23 
24 
25 namespace game_events
26 {
27 class event_handlers;
28 /**
29  * Represents a handler that is about to be added to the events manager but is still waiting for some data.
30  * The handler will automatically be added when this class is destroyed, unless it has become invalid somehow.
31  */
33 {
38  // It's move-constructible, but there's no way to make it move-assignable since it contains a reference...
40 public:
42  : list_(list)
43  , handler_(handler)
44  {}
45  /** Check if this handler is valid. */
46  bool valid() const {return handler_.get();}
47  /** Access the event handler. */
48  event_handler* operator->() {return handler_.get();}
52 };
53 
54 // event_handlers is essentially the implementation details of the manager
56 {
57 private:
58  using handler_queue_t = std::deque<handler_ptr>;
59  using map_t = std::unordered_map<std::string, handler_list>;
60  using id_map_t = std::unordered_map<std::string, weak_handler_ptr>;
61 
62  /**
63  * Active event handlers. Will not have elements removed unless the event_handlers is clear()ed.
64  * This is the only container that actually 'owns' any events in the form of shared_ptrs. The other
65  * three storage methods own weak_ptrs.
66  */
68 
69  /** Active event handlers with fixed event names, organized by event name. */
71 
72  /** Active event handlers with variables in their event names. */
74 
75  /** Allows quick locating of handlers by id. */
77 
78  void log_handlers();
79 
81  void finish_adding_event_handler(const handler_ptr& new_handler);
82 
83 public:
84  /** Utility to standardize the event names used in by_name_. */
85  static std::string standardize_name(const std::string& name);
86 
87  /** Compare function to sort event handlers by priority. */
88  static bool cmp(const handler_ptr& lhs, const handler_ptr& rhs);
89 
91  : active_()
92  , by_name_()
93  , dynamic_()
94  , id_map_()
95  {
96  }
97 
98  /** Access to the handlers with varying event names. */
100  {
101  return dynamic_;
102  }
103 
104  /** Read-only access to the active event handlers. Essentially gives all events. */
106  {
107  return active_;
108  }
109 
111  {
112  return active_;
113  }
114 
115  /** Adds an event handler. */
116  pending_event_handler add_event_handler(const std::string& name, const std::string& id, bool repeat, double priority = 0., bool is_menu_item = false);
117 
118  /** Removes an event handler, identified by its ID. */
119  void remove_event_handler(const std::string& id);
120 
121  /**
122  * Removes all expired event handlers and any weak_ptrs to them.
123  *
124  * @param event_name The event name from whose by-name queue to clean
125  * up handlers.
126  */
127  void clean_up_expired_handlers(const std::string& event_name);
128 
129  /** Gets an event handler, identified by its ID. */
130  const handler_ptr get_event_handler_by_id(const std::string& id);
131 
132  /** The number of active event handlers. */
133  std::size_t size() const
134  {
135  return active_.size();
136  }
137 };
138 
139 } // end namespace game_events
map_t by_name_
Active event handlers with fixed event names, organized by event name.
void finish_adding_event_handler(const handler_ptr &new_handler)
void clean_up_expired_handlers(const std::string &event_name)
Removes all expired event handlers and any weak_ptrs to them.
static bool cmp(const handler_ptr &lhs, const handler_ptr &rhs)
Compare function to sort event handlers by priority.
handler_list & get_dynamic()
Access to the handlers with varying event names.
const handler_queue_t & get_active() const
Read-only access to the active event handlers.
std::size_t size() const
The number of active event handlers.
handler_queue_t & get_active()
void remove_event_handler(const std::string &id)
Removes an event handler, identified by its ID.
pending_event_handler add_event_handler(const std::string &name, const std::string &id, bool repeat, double priority=0., bool is_menu_item=false)
Adds an event handler.
std::deque< handler_ptr > handler_queue_t
std::unordered_map< std::string, weak_handler_ptr > id_map_t
std::unordered_map< std::string, handler_list > map_t
handler_list dynamic_
Active event handlers with variables in their event names.
id_map_t id_map_
Allows quick locating of handlers by id.
const handler_ptr get_event_handler_by_id(const std::string &id)
Gets an event handler, identified by its ID.
handler_queue_t active_
Active event handlers.
static std::string standardize_name(const std::string &name)
Utility to standardize the event names used in by_name_.
Represents a handler that is about to be added to the events manager but is still waiting for some da...
pending_event_handler & operator=(pending_event_handler &&)=delete
pending_event_handler & operator=(const pending_event_handler &)=delete
pending_event_handler(pending_event_handler &&)=default
pending_event_handler(const pending_event_handler &)=delete
pending_event_handler(event_handlers &list, handler_ptr handler)
bool valid() const
Check if this handler is valid.
event_handler * operator->()
Access the event handler.
Definitions for the interface to Wesnoth Markup Language (WML).
Domain specific events.
std::list< weak_handler_ptr > handler_list
Definition: fwd.hpp:27
std::shared_ptr< event_handler > handler_ptr
Definition: fwd.hpp:25