| Index: content/browser/accessibility/browser_accessibility_manager_android.cc
|
| diff --git a/content/browser/accessibility/browser_accessibility_manager_android.cc b/content/browser/accessibility/browser_accessibility_manager_android.cc
|
| index 1f6e3d67e8806837df9a1fd3b25cb18a9957cb11..ca9de7db38ad60335952601a4b5b1c1b01ed414a 100644
|
| --- a/content/browser/accessibility/browser_accessibility_manager_android.cc
|
| +++ b/content/browser/accessibility/browser_accessibility_manager_android.cc
|
| @@ -206,9 +206,6 @@ void BrowserAccessibilityManagerAndroid::NotifyAccessibilityEvent(
|
| if (obj.is_null())
|
| return;
|
|
|
| - BrowserAccessibilityAndroid* android_node =
|
| - static_cast<BrowserAccessibilityAndroid*>(node);
|
| -
|
| if (event_type == ui::AX_EVENT_HIDE)
|
| return;
|
|
|
| @@ -225,6 +222,16 @@ void BrowserAccessibilityManagerAndroid::NotifyAccessibilityEvent(
|
| return;
|
| }
|
|
|
| + // Sometimes we get events on nodes in our internal accessibility tree
|
| + // that aren't exposed on Android. Walk up the ancestors and update |node|
|
| + // to point to the highest ancestor that's a leaf node.
|
| + BrowserAccessibility* parent = node->GetParent();
|
| + while (parent) {
|
| + if (parent->PlatformChildCount() == 0)
|
| + node = parent;
|
| + parent = parent->GetParent();
|
| + }
|
| +
|
| // Always send AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED to notify
|
| // the Android system that the accessibility hierarchy rooted at this
|
| // node has changed.
|
| @@ -237,6 +244,8 @@ void BrowserAccessibilityManagerAndroid::NotifyAccessibilityEvent(
|
| return;
|
| }
|
|
|
| + BrowserAccessibilityAndroid* android_node =
|
| + static_cast<BrowserAccessibilityAndroid*>(node);
|
| switch (event_type) {
|
| case ui::AX_EVENT_LOAD_COMPLETE:
|
| Java_BrowserAccessibilityManager_handlePageLoaded(
|
|
|