mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 15:47:44 +00:00
LibWeb: Unregister IntersectionObserver in finalize, not the destructor
Otherwise it UAFs the intersection root. Not sure how this didn't cause a lot of crashes!
This commit is contained in:
parent
5694981352
commit
7550b4175e
2 changed files with 4 additions and 1 deletions
|
@ -53,7 +53,9 @@ IntersectionObserver::IntersectionObserver(JS::Realm& realm, JS::GCPtr<WebIDL::C
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
IntersectionObserver::~IntersectionObserver()
|
IntersectionObserver::~IntersectionObserver() = default;
|
||||||
|
|
||||||
|
void IntersectionObserver::finalize()
|
||||||
{
|
{
|
||||||
intersection_root().visit([this](auto& node) {
|
intersection_root().visit([this](auto& node) {
|
||||||
node->document().unregister_intersection_observer({}, *this);
|
node->document().unregister_intersection_observer({}, *this);
|
||||||
|
|
|
@ -66,6 +66,7 @@ private:
|
||||||
|
|
||||||
virtual void initialize(JS::Realm&) override;
|
virtual void initialize(JS::Realm&) override;
|
||||||
virtual void visit_edges(JS::Cell::Visitor&) override;
|
virtual void visit_edges(JS::Cell::Visitor&) override;
|
||||||
|
virtual void finalize() override;
|
||||||
|
|
||||||
// https://www.w3.org/TR/intersection-observer/#dom-intersectionobserver-callback-slot
|
// https://www.w3.org/TR/intersection-observer/#dom-intersectionobserver-callback-slot
|
||||||
JS::GCPtr<WebIDL::CallbackType> m_callback;
|
JS::GCPtr<WebIDL::CallbackType> m_callback;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue