LibWeb: Introduce the Environment Settings Object

The environment settings object is effectively the context a piece of
script is running under, for example, it contains the origin,
responsible document, realm, global object and event loop for the
current context. This effectively replaces ScriptExecutionContext, but
it cannot be removed in this commit as EventTarget still depends on it.

https://html.spec.whatwg.org/multipage/webappapis.html#environment-settings-object
This commit is contained in:
Luke Wilde 2021-10-14 16:12:53 +01:00 committed by Linus Groh
parent 4db5406d62
commit f71f404e0c
Notes: sideshowbarker 2024-07-17 19:09:28 +09:00
29 changed files with 883 additions and 86 deletions

View file

@ -7,6 +7,7 @@
#pragma once
#include <LibJS/Script.h>
#include <LibWeb/Forward.h>
#include <LibWeb/HTML/Scripting/Script.h>
namespace Web::HTML {
@ -20,22 +21,26 @@ public:
No,
Yes,
};
static NonnullRefPtr<ClassicScript> create(String filename, StringView source, JS::Realm&, AK::URL base_url, MutedErrors = MutedErrors::No);
static NonnullRefPtr<ClassicScript> create(String filename, StringView source, EnvironmentSettingsObject&, AK::URL base_url, MutedErrors = MutedErrors::No);
JS::Script* script_record() { return m_script_record; }
JS::Script const* script_record() const { return m_script_record; }
EnvironmentSettingsObject& settings_object() { return m_settings_object; }
enum class RethrowErrors {
No,
Yes,
};
JS::Value run(RethrowErrors = RethrowErrors::No);
JS::Completion run(RethrowErrors = RethrowErrors::No);
private:
ClassicScript(AK::URL base_url, String filename);
ClassicScript(AK::URL base_url, String filename, EnvironmentSettingsObject& environment_settings_object);
EnvironmentSettingsObject& m_settings_object;
RefPtr<JS::Script> m_script_record;
MutedErrors m_muted_errors { MutedErrors::No };
Optional<JS::Parser::Error> m_error_to_rethrow;
};
}