OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/extensions/api/automation_internal/automation_event_rou
ter.h" | 5 #include "chrome/browser/extensions/api/automation_internal/automation_event_rou
ter.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 void AutomationEventRouter::DispatchAccessibilityEvent( | 55 void AutomationEventRouter::DispatchAccessibilityEvent( |
56 const ExtensionMsg_AccessibilityEventParams& params) { | 56 const ExtensionMsg_AccessibilityEventParams& params) { |
57 for (const auto& listener : listeners_) { | 57 for (const auto& listener : listeners_) { |
58 if (!listener.desktop && | 58 if (!listener.desktop && |
59 listener.tree_ids.find(params.tree_id) == listener.tree_ids.end()) { | 59 listener.tree_ids.find(params.tree_id) == listener.tree_ids.end()) { |
60 continue; | 60 continue; |
61 } | 61 } |
62 | 62 |
63 content::RenderProcessHost* rph = | 63 content::RenderProcessHost* rph = |
64 content::RenderProcessHost::FromID(listener.process_id); | 64 content::RenderProcessHost::FromID(listener.process_id); |
65 rph->Send(new ExtensionMsg_AccessibilityEvent(listener.routing_id, params)); | 65 rph->Send(new ExtensionMsg_AccessibilityEvent(listener.routing_id, |
| 66 params)); |
66 } | 67 } |
67 } | 68 } |
68 | 69 |
69 void AutomationEventRouter::DispatchTreeDestroyedEvent( | 70 void AutomationEventRouter::DispatchTreeDestroyedEvent( |
70 int tree_id, | 71 int tree_id, |
71 content::BrowserContext* browser_context) { | 72 content::BrowserContext* browser_context) { |
72 scoped_ptr<base::ListValue> args( | 73 scoped_ptr<base::ListValue> args( |
73 api::automation_internal::OnAccessibilityTreeDestroyed::Create(tree_id)); | 74 api::automation_internal::OnAccessibilityTreeDestroyed::Create(tree_id)); |
74 scoped_ptr<Event> event(new Event( | 75 scoped_ptr<Event> event(new Event( |
75 events::AUTOMATION_INTERNAL_ON_ACCESSIBILITY_TREE_DESTROYED, | 76 events::AUTOMATION_INTERNAL_ON_ACCESSIBILITY_TREE_DESTROYED, |
(...skipping 10 matching lines...) Expand all Loading... |
86 } | 87 } |
87 | 88 |
88 void AutomationEventRouter::Register( | 89 void AutomationEventRouter::Register( |
89 int listener_process_id, | 90 int listener_process_id, |
90 int listener_routing_id, | 91 int listener_routing_id, |
91 int ax_tree_id, | 92 int ax_tree_id, |
92 bool desktop) { | 93 bool desktop) { |
93 auto iter = std::find_if( | 94 auto iter = std::find_if( |
94 listeners_.begin(), | 95 listeners_.begin(), |
95 listeners_.end(), | 96 listeners_.end(), |
96 [listener_process_id, listener_routing_id](AutomationListener& item) { | 97 [listener_process_id, listener_routing_id]( |
| 98 const AutomationListener& item) { |
97 return (item.process_id == listener_process_id && | 99 return (item.process_id == listener_process_id && |
98 item.routing_id == listener_routing_id); | 100 item.routing_id == listener_routing_id); |
99 }); | 101 }); |
100 | 102 |
101 // Add a new entry if we don't have one with that process and routing id. | 103 // Add a new entry if we don't have one with that process and routing id. |
102 if (iter == listeners_.end()) { | 104 if (iter == listeners_.end()) { |
103 AutomationListener listener; | 105 AutomationListener listener; |
104 listener.routing_id = listener_routing_id; | 106 listener.routing_id = listener_routing_id; |
105 listener.process_id = listener_process_id; | 107 listener.process_id = listener_process_id; |
106 listener.desktop = desktop; | 108 listener.desktop = desktop; |
(...skipping 18 matching lines...) Expand all Loading... |
125 NOTREACHED(); | 127 NOTREACHED(); |
126 return; | 128 return; |
127 } | 129 } |
128 | 130 |
129 content::RenderProcessHost* rph = | 131 content::RenderProcessHost* rph = |
130 content::Source<content::RenderProcessHost>(source).ptr(); | 132 content::Source<content::RenderProcessHost>(source).ptr(); |
131 int process_id = rph->GetID(); | 133 int process_id = rph->GetID(); |
132 std::remove_if( | 134 std::remove_if( |
133 listeners_.begin(), | 135 listeners_.begin(), |
134 listeners_.end(), | 136 listeners_.end(), |
135 [process_id](AutomationListener& item) { | 137 [process_id](const AutomationListener& item) { |
136 return item.process_id = process_id; | 138 return item.process_id == process_id; |
137 }); | 139 }); |
138 } | 140 } |
139 | 141 |
140 } // namespace extensions | 142 } // namespace extensions |
OLD | NEW |