Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(193)

Unified Diff: content/browser/accessibility/frame_tree_accessibility.cc

Issue 252253002: Implement initial support for nesting one ax tree in another. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address feedback Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/accessibility/frame_tree_accessibility.cc
diff --git a/content/browser/accessibility/frame_tree_accessibility.cc b/content/browser/accessibility/frame_tree_accessibility.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e520cc36c78f55048a68c33b2d24627fe4e5fe5b
--- /dev/null
+++ b/content/browser/accessibility/frame_tree_accessibility.cc
@@ -0,0 +1,67 @@
+// Copyright (c) 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "content/browser/accessibility/frame_tree_accessibility.h"
+
+namespace content {
+
+const uint32 kNoFrameId = 0;
+
+FrameTreeAccessibility::FrameTreeAccessibility()
+ : next_id_(1) {
+}
+
+FrameTreeAccessibility::~FrameTreeAccessibility() {
+}
+
+FrameTreeAccessibility* FrameTreeAccessibility::GetInstance() {
+ return Singleton<FrameTreeAccessibility>::get();
+}
+
+void FrameTreeAccessibility::OnFrameCreated(
+ BrowserAccessibilityDelegate* frame) {
+ uint32 id = next_id_++;
+ frame_to_id_[frame] = id;
+ id_to_frame_[id] = frame;
+}
+
+void FrameTreeAccessibility::OnFrameDeleted(
+ BrowserAccessibilityDelegate* frame) {
+ if (frame_to_id_.find(frame) == frame_to_id_.end())
+ return;
+ uint32 id = frame_to_id_[frame];
+ frame_to_id_.erase(frame);
+ id_to_frame_.erase(id);
+ id_to_manager_.erase(id);
+}
+
+void FrameTreeAccessibility::SetFrameAccessibilityManager(
+ BrowserAccessibilityDelegate* frame,
+ BrowserAccessibilityManager* manager) {
+ if (frame_to_id_.find(frame) == frame_to_id_.end())
aboxhall 2014/05/06 15:41:27 How could this happen? Is it an error?
+ return;
+ uint32 id = frame_to_id_[frame];
+ id_to_manager_[id] = manager;
+}
+
+uint32 FrameTreeAccessibility::GetFrameId(BrowserAccessibilityDelegate* frame) {
+ if (frame_to_id_.find(frame) == frame_to_id_.end())
+ return kNoFrameId;
+ return frame_to_id_[frame];
+}
+
+BrowserAccessibilityDelegate* FrameTreeAccessibility::FindFrameById(uint32 id) {
+ if (id_to_frame_.find(id) == id_to_frame_.end())
+ return NULL;
+ return id_to_frame_[id];
+}
+
+BrowserAccessibilityManager*
+ FrameTreeAccessibility::FindAccessibilityManagerById(uint32 id) {
+ if (id_to_manager_.find(id) == id_to_manager_.end())
+ return NULL;
+ return id_to_manager_[id];
+}
+
+} // namespace content

Powered by Google App Engine
This is Rietveld 408576698