EventReceiver.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  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. // The call to `remove_child` may have deleted the object.
  109. // Do not dereference `this` from this point forward.
  110. }
  111. template<class T, class... Args>
  112. inline T& add(Args&&... args)
  113. {
  114. auto child = T::construct(forward<Args>(args)...);
  115. add_child(*child);
  116. return child;
  117. }
  118. template<class T, class... Args>
  119. inline ErrorOr<NonnullRefPtr<T>> try_add(Args&&... args)
  120. {
  121. auto child = TRY(T::try_create(forward<Args>(args)...));
  122. TRY(try_add_child(*child));
  123. return child;
  124. }
  125. virtual bool is_visible_for_timer_purposes() const;
  126. protected:
  127. explicit EventReceiver(EventReceiver* parent = nullptr);
  128. virtual void event(Core::Event&);
  129. virtual void timer_event(TimerEvent&);
  130. virtual void custom_event(CustomEvent&);
  131. // NOTE: You may get child events for children that are not yet fully constructed!
  132. virtual void child_event(ChildEvent&);
  133. private:
  134. EventReceiver* m_parent { nullptr };
  135. ByteString m_name;
  136. intptr_t m_timer_id { 0 };
  137. Vector<NonnullRefPtr<EventReceiver>> m_children;
  138. Function<bool(Core::Event&)> m_event_filter;
  139. };
  140. }
  141. template<>
  142. struct AK::Formatter<Core::EventReceiver> : AK::Formatter<FormatString> {
  143. ErrorOr<void> format(FormatBuilder& builder, Core::EventReceiver const& value)
  144. {
  145. return AK::Formatter<FormatString>::format(builder, "{}({})"sv, value.class_name(), &value);
  146. }
  147. };
  148. namespace Core {
  149. template<typename T, typename Callback>
  150. inline void EventReceiver::for_each_child_of_type(Callback callback)
  151. requires IsBaseOf<EventReceiver, T>
  152. {
  153. for_each_child([&](auto& child) {
  154. if (is<T>(child))
  155. return callback(static_cast<T&>(child));
  156. return IterationDecision::Continue;
  157. });
  158. }
  159. template<typename T>
  160. T* EventReceiver::find_child_of_type_named(StringView name)
  161. requires IsBaseOf<EventReceiver, T>
  162. {
  163. T* found_child = nullptr;
  164. for_each_child_of_type<T>([&](auto& child) {
  165. if (child.name() == name) {
  166. found_child = &child;
  167. return IterationDecision::Break;
  168. }
  169. return IterationDecision::Continue;
  170. });
  171. return found_child;
  172. }
  173. template<typename T>
  174. T* EventReceiver::find_descendant_of_type_named(StringView name)
  175. requires IsBaseOf<EventReceiver, T>
  176. {
  177. if (is<T>(*this) && this->name() == name) {
  178. return static_cast<T*>(this);
  179. }
  180. T* found_child = nullptr;
  181. for_each_child([&](auto& child) {
  182. found_child = child.template find_descendant_of_type_named<T>(name);
  183. if (found_child)
  184. return IterationDecision::Break;
  185. return IterationDecision::Continue;
  186. });
  187. return found_child;
  188. }
  189. }