From 840fcf43f52c47cfd886720a3789751a7977a05a Mon Sep 17 00:00:00 2001 From: Philippe Normand Date: Sat, 14 Nov 2020 11:01:01 +0000 Subject: [PATCH] gst-play: Port to GstPlay Part-of: --- meson.build | 4 +- playback/player/gst-play/gst-play.c | 208 ++++++++++++++------------- playback/player/gst-play/meson.build | 2 +- 3 files changed, 109 insertions(+), 105 deletions(-) diff --git a/meson.build b/meson.build index 150288ece8..3f0f994d7f 100644 --- a/meson.build +++ b/meson.build @@ -20,8 +20,8 @@ gmodule_dep = dependency('gmodule-2.0', gst_dep = dependency('gstreamer-1.0', fallback : ['gstreamer', 'gst_dep']) -gstplayer_dep = dependency('gstreamer-player-1.0', version: '>= 1.7.1.1', - fallback: ['gst-plugins-bad', 'gstplayer_dep']) +gstplay_dep = dependency('gstreamer-play-1.0', version: '>= 1.19.0.1', + fallback: ['gst-plugins-bad', 'gstplay_dep']) gsttag_dep = dependency('gstreamer-tag-1.0', fallback: ['gst-plugins-base', 'tag_dep']) gstwebrtc_dep = dependency('gstreamer-webrtc-1.0', version: '>= 1.14.0', diff --git a/playback/player/gst-play/gst-play.c b/playback/player/gst-play/gst-play.c index b28646f88b..73755ffaa1 100644 --- a/playback/player/gst-play/gst-play.c +++ b/playback/player/gst-play/gst-play.c @@ -30,7 +30,7 @@ #include #include "gst-play-kb.h" -#include +#include #define VOLUME_STEPS 20 @@ -43,21 +43,22 @@ typedef struct guint num_uris; gint cur_idx; - GstPlayer *player; + GstPlay *player; + GstPlaySignalAdapter *signal_adapter; GstState desired_state; gboolean repeat; GMainLoop *loop; -} GstPlay; +} Player; -static gboolean play_next (GstPlay * play); -static gboolean play_prev (GstPlay * play); -static void play_reset (GstPlay * play); -static void play_set_relative_volume (GstPlay * play, gdouble volume_step); +static gboolean play_next (Player * play); +static gboolean play_prev (Player * play); +static void play_reset (Player * play); +static void play_set_relative_volume (Player * play, gdouble volume_step); static void -end_of_stream_cb (GstPlayer * player, GstPlay * play) +end_of_stream_cb (GstPlaySignalAdapter * adapter, Player * play) { gst_print ("\n"); /* and switch to next item in list */ @@ -68,7 +69,7 @@ end_of_stream_cb (GstPlayer * player, GstPlay * play) } static void -error_cb (GstPlayer * player, GError * err, GstPlay * play) +error_cb (GstPlaySignalAdapter * adapter, GError * err, Player * play) { gst_printerr ("ERROR %s for %s\n", err->message, play->uris[play->cur_idx]); @@ -83,7 +84,8 @@ error_cb (GstPlayer * player, GError * err, GstPlay * play) } static void -position_updated_cb (GstPlayer * player, GstClockTime pos, GstPlay * play) +position_updated_cb (GstPlaySignalAdapter * adapter, GstClockTime pos, + Player * play) { GstClockTime dur = -1; gchar status[64] = { 0, }; @@ -105,13 +107,14 @@ position_updated_cb (GstPlayer * player, GstClockTime pos, GstPlay * play) } static void -state_changed_cb (GstPlayer * player, GstPlayerState state, GstPlay * play) +state_changed_cb (GstPlaySignalAdapter * adapter, GstPlayState state, + Player * play) { - gst_print ("State changed: %s\n", gst_player_state_get_name (state)); + gst_print ("State changed: %s\n", gst_play_state_get_name (state)); } static void -buffering_cb (GstPlayer * player, gint percent, GstPlay * play) +buffering_cb (GstPlaySignalAdapter * adapter, gint percent, Player * play) { gst_print ("Buffering: %d\n", percent); } @@ -148,7 +151,7 @@ print_one_tag (const GstTagList * list, const gchar * tag, gpointer user_data) } static void -print_video_info (GstPlayerVideoInfo * info) +print_video_info (GstPlayVideoInfo * info) { gint fps_n, fps_d; guint par_n, par_d; @@ -156,159 +159,159 @@ print_video_info (GstPlayerVideoInfo * info) if (info == NULL) return; - gst_print (" width : %d\n", gst_player_video_info_get_width (info)); - gst_print (" height : %d\n", gst_player_video_info_get_height (info)); + gst_print (" width : %d\n", gst_play_video_info_get_width (info)); + gst_print (" height : %d\n", gst_play_video_info_get_height (info)); gst_print (" max_bitrate : %d\n", - gst_player_video_info_get_max_bitrate (info)); - gst_print (" bitrate : %d\n", gst_player_video_info_get_bitrate (info)); - gst_player_video_info_get_framerate (info, &fps_n, &fps_d); + gst_play_video_info_get_max_bitrate (info)); + gst_print (" bitrate : %d\n", gst_play_video_info_get_bitrate (info)); + gst_play_video_info_get_framerate (info, &fps_n, &fps_d); gst_print (" framerate : %.2f\n", (gdouble) fps_n / fps_d); - gst_player_video_info_get_pixel_aspect_ratio (info, &par_n, &par_d); + gst_play_video_info_get_pixel_aspect_ratio (info, &par_n, &par_d); gst_print (" pixel-aspect-ratio %u:%u\n", par_n, par_d); } static void -print_audio_info (GstPlayerAudioInfo * info) +print_audio_info (GstPlayAudioInfo * info) { if (info == NULL) return; gst_print (" sample rate : %d\n", - gst_player_audio_info_get_sample_rate (info)); - gst_print (" channels : %d\n", gst_player_audio_info_get_channels (info)); + gst_play_audio_info_get_sample_rate (info)); + gst_print (" channels : %d\n", gst_play_audio_info_get_channels (info)); gst_print (" max_bitrate : %d\n", - gst_player_audio_info_get_max_bitrate (info)); - gst_print (" bitrate : %d\n", gst_player_audio_info_get_bitrate (info)); - gst_print (" language : %s\n", gst_player_audio_info_get_language (info)); + gst_play_audio_info_get_max_bitrate (info)); + gst_print (" bitrate : %d\n", gst_play_audio_info_get_bitrate (info)); + gst_print (" language : %s\n", gst_play_audio_info_get_language (info)); } static void -print_subtitle_info (GstPlayerSubtitleInfo * info) +print_subtitle_info (GstPlaySubtitleInfo * info) { if (info == NULL) return; - gst_print (" language : %s\n", gst_player_subtitle_info_get_language (info)); + gst_print (" language : %s\n", gst_play_subtitle_info_get_language (info)); } static void -print_all_stream_info (GstPlayerMediaInfo * media_info) +print_all_stream_info (GstPlayMediaInfo * media_info) { guint count = 0; GList *list, *l; - gst_print ("URI : %s\n", gst_player_media_info_get_uri (media_info)); + gst_print ("URI : %s\n", gst_play_media_info_get_uri (media_info)); gst_print ("Duration: %" GST_TIME_FORMAT "\n", - GST_TIME_ARGS (gst_player_media_info_get_duration (media_info))); + GST_TIME_ARGS (gst_play_media_info_get_duration (media_info))); gst_print ("Global taglist:\n"); - if (gst_player_media_info_get_tags (media_info)) - gst_tag_list_foreach (gst_player_media_info_get_tags (media_info), + if (gst_play_media_info_get_tags (media_info)) + gst_tag_list_foreach (gst_play_media_info_get_tags (media_info), print_one_tag, NULL); else gst_print (" (nil) \n"); - list = gst_player_media_info_get_stream_list (media_info); + list = gst_play_media_info_get_stream_list (media_info); if (!list) return; gst_print ("All Stream information\n"); for (l = list; l != NULL; l = l->next) { GstTagList *tags = NULL; - GstPlayerStreamInfo *stream = (GstPlayerStreamInfo *) l->data; + GstPlayStreamInfo *stream = (GstPlayStreamInfo *) l->data; gst_print (" Stream # %u \n", count++); gst_print (" type : %s_%u\n", - gst_player_stream_info_get_stream_type (stream), - gst_player_stream_info_get_index (stream)); - tags = gst_player_stream_info_get_tags (stream); + gst_play_stream_info_get_stream_type (stream), + gst_play_stream_info_get_index (stream)); + tags = gst_play_stream_info_get_tags (stream); gst_print (" taglist : \n"); if (tags) { gst_tag_list_foreach (tags, print_one_tag, NULL); } - if (GST_IS_PLAYER_VIDEO_INFO (stream)) - print_video_info ((GstPlayerVideoInfo *) stream); - else if (GST_IS_PLAYER_AUDIO_INFO (stream)) - print_audio_info ((GstPlayerAudioInfo *) stream); + if (GST_IS_PLAY_VIDEO_INFO (stream)) + print_video_info ((GstPlayVideoInfo *) stream); + else if (GST_IS_PLAY_AUDIO_INFO (stream)) + print_audio_info ((GstPlayAudioInfo *) stream); else - print_subtitle_info ((GstPlayerSubtitleInfo *) stream); + print_subtitle_info ((GstPlaySubtitleInfo *) stream); } } static void -print_all_video_stream (GstPlayerMediaInfo * media_info) +print_all_video_stream (GstPlayMediaInfo * media_info) { GList *list, *l; - list = gst_player_media_info_get_video_streams (media_info); + list = gst_play_media_info_get_video_streams (media_info); if (!list) return; gst_print ("All video streams\n"); for (l = list; l != NULL; l = l->next) { - GstPlayerVideoInfo *info = (GstPlayerVideoInfo *) l->data; - GstPlayerStreamInfo *sinfo = (GstPlayerStreamInfo *) info; - gst_print (" %s_%d #\n", gst_player_stream_info_get_stream_type (sinfo), - gst_player_stream_info_get_index (sinfo)); + GstPlayVideoInfo *info = (GstPlayVideoInfo *) l->data; + GstPlayStreamInfo *sinfo = (GstPlayStreamInfo *) info; + gst_print (" %s_%d #\n", gst_play_stream_info_get_stream_type (sinfo), + gst_play_stream_info_get_index (sinfo)); print_video_info (info); } } static void -print_all_subtitle_stream (GstPlayerMediaInfo * media_info) +print_all_subtitle_stream (GstPlayMediaInfo * media_info) { GList *list, *l; - list = gst_player_media_info_get_subtitle_streams (media_info); + list = gst_play_media_info_get_subtitle_streams (media_info); if (!list) return; gst_print ("All subtitle streams:\n"); for (l = list; l != NULL; l = l->next) { - GstPlayerSubtitleInfo *info = (GstPlayerSubtitleInfo *) l->data; - GstPlayerStreamInfo *sinfo = (GstPlayerStreamInfo *) info; - gst_print (" %s_%d #\n", gst_player_stream_info_get_stream_type (sinfo), - gst_player_stream_info_get_index (sinfo)); + GstPlaySubtitleInfo *info = (GstPlaySubtitleInfo *) l->data; + GstPlayStreamInfo *sinfo = (GstPlayStreamInfo *) info; + gst_print (" %s_%d #\n", gst_play_stream_info_get_stream_type (sinfo), + gst_play_stream_info_get_index (sinfo)); print_subtitle_info (info); } } static void -print_all_audio_stream (GstPlayerMediaInfo * media_info) +print_all_audio_stream (GstPlayMediaInfo * media_info) { GList *list, *l; - list = gst_player_media_info_get_audio_streams (media_info); + list = gst_play_media_info_get_audio_streams (media_info); if (!list) return; gst_print ("All audio streams: \n"); for (l = list; l != NULL; l = l->next) { - GstPlayerAudioInfo *info = (GstPlayerAudioInfo *) l->data; - GstPlayerStreamInfo *sinfo = (GstPlayerStreamInfo *) info; - gst_print (" %s_%d #\n", gst_player_stream_info_get_stream_type (sinfo), - gst_player_stream_info_get_index (sinfo)); + GstPlayAudioInfo *info = (GstPlayAudioInfo *) l->data; + GstPlayStreamInfo *sinfo = (GstPlayStreamInfo *) info; + gst_print (" %s_%d #\n", gst_play_stream_info_get_stream_type (sinfo), + gst_play_stream_info_get_index (sinfo)); print_audio_info (info); } } static void -print_current_tracks (GstPlay * play) +print_current_tracks (Player * play) { - GstPlayerAudioInfo *audio = NULL; - GstPlayerVideoInfo *video = NULL; - GstPlayerSubtitleInfo *subtitle = NULL; + GstPlayAudioInfo *audio = NULL; + GstPlayVideoInfo *video = NULL; + GstPlaySubtitleInfo *subtitle = NULL; gst_print ("Current video track: \n"); - video = gst_player_get_current_video_track (play->player); + video = gst_play_get_current_video_track (play->player); print_video_info (video); gst_print ("Current audio track: \n"); - audio = gst_player_get_current_audio_track (play->player); + audio = gst_play_get_current_audio_track (play->player); print_audio_info (audio); gst_print ("Current subtitle track: \n"); - subtitle = gst_player_get_current_subtitle_track (play->player); + subtitle = gst_play_get_current_subtitle_track (play->player); print_subtitle_info (subtitle); if (audio) @@ -322,7 +325,7 @@ print_current_tracks (GstPlay * play) } static void -print_media_info (GstPlayerMediaInfo * media_info) +print_media_info (GstPlayMediaInfo * media_info) { print_all_stream_info (media_info); gst_print ("\n"); @@ -334,7 +337,8 @@ print_media_info (GstPlayerMediaInfo * media_info) } static void -media_info_cb (GstPlayer * player, GstPlayerMediaInfo * info, GstPlay * play) +media_info_cb (GstPlaySignalAdapter * adapter, GstPlayMediaInfo * info, + Player * play) { static int once = 0; @@ -345,38 +349,37 @@ media_info_cb (GstPlayer * player, GstPlayerMediaInfo * info, GstPlay * play) } } -static GstPlay * +static Player * play_new (gchar ** uris, gdouble initial_volume) { - GstPlay *play; + Player *play; - play = g_new0 (GstPlay, 1); + play = g_new0 (Player, 1); play->uris = uris; play->num_uris = g_strv_length (uris); play->cur_idx = -1; - play->player = - gst_player_new (NULL); + play->player = gst_play_new (NULL); play->loop = g_main_loop_new (NULL, FALSE); play->desired_state = GST_STATE_PLAYING; - GstPlayerSignalAdapter *player_sig_adapt - = gst_player_signal_adapter_new( - play->player, - g_main_loop_get_context (play->loop)); + play->signal_adapter + = gst_play_signal_adapter_new_with_main_context (play->player, + g_main_loop_get_context (play->loop)); - g_signal_connect (player_sig_adapt, "position-updated", + g_signal_connect (play->signal_adapter, "position-updated", G_CALLBACK (position_updated_cb), play); - g_signal_connect (player_sig_adapt, "state-changed", + g_signal_connect (play->signal_adapter, "state-changed", G_CALLBACK (state_changed_cb), play); - g_signal_connect (player_sig_adapt, "buffering", G_CALLBACK (buffering_cb), play); - g_signal_connect (player_sig_adapt, "end-of-stream", + g_signal_connect (play->signal_adapter, "buffering", + G_CALLBACK (buffering_cb), play); + g_signal_connect (play->signal_adapter, "end-of-stream", G_CALLBACK (end_of_stream_cb), play); - g_signal_connect (player_sig_adapt, "error", G_CALLBACK (error_cb), play); + g_signal_connect (play->signal_adapter, "error", G_CALLBACK (error_cb), play); - g_signal_connect (player_sig_adapt, "media-info-updated", + g_signal_connect (play->signal_adapter, "media-info-updated", G_CALLBACK (media_info_cb), play); play_set_relative_volume (play, initial_volume - 1.0); @@ -385,10 +388,11 @@ play_new (gchar ** uris, gdouble initial_volume) } static void -play_free (GstPlay * play) +play_free (Player * play) { play_reset (play); + g_clear_object (&play->signal_adapter); gst_object_unref (play->player); g_main_loop_unref (play->loop); @@ -399,12 +403,12 @@ play_free (GstPlay * play) /* reset for new file/stream */ static void -play_reset (GstPlay * play) +play_reset (Player * play) { } static void -play_set_relative_volume (GstPlay * play, gdouble volume_step) +play_set_relative_volume (Player * play, gdouble volume_step) { gdouble volume; @@ -418,7 +422,7 @@ play_set_relative_volume (GstPlay * play, gdouble volume_step) } static gchar * -play_uri_get_display_name (GstPlay * play, const gchar * uri) +play_uri_get_display_name (Player * play, const gchar * uri) { gchar *loc; @@ -435,7 +439,7 @@ play_uri_get_display_name (GstPlay * play, const gchar * uri) } static void -play_uri (GstPlay * play, const gchar * next_uri) +play_uri (Player * play, const gchar * next_uri) { gchar *loc; @@ -446,12 +450,12 @@ play_uri (GstPlay * play, const gchar * next_uri) g_free (loc); g_object_set (play->player, "uri", next_uri, NULL); - gst_player_play (play->player); + gst_play_play (play->player); } /* returns FALSE if we have reached the end of the playlist */ static gboolean -play_next (GstPlay * play) +play_next (Player * play) { if ((play->cur_idx + 1) >= play->num_uris) { if (play->repeat) { @@ -467,7 +471,7 @@ play_next (GstPlay * play) /* returns FALSE if we have reached the beginning of the playlist */ static gboolean -play_prev (GstPlay * play) +play_prev (Player * play) { if (play->cur_idx == 0 || play->num_uris <= 1) return FALSE; @@ -477,7 +481,7 @@ play_prev (GstPlay * play) } static void -do_play (GstPlay * play) +do_play (Player * play) { gint i; @@ -550,19 +554,19 @@ restore_terminal (void) } static void -toggle_paused (GstPlay * play) +toggle_paused (Player * play) { if (play->desired_state == GST_STATE_PLAYING) { play->desired_state = GST_STATE_PAUSED; - gst_player_pause (play->player); + gst_play_pause (play->player); } else { play->desired_state = GST_STATE_PLAYING; - gst_player_play (play->player); + gst_play_play (play->player); } } static void -relative_seek (GstPlay * play, gdouble percent) +relative_seek (Player * play, gdouble percent) { gint64 dur = -1, pos = -1; @@ -578,18 +582,18 @@ relative_seek (GstPlay * play, gdouble percent) pos = pos + dur * percent; if (pos < 0) pos = 0; - gst_player_seek (play->player, pos); + gst_play_seek (play->player, pos); } static void keyboard_cb (const gchar * key_input, gpointer user_data) { - GstPlay *play = (GstPlay *) user_data; + Player *play = (Player *) user_data; switch (g_ascii_tolower (key_input[0])) { case 'i': { - GstPlayerMediaInfo *media_info = gst_player_get_media_info (play->player); + GstPlayMediaInfo *media_info = gst_play_get_media_info (play->player); if (media_info) { print_media_info (media_info); g_object_unref (media_info); @@ -640,7 +644,7 @@ keyboard_cb (const gchar * key_input, gpointer user_data) int main (int argc, char **argv) { - GstPlay *play; + Player *play; GPtrArray *playlist; gboolean print_version = FALSE; gboolean interactive = FALSE; /* FIXME: maybe enable by default? */ diff --git a/playback/player/gst-play/meson.build b/playback/player/gst-play/meson.build index 8ec021d0e6..5e80ca8dd4 100644 --- a/playback/player/gst-play/meson.build +++ b/playback/player/gst-play/meson.build @@ -2,5 +2,5 @@ executable('gst-play', ['gst-play.c', 'gst-play-kb.c', 'gst-play-kb.h'], - dependencies : [gst_dep, gstplayer_dep, m_dep]) + dependencies : [gst_dep, dependency('gstreamer-play-1.0'), m_dep])