OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/speech/chrome_speech_recognition_manager_delegate.h" | 5 #include "chrome/browser/speech/chrome_speech_recognition_manager_delegate.h" |
6 | 6 |
| 7 #include <memory> |
7 #include <set> | 8 #include <set> |
8 #include <string> | 9 #include <string> |
| 10 #include <vector> |
9 | 11 |
10 #include "base/bind.h" | 12 #include "base/bind.h" |
11 #include "base/macros.h" | 13 #include "base/macros.h" |
| 14 #include "base/memory/ptr_util.h" |
12 #include "base/strings/utf_string_conversions.h" | 15 #include "base/strings/utf_string_conversions.h" |
13 #include "base/synchronization/lock.h" | 16 #include "base/synchronization/lock.h" |
14 #include "base/threading/thread_restrictions.h" | 17 #include "base/threading/thread_restrictions.h" |
15 #include "build/build_config.h" | 18 #include "build/build_config.h" |
16 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 19 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
17 #include "chrome/browser/profiles/profile_manager.h" | 20 #include "chrome/browser/profiles/profile_manager.h" |
18 #include "chrome/browser/tab_contents/tab_util.h" | 21 #include "chrome/browser/tab_contents/tab_util.h" |
19 #include "chrome/common/pref_names.h" | 22 #include "chrome/common/pref_names.h" |
20 #include "chrome/common/url_constants.h" | 23 #include "chrome/common/url_constants.h" |
21 #include "components/prefs/pref_service.h" | 24 #include "components/prefs/pref_service.h" |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
98 // extension using the (new) speech JS APIs, will be properly handled here. | 101 // extension using the (new) speech JS APIs, will be properly handled here. |
99 // TODO(primiano) turn this line into a DCHECK once speech input extension | 102 // TODO(primiano) turn this line into a DCHECK once speech input extension |
100 // API is deprecated. | 103 // API is deprecated. |
101 if (!web_contents) | 104 if (!web_contents) |
102 return; | 105 return; |
103 | 106 |
104 // Avoid multiple registrations for the same |web_contents|. | 107 // Avoid multiple registrations for the same |web_contents|. |
105 if (FindWebContents(web_contents) != registered_web_contents_.end()) | 108 if (FindWebContents(web_contents) != registered_web_contents_.end()) |
106 return; | 109 return; |
107 | 110 |
108 registered_web_contents_.push_back(new WebContentsTracker( | 111 registered_web_contents_.push_back(base::MakeUnique<WebContentsTracker>( |
109 web_contents, base::Bind(&TabWatcher::OnTabClosed, | 112 web_contents, |
110 // |this| outlives WebContentsTracker. | 113 base::Bind(&TabWatcher::OnTabClosed, |
111 base::Unretained(this), web_contents), | 114 // |this| outlives WebContentsTracker. |
| 115 base::Unretained(this), web_contents), |
112 render_process_id, render_view_id)); | 116 render_process_id, render_view_id)); |
113 } | 117 } |
114 | 118 |
115 void OnTabClosed(content::WebContents* web_contents) { | 119 void OnTabClosed(content::WebContents* web_contents) { |
116 ScopedVector<WebContentsTracker>::iterator iter = | 120 auto iter = FindWebContents(web_contents); |
117 FindWebContents(web_contents); | |
118 DCHECK(iter != registered_web_contents_.end()); | 121 DCHECK(iter != registered_web_contents_.end()); |
119 int render_process_id = (*iter)->render_process_id(); | 122 int render_process_id = (*iter)->render_process_id(); |
120 int render_view_id = (*iter)->render_view_id(); | 123 int render_view_id = (*iter)->render_view_id(); |
121 registered_web_contents_.erase(iter); | 124 registered_web_contents_.erase(iter); |
122 | 125 |
123 tab_closed_callback_.Run(render_process_id, render_view_id); | 126 tab_closed_callback_.Run(render_process_id, render_view_id); |
124 } | 127 } |
125 | 128 |
126 private: | 129 private: |
127 class WebContentsTracker : public content::WebContentsObserver { | 130 class WebContentsTracker : public content::WebContentsObserver { |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
171 friend class base::RefCountedThreadSafe<TabWatcher>; | 174 friend class base::RefCountedThreadSafe<TabWatcher>; |
172 | 175 |
173 ~TabWatcher() { | 176 ~TabWatcher() { |
174 // Must be destroyed on the UI thread due to |registrar_| non thread-safety. | 177 // Must be destroyed on the UI thread due to |registrar_| non thread-safety. |
175 // TODO(lazyboy): Do we still need this? | 178 // TODO(lazyboy): Do we still need this? |
176 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 179 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
177 } | 180 } |
178 | 181 |
179 // Helper function to find the iterator in |registered_web_contents_| which | 182 // Helper function to find the iterator in |registered_web_contents_| which |
180 // contains |web_contents|. | 183 // contains |web_contents|. |
181 ScopedVector<WebContentsTracker>::iterator FindWebContents( | 184 std::vector<std::unique_ptr<WebContentsTracker>>::iterator FindWebContents( |
182 content::WebContents* web_contents) { | 185 content::WebContents* web_contents) { |
183 for (ScopedVector<WebContentsTracker>::iterator i( | 186 for (auto i = registered_web_contents_.begin(); |
184 registered_web_contents_.begin()); | |
185 i != registered_web_contents_.end(); ++i) { | 187 i != registered_web_contents_.end(); ++i) { |
186 if ((*i)->GetWebContents() == web_contents) | 188 if ((*i)->GetWebContents() == web_contents) |
187 return i; | 189 return i; |
188 } | 190 } |
189 | 191 |
190 return registered_web_contents_.end(); | 192 return registered_web_contents_.end(); |
191 } | 193 } |
192 | 194 |
193 // Keeps track of which WebContent(s) have been registered, in order to avoid | 195 // Keeps track of which WebContent(s) have been registered, in order to avoid |
194 // double registrations on WebContentsObserver and to pass the correct render | 196 // double registrations on WebContentsObserver and to pass the correct render |
195 // process id and render view id to |tab_closed_callback_| after the process | 197 // process id and render view id to |tab_closed_callback_| after the process |
196 // has gone away. | 198 // has gone away. |
197 ScopedVector<WebContentsTracker> registered_web_contents_; | 199 std::vector<std::unique_ptr<WebContentsTracker>> registered_web_contents_; |
198 | 200 |
199 // Callback used to notify, on the thread specified by |callback_thread_| the | 201 // Callback used to notify, on the thread specified by |callback_thread_| the |
200 // closure of a registered tab. | 202 // closure of a registered tab. |
201 TabClosedCallback tab_closed_callback_; | 203 TabClosedCallback tab_closed_callback_; |
202 | 204 |
203 DISALLOW_COPY_AND_ASSIGN(TabWatcher); | 205 DISALLOW_COPY_AND_ASSIGN(TabWatcher); |
204 }; | 206 }; |
205 | 207 |
206 ChromeSpeechRecognitionManagerDelegate | 208 ChromeSpeechRecognitionManagerDelegate |
207 ::ChromeSpeechRecognitionManagerDelegate() { | 209 ::ChromeSpeechRecognitionManagerDelegate() { |
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
353 // Otherwise this should be a regular tab contents. | 355 // Otherwise this should be a regular tab contents. |
354 allowed = true; | 356 allowed = true; |
355 check_permission = true; | 357 check_permission = true; |
356 #endif | 358 #endif |
357 | 359 |
358 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, | 360 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
359 base::Bind(callback, check_permission, allowed)); | 361 base::Bind(callback, check_permission, allowed)); |
360 } | 362 } |
361 | 363 |
362 } // namespace speech | 364 } // namespace speech |
OLD | NEW |