mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-09-20 17:58:18 +03:00
LibWeb: Update WindowProxy::internal_get_own_property
for navigables
This commit is contained in:
parent
d45f2a4952
commit
dd9eca254e
Notes:
sideshowbarker
2024-07-17 01:13:25 +09:00
Author: https://github.com/kalenikaliaksandr Commit: https://github.com/SerenityOS/serenity/commit/dd9eca254e Pull-request: https://github.com/SerenityOS/serenity/pull/18219
@ -72,20 +72,19 @@ JS::ThrowCompletionOr<Optional<JS::PropertyDescriptor>> WindowProxy::internal_ge
|
||||
// 1. Let index be ! ToUint32(P).
|
||||
auto index = property_key.as_number();
|
||||
|
||||
// 2. Let maxProperties be the number of document-tree child browsing contexts of W.
|
||||
auto max_properties = m_window->document_tree_child_browsing_context_count();
|
||||
// 2. Let children be the document-tree child navigables of W's associated Document.
|
||||
auto children = m_window->associated_document().document_tree_child_navigables();
|
||||
|
||||
// 3. Let value be undefined.
|
||||
Optional<JS::Value> value;
|
||||
|
||||
// 4. If maxProperties is greater than 0 and index is less than maxProperties, then set value to the WindowProxy object of the indexth document-tree child browsing context of W's browsing context, sorted in the order that their browsing context container elements were most recently inserted into W's associated Document, the WindowProxy object of the most recently inserted browsing context container's nested browsing context being last.
|
||||
if (max_properties > 0 && index < max_properties) {
|
||||
JS::MarkedVector<BrowsingContext*> browsing_contexts { vm.heap() };
|
||||
m_window->browsing_context()->for_each_child([&](BrowsingContext& child) {
|
||||
if (child.container() && child.container()->in_a_document_tree())
|
||||
browsing_contexts.append(&child);
|
||||
});
|
||||
value = JS::Value(browsing_contexts[index]->window_proxy());
|
||||
// 4. If index is less than children's size, then:
|
||||
if (index < children.size()) {
|
||||
// 1. Sort children in ascending order, with navigableA being less than navigableB if navigableA's container was inserted into W's associated Document earlier than navigableB's container was.
|
||||
// NOTE: children are coming sorted in required order from document_tree_child_navigables()
|
||||
|
||||
// 2. Set value to children[index]'s active WindowProxy.
|
||||
value = children[index]->active_window_proxy();
|
||||
}
|
||||
|
||||
// 5. If value is undefined, then:
|
||||
|
Loading…
Reference in New Issue
Block a user