Index: content/browser/media/audio_output_impl.h |
diff --git a/content/browser/media/audio_output_impl.h b/content/browser/media/audio_output_impl.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3eae5bce95f39b671f76656fc2825a0c0a861433 |
--- /dev/null |
+++ b/content/browser/media/audio_output_impl.h |
@@ -0,0 +1,87 @@ |
+// Copyright 2015 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_MEDIA_AUDIO_OUTPUT_IMPL_H_ |
+#define CONTENT_BROWSER_MEDIA_AUDIO_OUTPUT_IMPL_H_ |
+ |
+#include "base/callback.h" |
+#include "base/compiler_specific.h" |
+#include "base/id_map.h" |
+#include "base/macros.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/threading/thread_checker.h" |
+#include "content/browser/renderer_host/media/audio_renderer_host.h" |
+#include "content/common/content_export.h" |
+#include "media/mojo/interfaces/audio_output.mojom.h" |
+#include "mojo/public/cpp/bindings/interface_request.h" |
+#include "mojo/public/cpp/bindings/strong_binding.h" |
+ |
+namespace base { |
+class FilePath; |
+} |
+ |
+namespace content { |
+ |
+class CONTENT_EXPORT AudioOutputStreamImpl : public mojom::AudioOutputStream { |
+ public: |
+ explicit AudioOutputStreamImpl( |
+ mojo::InterfaceRequest<mojom::AudioOutputStream> request, |
+ int stream_id, |
+ AudioRendererHost::AudioEntry* entry, |
+ AudioRendererHost* audio_renderer_host); |
+ void Close() override; |
+ ~AudioOutputStreamImpl() override; |
+ |
+ private: |
+ mojo::Binding<mojom::AudioOutputStream> binding_; |
+ int stream_id_; |
+ AudioRendererHost::AudioEntry* entry_; |
Henrik Grunell
2016/04/19 15:36:08
What's the lifetime of AudioOutputStreamImpl? I.e.
rchtara
2016/04/21 09:10:17
|audio_renderer_host_| is scoped_refptr in AudioOu
Henrik Grunell
2016/04/22 08:23:03
OK, but what if the reference is released before A
|
+ AudioRendererHost* audio_renderer_host_; |
+ DISALLOW_COPY_AND_ASSIGN(AudioOutputStreamImpl); |
+}; |
+ |
+// This class must always be accessed from the creation thread. |
+class CONTENT_EXPORT AudioOutputImpl |
+ : NON_EXPORTED_BASE(public mojom::AudioOutput) { |
+ public: |
+ AudioOutputImpl(mojom::AudioOutputRequest request); |
+ |
+ ~AudioOutputImpl() override; |
+ |
+ static void CreateService( |
+ scoped_refptr<AudioRendererHost> audio_renderer_host, |
+ mojom::AudioOutputRequest request) { |
+ auto service = new AudioOutputImpl(std::move(request)); |
+ service->audio_renderer_host_ = audio_renderer_host; |
+ audio_renderer_host->audio_output_impl_ = service; |
+ } |
+ |
+ void InitMojo(mojo::InterfaceRequest<mojom::AudioOutput> request); |
+ |
+ mojom::AudioOutputStreamPtr* StreamFactory( |
Henrik Grunell
2016/04/19 15:36:08
Who calls this function? Comments on the functions
rchtara
2016/04/21 09:10:17
Done.
Henrik Grunell
2016/04/22 08:23:03
Don't specify the function that calls it, that can
|
+ int stream_id, |
+ AudioRendererHost::AudioEntry* entry, |
+ AudioRendererHost* audio_renderer_host); |
+ |
+ private: |
+ void CreateStream(int stream_id, |
+ int render_frame_id, |
+ mojom::AudioOutputStreamParametersPtr params, |
+ const CreateStreamCallback& callback) override; |
+ void DoCloseStream(int32_t id); |
+ |
+ // Mojo connection error callback. |
+ void OnDisconnect(AudioOutputImpl* impl); |
+ |
+ scoped_refptr<AudioRendererHost> audio_renderer_host_; |
+ base::ThreadChecker thread_checker_; |
+ mojo::StrongBinding<AudioOutput> binding_; |
+ std::map<int, scoped_ptr<AudioOutputStreamImpl>> stream_impls; |
Henrik Grunell
2016/04/19 15:36:08
Add trailing _ to member variable.
rchtara
2016/04/21 09:10:17
Done.
|
+ DISALLOW_COPY_AND_ASSIGN(AudioOutputImpl); |
+}; |
+ |
+} // namespace content |
+ |
+#endif // CONTENT_BROWSER_MEDIA_AUDIO_OUTPUT_IMPL_H_ |