[webkit-changes] [WebKit/WebKit] 1a8243: AX: Grids/tables are not resilient to invalid Row-...
Joshua Hoffman
noreply at github.com
Thu Dec 21 22:17:13 PST 2023
Branch: refs/heads/main
Home: https://github.com/WebKit/WebKit
Commit: 1a8243f4e81e0c14d5d032cf42037eafea856b67
https://github.com/WebKit/WebKit/commit/1a8243f4e81e0c14d5d032cf42037eafea856b67
Author: Joshua Hoffman <jhoffman23 at apple.com>
Date: 2023-12-21 (Thu, 21 Dec 2023)
Changed paths:
A LayoutTests/accessibility/grid-row-authoring-error-ignored.html
A LayoutTests/platform/glib/accessibility/grid-row-authoring-error-ignored-expected.txt
A LayoutTests/platform/mac/accessibility/grid-row-authoring-error-ignored-expected.txt
M Source/WebCore/accessibility/AXCoreObject.h
M Source/WebCore/accessibility/AccessibilityObject.cpp
M Source/WebCore/accessibility/AccessibilityObject.h
M Source/WebCore/accessibility/AccessibilityRenderObject.cpp
Log Message:
-----------
AX: Grids/tables are not resilient to invalid Row->Cell hierarchy
https://bugs.webkit.org/show_bug.cgi?id=266680
rdar://118938262
Reviewed by Chris Fleizach.
Our AX tree structure for tables is not resilient for a common authoring error where
table rows are not the direct unignored parent of table cells. This markdown does
not follow the spec (https://www.w3.org/TR/wai-aria-1.1/#gridcell), but is used
by authors regardless. This has shown be the cause of missing content in a variety
of tables.
To be more resilient to these errors, this patch makes all objects that are between
cells and their parent rows ignored. A new test was added to verify this behavior.
* LayoutTests/accessibility/grid-row-authoring-error-ignored.html: Added.
* LayoutTests/platform/glib/accessibility/grid-row-authoring-error-ignored-expected.txt: Added.
* LayoutTests/platform/mac/accessibility/grid-row-authoring-error-ignored-expected.txt: Added.
* Source/WebCore/accessibility/AXCoreObject.h:
* Source/WebCore/accessibility/AccessibilityObject.cpp:
(WebCore::AccessibilityObject::computeAncestorFlags const):
(WebCore::AccessibilityObject::matchesAncestorFlag const):
(WebCore::AccessibilityObject::isInRow const):
(WebCore::AccessibilityObject::ignoredByRowAncestor const):
* Source/WebCore/accessibility/AccessibilityObject.h:
* Source/WebCore/accessibility/AccessibilityRenderObject.cpp:
(WebCore::AccessibilityRenderObject::computeAccessibilityIsIgnored const):
Canonical link: https://commits.webkit.org/272447@main
More information about the webkit-changes
mailing list