CObject.cpp 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include <LibCore/CObject.h>
  2. #include <LibCore/CEvent.h>
  3. #include <LibCore/CEventLoop.h>
  4. #include <AK/Assertions.h>
  5. #include <stdio.h>
  6. CObject::CObject(CObject* parent)
  7. : m_parent(parent)
  8. {
  9. if (m_parent)
  10. m_parent->add_child(*this);
  11. }
  12. CObject::~CObject()
  13. {
  14. stop_timer();
  15. if (m_parent)
  16. m_parent->remove_child(*this);
  17. auto children_to_delete = move(m_children);
  18. for (auto* child : children_to_delete)
  19. delete child;
  20. }
  21. void CObject::event(CEvent& event)
  22. {
  23. switch (event.type()) {
  24. case CEvent::Timer:
  25. return timer_event(static_cast<CTimerEvent&>(event));
  26. case CEvent::DeferredDestroy:
  27. delete this;
  28. break;
  29. case CEvent::ChildAdded:
  30. case CEvent::ChildRemoved:
  31. return child_event(static_cast<CChildEvent&>(event));
  32. case CEvent::Invalid:
  33. ASSERT_NOT_REACHED();
  34. break;
  35. default:
  36. break;
  37. }
  38. }
  39. void CObject::add_child(CObject& object)
  40. {
  41. m_children.append(&object);
  42. CEventLoop::current().post_event(*this, make<CChildEvent>(CEvent::ChildAdded, object));
  43. }
  44. void CObject::remove_child(CObject& object)
  45. {
  46. for (ssize_t i = 0; i < m_children.size(); ++i) {
  47. if (m_children[i] == &object) {
  48. m_children.remove(i);
  49. CEventLoop::current().post_event(*this, make<CChildEvent>(CEvent::ChildRemoved, object));
  50. return;
  51. }
  52. }
  53. }
  54. void CObject::timer_event(CTimerEvent&)
  55. {
  56. }
  57. void CObject::child_event(CChildEvent&)
  58. {
  59. }
  60. void CObject::start_timer(int ms)
  61. {
  62. if (m_timer_id) {
  63. dbgprintf("CObject{%p} already has a timer!\n", this);
  64. ASSERT_NOT_REACHED();
  65. }
  66. m_timer_id = CEventLoop::register_timer(*this, ms, true);
  67. }
  68. void CObject::stop_timer()
  69. {
  70. if (!m_timer_id)
  71. return;
  72. bool success = CEventLoop::unregister_timer(m_timer_id);
  73. ASSERT(success);
  74. m_timer_id = 0;
  75. }
  76. void CObject::delete_later()
  77. {
  78. CEventLoop::current().post_event(*this, make<CEvent>(CEvent::DeferredDestroy));
  79. }
  80. void CObject::dump_tree(int indent)
  81. {
  82. for (int i = 0; i < indent; ++i) {
  83. printf(" ");
  84. }
  85. printf("%s{%p}\n", class_name(), this);
  86. for (auto* child : children()) {
  87. child->dump_tree(indent + 2);
  88. }
  89. }
  90. void CObject::deferred_invoke(Function<void(CObject&)> invokee)
  91. {
  92. CEventLoop::current().post_event(*this, make<CDeferredInvocationEvent>(move(invokee)));
  93. }