mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
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:
parent
1ca3203bb6
commit
286020bd23
1 changed files with 10 additions and 0 deletions
|
@ -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,
|
||||||
|
|
Loading…
Reference in a new issue