Skip to content

Commit

Permalink
LibWeb/Bindings: Define constructor properties in the correct order
Browse files Browse the repository at this point in the history
  • Loading branch information
shannonbooth authored and pbrw committed Jan 14, 2025
1 parent 26a6777 commit bf46608
Show file tree
Hide file tree
Showing 8 changed files with 56 additions and 9 deletions.
3 changes: 2 additions & 1 deletion Libraries/LibWeb/Bindings/AudioConstructor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,9 @@ void AudioConstructor::initialize(JS::Realm& realm)
auto& vm = this->vm();
Base::initialize(realm);

define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLAudioElementPrototype>(realm, "HTMLAudioElement"_fly_string), 0);
define_direct_property(vm.names.length, JS::Value(0), JS::Attribute::Configurable);
define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "Audio"_string), JS::Attribute::Configurable);
define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLAudioElementPrototype>(realm, "HTMLAudioElement"_fly_string), 0);
}

JS::ThrowCompletionOr<JS::Value> AudioConstructor::call()
Expand Down
3 changes: 2 additions & 1 deletion Libraries/LibWeb/Bindings/ImageConstructor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,9 @@ void ImageConstructor::initialize(JS::Realm& realm)
auto& vm = this->vm();
Base::initialize(realm);

define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLImageElementPrototype>(realm, "HTMLImageElement"_fly_string), 0);
define_direct_property(vm.names.length, JS::Value(0), JS::Attribute::Configurable);
define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "Image"_string), JS::Attribute::Configurable);
define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLImageElementPrototype>(realm, "HTMLImageElement"_fly_string), 0);
}

JS::ThrowCompletionOr<JS::Value> ImageConstructor::call()
Expand Down
3 changes: 2 additions & 1 deletion Libraries/LibWeb/Bindings/OptionConstructor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,9 @@ void OptionConstructor::initialize(JS::Realm& realm)
auto& vm = this->vm();
Base::initialize(realm);

define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLOptionElementPrototype>(realm, "HTMLOptionElement"_fly_string), 0);
define_direct_property(vm.names.length, JS::Value(0), JS::Attribute::Configurable);
define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "Option"_string), JS::Attribute::Configurable);
define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLOptionElementPrototype>(realm, "HTMLOptionElement"_fly_string), 0);
}

JS::ThrowCompletionOr<JS::Value> OptionConstructor::call()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* Copyright (c) 2021-2023, Luke Wilde <[email protected]>
* Copyright (c) 2022, Ali Mohammad Pur <[email protected]>
* Copyright (c) 2023-2024, Kenneth Myhra <[email protected]>
* Copyright (c) 2023-2024, Shannon Booth <[email protected]>
* Copyright (c) 2023-2025, Shannon Booth <[email protected]>
* Copyright (c) 2023-2024, Matthew Olsson <[email protected]>
*
* SPDX-License-Identifier: BSD-2-Clause
Expand Down Expand Up @@ -4753,8 +4753,9 @@ void @constructor_class@::initialize(JS::Realm& realm)
}

generator.append(R"~~~(
define_direct_property(vm.names.prototype, &ensure_web_prototype<@prototype_class@>(realm, "@namespaced_name@"_fly_string), 0);
define_direct_property(vm.names.length, JS::Value(@constructor.length@), JS::Attribute::Configurable);
define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "@namespaced_name@"_string), JS::Attribute::Configurable);
define_direct_property(vm.names.prototype, &ensure_web_prototype<@prototype_class@>(realm, "@namespaced_name@"_fly_string), 0);
)~~~");

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -152,17 +152,14 @@ void Intrinsics::create_web_prototype_and_constructor<@prototype_class@>(JS::Rea
m_constructors.set("@interface_name@"_fly_string, constructor);
prototype->define_direct_property(vm.names.constructor, constructor.ptr(), JS::Attribute::Writable | JS::Attribute::Configurable);
constructor->define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "@interface_name@"_string), JS::Attribute::Configurable);
)~~~");

if (legacy_constructor.has_value()) {
gen.set("legacy_interface_name", legacy_constructor->name);
gen.set("legacy_constructor_class", legacy_constructor->constructor_class);
gen.append(R"~~~(
auto legacy_constructor = realm.create<@legacy_constructor_class@>(realm);
m_constructors.set("@legacy_interface_name@"_fly_string, legacy_constructor);
legacy_constructor->define_direct_property(vm.names.name, JS::PrimitiveString::create(vm, "@legacy_interface_name@"_string), JS::Attribute::Configurable);)~~~");
m_constructors.set("@legacy_interface_name@"_fly_string, legacy_constructor);)~~~");
}

gen.append(R"~~~(
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
Harness status: OK

Found 3 tests

3 Pass
Pass Constructor property enumeration order of "length", "name", and "prototype"
Pass Method property enumeration order of "length" and "name"
Pass Getter property enumeration order of "length" and "name"
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
<!doctype html>
<meta charset=utf-8>

<script>
self.GLOBAL = {
isWindow: function() { return true; },
isWorker: function() { return false; },
isShadowRealm: function() { return false; },
};
</script>
<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>

<div id=log></div>
<script src="../../webidl/ecmascript-binding/builtin-function-properties.any.js"></script>
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
"use strict";

test(() => {
const ownPropKeys = Reflect.ownKeys(Blob).slice(0, 3);
assert_array_equals(ownPropKeys, ["length", "name", "prototype"]);
}, 'Constructor property enumeration order of "length", "name", and "prototype"');

test(() => {
assert_own_property(Blob.prototype, "slice");

const ownPropKeys = Reflect.ownKeys(Blob.prototype.slice).slice(0, 2);
assert_array_equals(ownPropKeys, ["length", "name"]);
}, 'Method property enumeration order of "length" and "name"');

test(() => {
assert_own_property(Blob.prototype, "size");

const desc = Reflect.getOwnPropertyDescriptor(Blob.prototype, "size");
assert_equals(typeof desc.get, "function");

const ownPropKeys = Reflect.ownKeys(desc.get).slice(0, 2);
assert_array_equals(ownPropKeys, ["length", "name"]);
}, 'Getter property enumeration order of "length" and "name"');

0 comments on commit bf46608

Please sign in to comment.