mirror of
https://github.com/servo/servo.git
synced 2025-09-30 00:29:14 +01:00
Implement shadow dom slots (#35013)
* Implement slot-related algorithms Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Hook up slot elements to DOM creation logic Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Set a slot assignment mode for servo-internal shadow roots Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Assign slots when a slottable's slot attribute changes Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Properly compute slot name Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * ./mach test-tidy Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Update <slot> name when name attribute changes Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Implement fast path for Node::assign_slottables_for_a_tree assign_slottables_for_a_tree traverses all descendants of the node and is potentially very expensive. If the node is not a shadow root then assigning slottables to it won't have any effect, so we take a fast path out. Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Move slottable data into ElementRareData This shrinks all element descendants back to their original size. Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Address review comments Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> * Update WPT expectations Signed-off-by: Simon Wülker <simon.wuelker@arcor.de> --------- Signed-off-by: Simon Wülker <simon.wuelker@arcor.de>
This commit is contained in:
parent
8bb50fa3c9
commit
dabe162d44
31 changed files with 758 additions and 355 deletions
|
@ -13,6 +13,3 @@
|
|||
|
||||
[param element's name property reflects its content attribute]
|
||||
expected: FAIL
|
||||
|
||||
[slot element's name property reflects its content attribute]
|
||||
expected: FAIL
|
||||
|
|
|
@ -7858,63 +7858,6 @@
|
|||
[HTMLTemplateElement interface: document.createElement("template") must inherit property "shadowRootSerializable" with the proper type]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: existence and properties of interface object]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface object length]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface object name]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: existence and properties of interface prototype object]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: existence and properties of interface prototype object's "constructor" property]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: existence and properties of interface prototype object's @@unscopables property]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: attribute name]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: operation assignedNodes(optional AssignedNodesOptions)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: operation assignedElements(optional AssignedNodesOptions)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: operation assign((Element or Text)...)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement must be primary interface of document.createElement("slot")]
|
||||
expected: FAIL
|
||||
|
||||
[Stringification of document.createElement("slot")]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: document.createElement("slot") must inherit property "name" with the proper type]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: document.createElement("slot") must inherit property "assignedNodes(optional AssignedNodesOptions)" with the proper type]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: calling assignedNodes(optional AssignedNodesOptions) on document.createElement("slot") with too few arguments must throw TypeError]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: document.createElement("slot") must inherit property "assignedElements(optional AssignedNodesOptions)" with the proper type]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: calling assignedElements(optional AssignedNodesOptions) on document.createElement("slot") with too few arguments must throw TypeError]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: document.createElement("slot") must inherit property "assign((Element or Text)...)" with the proper type]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLSlotElement interface: calling assign((Element or Text)...) on document.createElement("slot") with too few arguments must throw TypeError]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLMarqueeElement interface: existence and properties of interface object]
|
||||
expected: FAIL
|
||||
|
||||
|
|
114
tests/wpt/meta/html/dom/reflection-misc.html.ini
vendored
114
tests/wpt/meta/html/dom/reflection-misc.html.ini
vendored
|
@ -1073,120 +1073,6 @@
|
|||
[slot.tabIndex: IDL set to -2147483648]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL get with DOM attribute unset]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to ""]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo "]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to undefined]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to 7]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to 1.5]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to "5%"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to "+100"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to ".5"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to true]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to false]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to object "[object Object\]"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to NaN]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to Infinity]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to -Infinity]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to "\\0"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to null]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to object "test-toString"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: setAttribute() to object "test-valueOf"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to ""]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo "]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to undefined]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to 7]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to 1.5]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to "5%"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to "+100"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to ".5"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to true]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to false]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to object "[object Object\]"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to NaN]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to Infinity]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to -Infinity]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to "\\0"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to null]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to object "test-toString"]
|
||||
expected: FAIL
|
||||
|
||||
[slot.name: IDL set to object "test-valueOf"]
|
||||
expected: FAIL
|
||||
|
||||
[ins.accessKey: typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
|
|
|
@ -53,15 +53,6 @@
|
|||
[Interfaces for RTC: createElement]
|
||||
expected: FAIL
|
||||
|
||||
[Interfaces for slot: useNS]
|
||||
expected: FAIL
|
||||
|
||||
[Interfaces for slot: useParser]
|
||||
expected: FAIL
|
||||
|
||||
[Interfaces for SLOT: createElement]
|
||||
expected: FAIL
|
||||
|
||||
[Interfaces for permission: useNS]
|
||||
expected: FAIL
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue