Index: content/browser/speech/speech_recognition_dispatcher_host.h |
diff --git a/content/browser/speech/speech_recognition_dispatcher_host.h b/content/browser/speech/speech_recognition_dispatcher_host.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..62684357882426181ef0e1764686d7829b093a1f |
--- /dev/null |
+++ b/content/browser/speech/speech_recognition_dispatcher_host.h |
@@ -0,0 +1,86 @@ |
+// Copyright (c) 2012 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. |
+ |
+#ifndef CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ |
+#define CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ |
+#pragma once |
+ |
+#include "base/memory/scoped_ptr.h" |
+#include "content/common/content_export.h" |
+#include "content/public/browser/browser_message_filter.h" |
+#include "content/public/browser/speech_recognition_event_listener.h" |
+#include "net/url_request/url_request_context_getter.h" |
+ |
+struct SpeechRecognitionHostMsg_StartRequest_Params; |
+ |
+namespace content { |
+class SpeechRecognitionPreferences; |
+struct SpeechRecognitionResult; |
+} |
+ |
+namespace speech { |
+ |
+class SpeechRecognitionManagerImpl; |
+ |
+// SpeechRecognitionDispatcherHost is a delegate for Speech API messages used by |
+// RenderMessageFilter. Basically it acts as a proxy, relaying the events coming |
+// from the SpeechRecognitionManager to IPC messages (and vice versa). |
+// It's the complement of SpeechRecognitionDispatcher (owned by RenderView). |
+class CONTENT_EXPORT SpeechRecognitionDispatcherHost |
+ : public content::BrowserMessageFilter, |
+ public content::SpeechRecognitionEventListener { |
+ public: |
+ SpeechRecognitionDispatcherHost( |
+ int render_process_id, |
+ net::URLRequestContextGetter* context_getter, |
+ content::SpeechRecognitionPreferences* recognition_preferences); |
+ |
+ // SpeechRecognitionEventListener methods. |
+ virtual void OnRecognitionStart(int session_id) OVERRIDE; |
+ virtual void OnAudioStart(int session_id) OVERRIDE; |
+ virtual void OnEnvironmentEstimationComplete(int session_id) OVERRIDE; |
+ virtual void OnSoundStart(int session_id) OVERRIDE; |
+ virtual void OnSoundEnd(int session_id) OVERRIDE; |
+ virtual void OnAudioEnd(int session_id) OVERRIDE; |
+ virtual void OnRecognitionEnd(int session_id) OVERRIDE; |
+ virtual void OnRecognitionResult( |
+ int session_id, const content::SpeechRecognitionResult& result) OVERRIDE; |
+ virtual void OnRecognitionError( |
+ int session_id, const content::SpeechRecognitionError& error) OVERRIDE; |
+ virtual void OnAudioLevelsChange( |
+ int session_id, float volume, float noise_volume) OVERRIDE; |
+ |
+ // content::BrowserMessageFilter implementation. |
+ virtual bool OnMessageReceived(const IPC::Message& message, |
+ bool* message_was_ok) OVERRIDE; |
+ |
+ // Singleton manager setter useful for tests. |
+ static void set_manager(SpeechRecognitionManagerImpl* manager); |
+ |
+ private: |
+ virtual ~SpeechRecognitionDispatcherHost(); |
+ |
+ void OnStartRequest( |
+ const SpeechRecognitionHostMsg_StartRequest_Params ¶ms); |
hans
2012/05/11 16:56:32
the & should be on the type
Primiano Tucci (use gerrit)
2012/05/14 12:58:22
Oops. Done.
|
+ void OnAbortRequest(int render_view_id, int js_handle_id); |
+ void OnStopCaptureRequest(int render_view_id, int js_handle_id); |
+ |
+ // Returns the speech recognition manager to forward events to, creating one |
hans
2012/05/11 16:56:32
hmm, maybe change the comment to say "requests" ra
Primiano Tucci (use gerrit)
2012/05/14 12:58:22
Right. Furthermore I removed the "creating one if
|
+ // if needed. |
+ SpeechRecognitionManagerImpl* manager(); |
+ |
+ int render_process_id_; |
+ bool may_have_pending_requests_; // Set if we received any speech IPC request |
hans
2012/05/11 16:56:32
nit: period.
Primiano Tucci (use gerrit)
2012/05/14 12:58:22
Done.
|
+ |
+ scoped_refptr<net::URLRequestContextGetter> context_getter_; |
+ scoped_refptr<content::SpeechRecognitionPreferences> recognition_preferences_; |
+ |
+ static SpeechRecognitionManagerImpl* manager_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(SpeechRecognitionDispatcherHost); |
+}; |
+ |
+} // namespace speech |
+ |
+#endif // CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ |