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

Unified Diff: mojo/services/media/control/interfaces/media_source.mojom

Issue 1509323002: Mojom updates for Motown. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: sync with master Created 5 years 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: mojo/services/media/control/interfaces/media_source.mojom
diff --git a/mojo/services/media/control/interfaces/media_source.mojom b/mojo/services/media/control/interfaces/media_source.mojom
new file mode 100644
index 0000000000000000000000000000000000000000..7048936f3e535f4bc0e022b61f0872d9a70f0dca
--- /dev/null
+++ b/mojo/services/media/control/interfaces/media_source.mojom
@@ -0,0 +1,64 @@
+// 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.
+
+[DartPackage="mojo_services"]
+module mojo.media;
+
+import "mojo/services/media/common/interfaces/media_clock.mojom";
+import "mojo/services/media/common/interfaces/media_common.mojom";
+import "mojo/services/media/common/interfaces/media_metadata.mojom";
+import "mojo/services/media/common/interfaces/media_state.mojom";
+import "mojo/services/media/common/interfaces/media_transport.mojom";
+import "mojo/services/media/common/interfaces/media_types.mojom";
+
+// Produces media streams delivered from a specified origin.
+interface MediaSource {
+ // Gets the streams produced by this source.
+ GetStreams() => (array<MediaSourceStreamDescriptor> streams);
+
+ // Gets the clock disposition from the source.
+ GetClockDisposition() => (ClockDisposition clock_disposition);
+
+ // Gets a master clock if the source can be master, null otherwise.
+ GetMasterClock(Clock& master_clock);
+
+ // Sets a master clock.
+ SetMasterClock(Clock? master_clock);
+
+ // Gets the producer for the specified stream.
+ GetProducer(uint8 stream_index, MediaProducer& producer);
+
+ // Gets the pull mode producer for the specified stream.
+ GetPullModeProducer(uint8 stream_index, MediaPullModeProducer& producer);
+
+ // Gets the status. To get the status immediately, call GetStatus(0). To
+ // get updates thereafter, pass the version sent in the previous callback.
+ GetStatus(uint64 version_last_seen) =>
jeffbrown 2015/12/10 20:01:00 Same comment here. Consider changing to an ACK-ba
dalesat 2015/12/10 22:33:39 See previous reply.
+ (uint64 version, MediaSourceStatus status);
+
+ // Prepares the source.
+ // TODO(dalesat): Revisit.
+ Prepare() => ();
+};
+
+// Describes a media stream produced by a source.
+struct MediaSourceStreamDescriptor {
+ // Zero-based index.
+ uint8 index;
+
+ // Media type of the stream after conversion.
+ MediaType media_type;
+
+ // Media type of the stream before conversion (as produced by the demux).
+ MediaType original_media_type;
+};
+
+// Describes the media source.
+struct MediaSourceStatus {
+ // Current state of the source.
+ MediaState state;
+
+ // Describes the media.
+ MediaMetadata? metadata;
+};

Powered by Google App Engine
This is Rietveld 408576698