| 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 |