EventReceiver.h 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /*
  2. * Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2022, the SerenityOS developers.
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #pragma once
  8. #include <AK/ByteString.h>
  9. #include <AK/Forward.h>
  10. #include <AK/Function.h>
  11. #include <AK/HashMap.h>
  12. #include <AK/Noncopyable.h>
  13. #include <AK/OwnPtr.h>
  14. #include <AK/StringView.h>
  15. #include <AK/TypeCasts.h>
  16. #include <AK/Weakable.h>
  17. #include <LibCore/Forward.h>
  18. namespace Core {
  19. enum class TimerShouldFireWhenNotVisible {
  20. No = 0,
  21. Yes
  22. };
  23. #define C_OBJECT(klass) \
  24. public: \
  25. virtual StringView class_name() const override \
  26. { \
  27. return #klass##sv; \
  28. } \
  29. template<typename Klass = klass, class... Args> \
  30. static NonnullRefPtr<klass> construct(Args&&... args) \
  31. { \
  32. return adopt_ref(*new Klass(::forward<Args>(args)...)); \
  33. } \
  34. template<typename Klass = klass, class... Args> \
  35. static ErrorOr<NonnullRefPtr<klass>> try_create(Args&&... args) \
  36. { \
  37. return adopt_nonnull_ref_or_enomem(new (nothrow) Klass(::forward<Args>(args)...)); \
  38. }
  39. #define C_OBJECT_ABSTRACT(klass) \
  40. public: \
  41. virtual StringView class_name() const override \
  42. { \
  43. return #klass##sv; \
  44. }
  45. class EventReceiver
  46. : public RefCounted<EventReceiver>
  47. , public Weakable<EventReceiver> {
  48. // NOTE: No C_OBJECT macro for Core::EventReceiver itself.
  49. AK_MAKE_NONCOPYABLE(EventReceiver);
  50. AK_MAKE_NONMOVABLE(EventReceiver);
  51. public:
  52. virtual ~EventReceiver();
  53. virtual StringView class_name() const = 0;
  54. template<typename T>
  55. bool fast_is() const = delete;
  56. virtual bool is_widget() const { return false; }
  57. ByteString const& name() const { return m_name; }
  58. void set_name(ByteString name) { m_name = move(name); }
  59. Vector<NonnullRefPtr<EventReceiver>>& children() { return m_children; }
  60. Vector<NonnullRefPtr<EventReceiver>> const& children() const { return m_children; }
  61. template<typename Callback>
  62. void for_each_child(Callback callback)
  63. {
  64. for (auto& child : m_children) {
  65. if (callback(*child) == IterationDecision::Break)
  66. return;
  67. }
  68. }
  69. template<typename T, typename Callback>
  70. void for_each_child_of_type(Callback callback)
  71. requires IsBaseOf<EventReceiver, T>;
  72. template<typename T>
  73. T* find_child_of_type_named(StringView)
  74. requires IsBaseOf<EventReceiver, T>;
  75. template<typename T, size_t N>
  76. ALWAYS_INLINE T* find_child_of_type_named(char const (&string_literal)[N])
  77. requires IsBaseOf<EventReceiver, T>
  78. {
  79. return find_child_of_type_named<T>(StringView { string_literal, N - 1 });
  80. }
  81. template<typename T>
  82. T* find_descendant_of_type_named(StringView)
  83. requires IsBaseOf<EventReceiver, T>;
  84. template<typename T, size_t N>
  85. ALWAYS_INLINE T* find_descendant_of_type_named(char const (&string_literal)[N])
  86. requires IsBaseOf<EventReceiver, T>
  87. {
  88. return find_descendant_of_type_named<T>(StringView { string_literal, N - 1 });
  89. }
  90. bool is_ancestor_of(EventReceiver const&) const;
  91. EventReceiver* parent() { return m_parent; }
  92. EventReceiver const* parent() const { return m_parent; }
  93. void start_timer(int ms, TimerShouldFireWhenNotVisible = TimerShouldFireWhenNotVisible::No);
  94. void stop_timer();
  95. bool has_timer() const { return m_timer_id; }
  96. ErrorOr<void> try_add_child(EventReceiver&);
  97. void add_child(EventReceiver&);
  98. void insert_child_before(EventReceiver& new_child, EventReceiver& before_child);
  99. void remove_child(EventReceiver&);
  100. void remove_all_children();
  101. void set_event_filter(Function<bool(Core::Event&)>);
  102. void deferred_invoke(Function<void()>);
  103. void dispatch_event(Core::Event&, EventReceiver* stay_within = nullptr);
  104. void remove_from_parent()
  105. {
  106. if (m_parent)
  107. m_parent->remove_child(*this);
  108. m_parent = nullptr;
  109. }
  110. template<class T, class... Args>
  111. inline T& add(Args&&... args)
  112. {
  113. auto child = T::construct(forward<Args>(args)...);
  114. add_child(*child);
  115. return child;
  116. }
  117. template<class T, class... Args>
  118. inline ErrorOr<NonnullRefPtr<T>> try_add(Args&&... args)
  119. {
  120. auto child = TRY(T::try_create(forward<Args>(args)...));
  121. TRY(try_add_child(*child));
  122. return child;
  123. }
  124. virtual bool is_visible_for_timer_purposes() const;
  125. protected:
  126. explicit EventReceiver(EventReceiver* parent = nullptr);
  127. virtual void event(Core::Event&);
  128. virtual void timer_event(TimerEvent&);
  129. virtual void custom_event(CustomEvent&);
  130. // NOTE: You may get child events for children that are not yet fully constructed!
  131. virtual void child_event(ChildEvent&);
  132. private:
  133. EventReceiver* m_parent { nullptr };
  134. ByteString m_name;
  135. int m_timer_id { 0 };
  136. Vector<NonnullRefPtr<EventReceiver>> m_children;
  137. Function<bool(Core::Event&)> m_event_filter;
  138. };
  139. }
  140. template<>
  141. struct AK::Formatter<Core::EventReceiver> : AK::Formatter<FormatString> {
  142. ErrorOr<void> format(FormatBuilder& builder, Core::EventReceiver const& value)
  143. {
  144. return AK::Formatter<FormatString>::format(builder, "{}({})"sv, value.class_name(), &value);
  145. }
  146. };
  147. namespace Core {
  148. template<typename T, typename Callback>
  149. inline void EventReceiver::for_each_child_of_type(Callback callback)
  150. requires IsBaseOf<EventReceiver, T>
  151. {
  152. for_each_child([&](auto& child) {
  153. if (is<T>(child))
  154. return callback(static_cast<T&>(child));
  155. return IterationDecision::Continue;
  156. });
  157. }
  158. template<typename T>
  159. T* EventReceiver::find_child_of_type_named(StringView name)
  160. requires IsBaseOf<EventReceiver, T>
  161. {
  162. T* found_child = nullptr;
  163. for_each_child_of_type<T>([&](auto& child) {
  164. if (child.name() == name) {
  165. found_child = &child;
  166. return IterationDecision::Break;
  167. }
  168. return IterationDecision::Continue;
  169. });
  170. return found_child;
  171. }
  172. template<typename T>
  173. T* EventReceiver::find_descendant_of_type_named(StringView name)
  174. requires IsBaseOf<EventReceiver, T>
  175. {
  176. if (is<T>(*this) && this->name() == name) {
  177. return static_cast<T*>(this);
  178. }
  179. T* found_child = nullptr;
  180. for_each_child([&](auto& child) {
  181. found_child = child.template find_descendant_of_type_named<T>(name);
  182. if (found_child)
  183. return IterationDecision::Break;
  184. return IterationDecision::Continue;
  185. });
  186. return found_child;
  187. }
  188. }