mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 04:38:11 +00:00
LibCore: Make CObject reference-counted
Okay, I've spent a whole day on this now, and it finally kinda works! With this patch, CObject and all of its derived classes are reference counted instead of tree-owned. The previous, Qt-like model was nice and familiar, but ultimately also outdated and difficult to reason about. CObject-derived types should now be stored in RefPtr/NonnullRefPtr and each class can be constructed using the forwarding construct() helper: auto widget = GWidget::construct(parent_widget); Note that construct() simply forwards all arguments to an existing constructor. It is inserted into each class by the C_OBJECT macro, see CObject.h to understand how that works. CObject::delete_later() disappears in this patch, as there is no longer a single logical owner of a CObject.
This commit is contained in:
parent
0c72e0c09f
commit
bc319d9e88
45 changed files with 174 additions and 233 deletions
|
@ -325,13 +325,13 @@ Rect GWidget::screen_relative_rect() const
|
|||
GWidget* GWidget::child_at(const Point& point) const
|
||||
{
|
||||
for (int i = children().size() - 1; i >= 0; --i) {
|
||||
if (!is<GWidget>(*children()[i]))
|
||||
if (!is<GWidget>(children()[i]))
|
||||
continue;
|
||||
auto& child = to<GWidget>(*children()[i]);
|
||||
auto& child = to<GWidget>(children()[i]);
|
||||
if (!child.is_visible())
|
||||
continue;
|
||||
if (child.relative_rect().contains(point))
|
||||
return &child;
|
||||
return const_cast<GWidget*>(&child);
|
||||
}
|
||||
return nullptr;
|
||||
}
|
||||
|
@ -492,7 +492,7 @@ void GWidget::move_to_front()
|
|||
parent->children().remove_first_matching([this](auto& entry) {
|
||||
return entry == this;
|
||||
});
|
||||
parent->children().append(this);
|
||||
parent->children().append(*this);
|
||||
parent->update();
|
||||
}
|
||||
|
||||
|
@ -506,7 +506,7 @@ void GWidget::move_to_back()
|
|||
parent->children().remove_first_matching([this](auto& entry) {
|
||||
return entry == this;
|
||||
});
|
||||
parent->children().prepend(this);
|
||||
parent->children().prepend(*this);
|
||||
parent->update();
|
||||
}
|
||||
|
||||
|
@ -515,7 +515,7 @@ bool GWidget::is_frontmost() const
|
|||
auto* parent = parent_widget();
|
||||
if (!parent)
|
||||
return true;
|
||||
return parent->children().last() == this;
|
||||
return &parent->children().last() == this;
|
||||
}
|
||||
|
||||
bool GWidget::is_backmost() const
|
||||
|
@ -523,7 +523,7 @@ bool GWidget::is_backmost() const
|
|||
auto* parent = parent_widget();
|
||||
if (!parent)
|
||||
return true;
|
||||
return parent->children().first() == this;
|
||||
return &parent->children().first() == this;
|
||||
}
|
||||
|
||||
GAction* GWidget::action_for_key_event(const GKeyEvent& event)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue