
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).
32 lines
1 KiB
C++
32 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2021-2023, Linus Groh <linusg@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibJS/Contrib/Test262/IsHTMLDDA.h>
|
|
#include <LibJS/Runtime/GlobalObject.h>
|
|
|
|
namespace JS::Test262 {
|
|
|
|
IsHTMLDDA::IsHTMLDDA(Realm& realm)
|
|
// NativeFunction without prototype is currently not possible (only due to the lack of a ctor that supports it)
|
|
: NativeFunction("IsHTMLDDA", realm.intrinsics().function_prototype())
|
|
{
|
|
}
|
|
|
|
ThrowCompletionOr<Value> IsHTMLDDA::call()
|
|
{
|
|
auto& vm = this->vm();
|
|
if (vm.argument_count() == 0)
|
|
return js_null();
|
|
if (vm.argument(0).is_string() && TRY(vm.argument(0).as_string().deprecated_string()).is_empty())
|
|
return js_null();
|
|
// Not sure if this really matters, INTERPRETING.md simply says:
|
|
// * IsHTMLDDA - (present only in implementations that can provide it) an object that:
|
|
// a. has an [[IsHTMLDDA]] internal slot, and
|
|
// b. when called with no arguments or with the first argument "" (an empty string) returns null.
|
|
return js_undefined();
|
|
}
|
|
|
|
}
|