summaryrefslogtreecommitdiffstats
path: root/webkit/glue
diff options
context:
space:
mode:
authordmazzoni@chromium.org <dmazzoni@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-08 19:26:24 +0000
committerdmazzoni@chromium.org <dmazzoni@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-08 19:26:24 +0000
commit8368e3c097978a1424e13786efceead3ffc6c385 (patch)
tree388a0a7d01f15a992a097ec92bad7727f17a9f92 /webkit/glue
parentf74252d3754d1d58b6f97cb3cd89b47d151cd88d (diff)
downloadchromium_src-8368e3c097978a1424e13786efceead3ffc6c385.zip
chromium_src-8368e3c097978a1424e13786efceead3ffc6c385.tar.gz
chromium_src-8368e3c097978a1424e13786efceead3ffc6c385.tar.bz2
Browser accessibility improvements so that screen readers can access more
complicated webpages without problems. First, WebAccessibility now works around a "multiple inheritance problem" in WebCore::AccessibilityObject where the same node appears as a child of multiple parents. For example, a table cell appears as a child of both a row and a column. This is solved by having each WebAccessibility parent check whether the child lists itself as an ancestor. If not, it notes the child's id only in a separate vector, so each child appears fully only once. Second, BrowserAccessibility now has internal reference counting, which allows BrowserAccessibilityManager to update any subtree while maximally reusing as many objects as possible. This fixes many screen reader interaction problems! All of this new functionality is tested with new cross-platform tests. BUG=67192 BUG=67620 TEST=Adds new unit tests and a browser test. Review URL: http://codereview.chromium.org/6625042 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@77316 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue')
-rw-r--r--webkit/glue/webaccessibility.cc30
-rw-r--r--webkit/glue/webaccessibility.h7
2 files changed, 28 insertions, 9 deletions
diff --git a/webkit/glue/webaccessibility.cc b/webkit/glue/webaccessibility.cc
index f6df3b2..48cc339 100644
--- a/webkit/glue/webaccessibility.cc
+++ b/webkit/glue/webaccessibility.cc
@@ -380,12 +380,6 @@ void WebAccessibility::Init(const WebKit::WebAccessibilityObject& src,
// Add the source object to the cache and store its id.
id = cache->addOrGetId(src);
- if (role == WebAccessibility::ROLE_EDITABLE_TEXT ||
- role == WebAccessibility::ROLE_TEXTAREA ||
- role == WebAccessibility::ROLE_TEXT_FIELD) {
- include_children = false;
- }
-
if (include_children) {
// Recursively create children.
int child_count = src.childCount();
@@ -393,13 +387,33 @@ void WebAccessibility::Init(const WebKit::WebAccessibilityObject& src,
WebAccessibilityObject child = src.childAt(i);
// The child may be invalid due to issues in webkit accessibility code.
- // Don't add children are invalid thus preventing a crash.
+ // Don't add children that are invalid thus preventing a crash.
// https://bugs.webkit.org/show_bug.cgi?id=44149
// TODO(ctguil): We may want to remove this check as webkit stabilizes.
- if (child.isValid())
+ if (!child.isValid())
+ continue;
+
+ // Some nodes appear in the tree in more than one place: for example,
+ // a cell in a table appears as a child of both a row and a column.
+ // Only recursively add child nodes that have this node as one of its
+ // ancestors. For child nodes that are actually parented to something
+ // else, store only the ID.
+ if (IsAncestorOf(src, child)) {
children.push_back(WebAccessibility(child, cache, include_children));
+ } else {
+ indirect_child_ids.push_back(cache->addOrGetId(child));
+ }
}
}
}
+bool WebAccessibility::IsAncestorOf(
+ const WebKit::WebAccessibilityObject& ancestor,
+ const WebKit::WebAccessibilityObject& child) {
+ WebKit::WebAccessibilityObject parent = child.parentObject();
+ while (!parent.isNull() && !parent.equals(ancestor))
+ parent = parent.parentObject();
+ return parent.equals(ancestor);
+}
+
} // namespace webkit_glue
diff --git a/webkit/glue/webaccessibility.h b/webkit/glue/webaccessibility.h
index 081d156..b67ce83 100644
--- a/webkit/glue/webaccessibility.h
+++ b/webkit/glue/webaccessibility.h
@@ -193,11 +193,15 @@ struct WebAccessibility {
~WebAccessibility();
private:
- // Initialize an already-created struct, same as the constructor a
+ // Initialize an already-created struct, same as the constructor above.
void Init(const WebKit::WebAccessibilityObject& src,
WebKit::WebAccessibilityCache* cache,
bool include_children);
+ // Returns true if |ancestor| is an ancestor of |child|.
+ bool IsAncestorOf(const WebKit::WebAccessibilityObject& ancestor,
+ const WebKit::WebAccessibilityObject& child);
+
public:
// This is a simple serializable struct. All member variables should be
// copyable.
@@ -209,6 +213,7 @@ struct WebAccessibility {
WebKit::WebRect location;
std::map<int32, string16> attributes;
std::vector<WebAccessibility> children;
+ std::vector<int32> indirect_child_ids;
std::vector<std::pair<string16, string16> > html_attributes;
};