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

Unified Diff: chromecast/public/cast_audio_output_device.h

Issue 1105803002: Exposes a shlib interface for media/audio path. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Name refactoring. Created 5 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 side-by-side diff with in-line comments
Download patch
Index: chromecast/public/cast_audio_output_device.h
diff --git a/chromecast/public/cast_audio_output_device.h b/chromecast/public/cast_audio_output_device.h
new file mode 100644
index 0000000000000000000000000000000000000000..c6ba576c8ba79c54c2966a646117a167e9c8dbab
--- /dev/null
+++ b/chromecast/public/cast_audio_output_device.h
@@ -0,0 +1,44 @@
+// 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 CHROMECAST_PUBLIC_CAST_AUDIO_OUTPUT_DEVICE_H_
+#define CHROMECAST_PUBLIC_CAST_AUDIO_OUTPUT_DEVICE_H_
+
+#include <string>
halliwell 2015/04/24 15:04:48 Is <string> used?
slan 2015/04/24 16:19:39 Nope. Artifact of re-factoring. Removed.
+
+#include "cast_audio_stream.h"
+#include "chromecast_export.h"
+
+namespace chromecast {
+
+// This is an interface used to provide platform-specific audio streams.
+// Implementations of this interface should survive for the duration of the
+// process.
+
+// Note: This interface should be implemented by third parties seeking to
+// provide an audio manager platform for Cast. CastAudioManager will call
+// this interface.
+
halliwell 2015/04/24 15:04:48 How do implementations get instantiated ... is tha
slan 2015/04/24 16:19:39 Yes, follow-up CL. This merits a discussion about
+class CHROMECAST_EXPORT CastAudioOutputDevice {
+ public:
+ virtual ~CastAudioOutputDevice() {}
+
+ // Returns the maximum number of output streams allowed.
+ virtual int GetMaximumOutputStreamsAllowed() const = 0;
+
+ // Returns the preferred output stream parameters. The caller may inject
+ // |suggested| parameters, but it is left to the implementation to decide
+ // which of these to return.
+ virtual AudioParameters GetPreferredOutputStreamParameters(
+ const AudioParameters& suggested) const = 0;
+
+ // Creates the output stream with parameters described by |params|. Caller
+ // does not take ownership of the returned stream.
halliwell 2015/04/24 15:04:48 So what's the lifetime of these streams ... they l
slan 2015/04/24 16:19:39 Good question. For now, that is left up to the imp
halliwell 2015/04/25 01:34:10 I'm not familiar with practical usage of these cla
+ virtual CastAudioOutputStream* MakeOutputStream(
+ const AudioParameters& params) = 0;
+};
+
+} // namespace chromecast
+
+#endif // CHROMECAST_PUBLIC_CAST_AUDIO_OUTPUT_DEVICE_H_

Powered by Google App Engine
This is Rietveld 408576698