mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-04-26 09:45:06 +02:00
LibWeb+LibJS: Make the EventTarget hierarchy (incl. DOM) GC-allocated
This is a monster patch that turns all EventTargets into GC-allocated PlatformObjects. Their C++ wrapper classes are removed, and the LibJS garbage collector is now responsible for their lifetimes. There's a fair amount of hacks and band-aids in this patch, and we'll have a lot of cleanup to do after this.
This commit is contained in:
Notes:
sideshowbarker
2024-07-17 07:28:15 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/6f433c8656 Pull-request: https://github.com/SerenityOS/serenity/pull/14816 Reviewed-by: https://github.com/ADKaster Reviewed-by: https://github.com/linusg ✅
@@ -20,7 +20,7 @@ class WorkerEnvironmentSettingsObject final
|
||||
public:
|
||||
WorkerEnvironmentSettingsObject(DOM::Document& document, NonnullOwnPtr<JS::ExecutionContext> execution_context)
|
||||
: EnvironmentSettingsObject(move(execution_context))
|
||||
, m_document(document)
|
||||
, m_document(JS::make_handle(document))
|
||||
{
|
||||
}
|
||||
|
||||
@@ -37,14 +37,14 @@ public:
|
||||
|
||||
virtual ~WorkerEnvironmentSettingsObject() override = default;
|
||||
|
||||
RefPtr<DOM::Document> responsible_document() override { return m_document; }
|
||||
JS::GCPtr<DOM::Document> responsible_document() override { return m_document.ptr(); }
|
||||
String api_url_character_encoding() override { return m_document->encoding_or_default(); }
|
||||
AK::URL api_base_url() override { return m_document->url(); }
|
||||
Origin origin() override { return m_document->origin(); }
|
||||
CanUseCrossOriginIsolatedAPIs cross_origin_isolated_capability() override { TODO(); }
|
||||
|
||||
private:
|
||||
NonnullRefPtr<DOM::Document> m_document;
|
||||
JS::Handle<DOM::Document> m_document;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user