From 06be1f8b52eb486b3fe0936f935eec9ea12339ef Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Mon, 29 Mar 2021 17:03:33 +0200 Subject: gstmedia: Ensure we prepare files without duration In particular this fixes playback of images. Fixes #3810 --- modules/media/gtkgstmediafile.c | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/modules/media/gtkgstmediafile.c b/modules/media/gtkgstmediafile.c index 6382f3b10a..7edc682e9c 100644 --- a/modules/media/gtkgstmediafile.c +++ b/modules/media/gtkgstmediafile.c @@ -126,11 +126,27 @@ g_io_module_query (void) return g_strdupv (eps); } +static void +gtk_gst_media_file_ensure_prepared (GtkGstMediaFile *self, + gint64 duration) +{ + if (gtk_media_stream_is_prepared (GTK_MEDIA_STREAM (self))) + return; + + gtk_media_stream_prepared (GTK_MEDIA_STREAM (self), + TRUE, + TRUE, + TRUE, + duration); +} + static void gtk_gst_media_file_position_updated_cb (GstPlayer *player, GstClockTime time, GtkGstMediaFile *self) { + gtk_gst_media_file_ensure_prepared (self, 0); + gtk_media_stream_update (GTK_MEDIA_STREAM (self), FROM_GST_TIME (time)); } @@ -139,14 +155,7 @@ gtk_gst_media_file_duration_changed_cb (GstPlayer *player, GstClockTime duration, GtkGstMediaFile *self) { - if (gtk_media_stream_is_prepared (GTK_MEDIA_STREAM (self))) - return; - - gtk_media_stream_prepared (GTK_MEDIA_STREAM (self), - TRUE, - TRUE, - TRUE, - FROM_GST_TIME (duration)); + gtk_gst_media_file_ensure_prepared (self, FROM_GST_TIME (duration)); } static void @@ -176,6 +185,8 @@ static void gtk_gst_media_file_end_of_stream_cb (GstPlayer *player, GtkGstMediaFile *self) { + gtk_gst_media_file_ensure_prepared (self, 0); + if (gtk_media_stream_get_ended (GTK_MEDIA_STREAM (self))) return; -- cgit v1.2.1 From 38fff37daec3c8ec679717c93650fed2a5999bde Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Mon, 29 Mar 2021 15:02:22 +0200 Subject: mediastream: Insist streams are prepared when they start playing Applications expect that behavior, so don't let implementations get away without preparing the stream. --- gtk/gtkmediastream.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/gtk/gtkmediastream.c b/gtk/gtkmediastream.c index 8635b6bb4c..1b3d1c1115 100644 --- a/gtk/gtkmediastream.c +++ b/gtk/gtkmediastream.c @@ -1263,6 +1263,8 @@ gtk_media_stream_error_valist (GtkMediaStream *self, * * It is up to implementations to call this at the frequency * they deem appropriate. + * + * The media stream must be prepared when this function is called. */ void gtk_media_stream_update (GtkMediaStream *self, @@ -1271,6 +1273,7 @@ gtk_media_stream_update (GtkMediaStream *self, GtkMediaStreamPrivate *priv = gtk_media_stream_get_instance_private (self); g_return_if_fail (GTK_IS_MEDIA_STREAM (self)); + g_return_if_fail (gtk_media_stream_is_prepared (self)); g_object_freeze_notify (G_OBJECT (self)); @@ -1301,6 +1304,8 @@ gtk_media_stream_update (GtkMediaStream *self, * * This is a hint only, calls to GtkMediaStream.play() * may still happen. + * + * The media stream must be prepared when this function is called. */ void gtk_media_stream_ended (GtkMediaStream *self) @@ -1308,6 +1313,7 @@ gtk_media_stream_ended (GtkMediaStream *self) GtkMediaStreamPrivate *priv = gtk_media_stream_get_instance_private (self); g_return_if_fail (GTK_IS_MEDIA_STREAM (self)); + g_return_if_fail (gtk_media_stream_is_prepared (self)); g_return_if_fail (!gtk_media_stream_get_ended (self)); g_object_freeze_notify (G_OBJECT (self)); -- cgit v1.2.1