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

Side by Side Diff: content/browser/speech/speech_recognition_manager_impl.h

Issue 13989003: Replace MediaStreamUIController with MediaStreamUIProxy. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 #ifndef CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_ 5 #ifndef CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_
6 #define CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_ 6 #define CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_
7 7
8 #include <map> 8 #include <map>
9 #include <string> 9 #include <string>
10 10
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/callback.h" 12 #include "base/callback.h"
13 #include "base/compiler_specific.h" 13 #include "base/compiler_specific.h"
14 #include "base/memory/weak_ptr.h" 14 #include "base/memory/weak_ptr.h"
15 #include "content/browser/renderer_host/media/media_stream_requester.h" 15 #include "content/browser/renderer_host/media/media_stream_requester.h"
16 #include "content/public/browser/speech_recognition_event_listener.h" 16 #include "content/public/browser/speech_recognition_event_listener.h"
17 #include "content/public/browser/speech_recognition_manager.h" 17 #include "content/public/browser/speech_recognition_manager.h"
18 #include "content/public/browser/speech_recognition_session_config.h" 18 #include "content/public/browser/speech_recognition_session_config.h"
19 #include "content/public/browser/speech_recognition_session_context.h" 19 #include "content/public/browser/speech_recognition_session_context.h"
20 #include "content/public/common/speech_recognition_error.h" 20 #include "content/public/common/speech_recognition_error.h"
21 21
22 namespace content { 22 namespace content {
23 class BrowserMainLoop; 23 class BrowserMainLoop;
24 class MediaStreamUIProxy;
24 class SpeechRecognitionManagerDelegate; 25 class SpeechRecognitionManagerDelegate;
25 class SpeechRecognizer; 26 class SpeechRecognizer;
26 27
27 // This is the manager for speech recognition. It is a single instance in 28 // This is the manager for speech recognition. It is a single instance in
28 // the browser process and can serve several requests. Each recognition request 29 // the browser process and can serve several requests. Each recognition request
29 // corresponds to a session, initiated via |CreateSession|. 30 // corresponds to a session, initiated via |CreateSession|.
30 // 31 //
31 // In any moment, the manager has a single session known as the primary session, 32 // In any moment, the manager has a single session known as the primary session,
32 // |primary_session_id_|. 33 // |primary_session_id_|.
33 // This is the session that is capturing audio, waiting for user permission, 34 // This is the session that is capturing audio, waiting for user permission,
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
116 117
117 struct Session { 118 struct Session {
118 Session(); 119 Session();
119 ~Session(); 120 ~Session();
120 121
121 int id; 122 int id;
122 bool listener_is_active; 123 bool listener_is_active;
123 SpeechRecognitionSessionConfig config; 124 SpeechRecognitionSessionConfig config;
124 SpeechRecognitionSessionContext context; 125 SpeechRecognitionSessionContext context;
125 scoped_refptr<SpeechRecognizer> recognizer; 126 scoped_refptr<SpeechRecognizer> recognizer;
127 scoped_ptr<MediaStreamUIProxy> ui;
126 }; 128 };
127 129
128 // Callback issued by the SpeechRecognitionManagerDelegate for reporting 130 // Callback issued by the SpeechRecognitionManagerDelegate for reporting
129 // asynchronously the result of the CheckRecognitionIsAllowed call. 131 // asynchronously the result of the CheckRecognitionIsAllowed call.
130 void RecognitionAllowedCallback(int session_id, 132 void RecognitionAllowedCallback(int session_id,
131 bool ask_user, 133 bool ask_user,
132 bool is_allowed); 134 bool is_allowed);
133 135
134 // Callback to get back the result of a media request. |label| is the string 136 // Callback to get back the result of a media request. |devices| is an array
135 // to identify the request; |devices| is an array of devices approved to be 137 // of devices approved to be used for the request, |devices| is empty if the
136 // used for the request, |devices| is empty if the users deny the request. 138 // users deny the request.
137 void MediaRequestPermissionCallback(const std::string& label, 139 void MediaRequestPermissionCallback(int session_id,
138 const MediaStreamDevices& devices); 140 const MediaStreamDevices& devices,
141 scoped_ptr<MediaStreamUIProxy> stream_ui);
139 142
140 // Entry point for pushing any external event into the session handling FSM. 143 // Entry point for pushing any external event into the session handling FSM.
141 void DispatchEvent(int session_id, FSMEvent event); 144 void DispatchEvent(int session_id, FSMEvent event);
142 145
143 // Defines the behavior of the session handling FSM, selecting the appropriate 146 // Defines the behavior of the session handling FSM, selecting the appropriate
144 // transition according to the session, its current state and the event. 147 // transition according to the session, its current state and the event.
145 void ExecuteTransitionAndGetNextState( 148 void ExecuteTransitionAndGetNextState(Session* session,
146 const Session& session, FSMState session_state, FSMEvent event); 149 FSMState session_state,
150 FSMEvent event);
147 151
148 // Retrieves the state of the session, enquiring directly the recognizer. 152 // Retrieves the state of the session, enquiring directly the recognizer.
149 FSMState GetSessionState(int session_id) const; 153 FSMState GetSessionState(int session_id) const;
150 154
151 // The methods below handle transitions of the session handling FSM. 155 // The methods below handle transitions of the session handling FSM.
152 void SessionStart(const Session& session); 156 void SessionStart(const Session& session);
153 void SessionAbort(const Session& session); 157 void SessionAbort(const Session& session);
154 void SessionStopAudioCapture(const Session& session); 158 void SessionStopAudioCapture(const Session& session);
155 void ResetCapturingSessionId(const Session& session); 159 void ResetCapturingSessionId(const Session& session);
156 void SessionDelete(const Session& session); 160 void SessionDelete(Session* session);
157 void NotFeasible(const Session& session, FSMEvent event); 161 void NotFeasible(const Session& session, FSMEvent event);
158 162
159 bool SessionExists(int session_id) const; 163 bool SessionExists(int session_id) const;
160 const Session& GetSession(int session_id) const; 164 Session* GetSession(int session_id) const;
161 SpeechRecognitionEventListener* GetListener(int session_id) const; 165 SpeechRecognitionEventListener* GetListener(int session_id) const;
162 SpeechRecognitionEventListener* GetDelegateListener() const; 166 SpeechRecognitionEventListener* GetDelegateListener() const;
163 int GetNextSessionID(); 167 int GetNextSessionID();
164 168
165 typedef std::map<int, Session> SessionsTable; 169 typedef std::map<int, Session*> SessionsTable;
tommi (sloooow) - chröme 2013/04/22 13:22:39 can we use scoped_ptr<> and Pass() to protect agai
Sergey Ulanov 2013/04/23 05:21:44 No. STL collections work only with copyable types,
166 SessionsTable sessions_; 170 SessionsTable sessions_;
167 int primary_session_id_; 171 int primary_session_id_;
168 int last_session_id_; 172 int last_session_id_;
169 bool is_dispatching_event_; 173 bool is_dispatching_event_;
170 scoped_ptr<SpeechRecognitionManagerDelegate> delegate_; 174 scoped_ptr<SpeechRecognitionManagerDelegate> delegate_;
171 175
172 // Used for posting asynchronous tasks (on the IO thread) without worrying 176 // Used for posting asynchronous tasks (on the IO thread) without worrying
173 // about this class being destroyed in the meanwhile (due to browser shutdown) 177 // about this class being destroyed in the meanwhile (due to browser shutdown)
174 // since tasks pending on a destroyed WeakPtr are automatically discarded. 178 // since tasks pending on a destroyed WeakPtr are automatically discarded.
175 base::WeakPtrFactory<SpeechRecognitionManagerImpl> weak_factory_; 179 base::WeakPtrFactory<SpeechRecognitionManagerImpl> weak_factory_;
176 }; 180 };
177 181
178 } // namespace content 182 } // namespace content
179 183
180 #endif // CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_ 184 #endif // CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_MANAGER_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698