summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp
diff options
context:
space:
mode:
authorLinus Groh <mail@linusgroh.de>2023-04-13 00:47:15 +0200
committerLinus Groh <mail@linusgroh.de>2023-04-13 14:29:42 +0200
commitb84f8fb55b2f926970af1d657314bb82a905ae1d (patch)
treebef32f893a3077f71b29e955fbf036602e6e83e5 /Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp
parented9e2366da6a28ad39bf6f71d70201d59fa79220 (diff)
downloadserenity-b84f8fb55b2f926970af1d657314bb82a905ae1d.zip
LibJS: Make intrinsics getters return NonnullGCPtr
Some of these are allocated upon initialization of the intrinsics, and some lazily, but in neither case the getters actually return a nullptr. This saves us a whole bunch of pointer dereferences (as NonnullGCPtr has an `operator T&()`), and also has the interesting side effect of forcing us to explicitly use the FunctionObject& overload of call(), as passing a NonnullGCPtr is ambigous - it could implicitly be turned into a Value _or_ a FunctionObject& (so we have to dereference manually).
Diffstat (limited to 'Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp')
-rw-r--r--Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp b/Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp
index 0361c7be25..ec1bb716c8 100644
--- a/Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp
+++ b/Userland/Libraries/LibWeb/WebDriver/ExecuteScript.cpp
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
+ * Copyright (c) 2022-2023, Linus Groh <linusg@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
@@ -362,7 +362,7 @@ ExecuteScriptResultSerialized execute_async_script(Web::Page& page, DeprecatedSt
return ExecuteScriptResult { ExecuteScriptResultType::PromiseResolved, JS::js_null() };
// 9. Let scriptPromise be PromiseResolve(Promise, scriptResult.[[Value]]).
- auto script_promise_or_error = JS::promise_resolve(vm, *realm.intrinsics().promise_constructor(), script_result.value());
+ auto script_promise_or_error = JS::promise_resolve(vm, realm.intrinsics().promise_constructor(), script_result.value());
if (script_promise_or_error.is_throw_completion())
return ExecuteScriptResult { ExecuteScriptResultType::PromiseRejected, *script_promise_or_error.throw_completion().value() };
auto& script_promise = static_cast<JS::Promise&>(*script_promise_or_error.value());