uridecodebin: Set source element to READY before querying it

Generating the source element is done when uridecodebin is doing the
READY to PAUSED state change, so it is reasonable to set the new source
element to that state.

This also allows detecting early failures with backing libraries or
hardware (checks done in NULL->READY).

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4016>
This commit is contained in:
Thibault Saunier 2023-01-31 13:21:48 -03:00 committed by GStreamer Marge Bot
parent 1ca3203bb6
commit 286020bd23

View file

@ -2309,6 +2309,10 @@ setup_source (GstURIDecodeBin * decoder)
/* stream admin setup */ /* stream admin setup */
decoder->streams = g_hash_table_new_full (NULL, NULL, NULL, free_stream); decoder->streams = g_hash_table_new_full (NULL, NULL, NULL, free_stream);
if (gst_element_set_state (source,
GST_STATE_READY) != GST_STATE_CHANGE_SUCCESS)
goto state_fail;
/* see if the source element emits raw audio/video all by itself, /* see if the source element emits raw audio/video all by itself,
* if so, we can create streams for the pads and be done with it. * if so, we can create streams for the pads and be done with it.
* Also check that is has source pads, if not, we assume it will * Also check that is has source pads, if not, we assume it will
@ -2372,6 +2376,12 @@ no_source:
/* error message was already posted */ /* error message was already posted */
return FALSE; return FALSE;
} }
state_fail:
{
GST_ELEMENT_ERROR (decoder, CORE, FAILED,
(_("Source element can't be prepared")), (NULL));
return FALSE;
}
invalid_source: invalid_source:
{ {
GST_ELEMENT_ERROR (decoder, CORE, FAILED, GST_ELEMENT_ERROR (decoder, CORE, FAILED,