mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 15:08:48 +00:00
ges: Keep internal stream selection messages internally
Timeline StreamCollection are very specific to inner working of nested timelines and should not interfere with the usual stream selection process and are now handled as element messages. Stream selection inside `nleobject` need to be handled internally by the application or GES itself so we should just drop all those as they would interfere and fail if they are exposed to other elements. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5983>
This commit is contained in:
parent
b14207cc9e
commit
37602d1d02
4 changed files with 45 additions and 14 deletions
|
@ -514,6 +514,16 @@ forward:
|
||||||
GST_BIN_CLASS (parent_class)->handle_message (bin, message);
|
GST_BIN_CLASS (parent_class)->handle_message (bin, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ges_timeline_post_stream_collection (GESTimeline * timeline)
|
||||||
|
{
|
||||||
|
gst_element_post_message ((GstElement *) timeline,
|
||||||
|
gst_message_new_element ((GstObject *) timeline,
|
||||||
|
gst_structure_new ("ges-timeline-collection", "collection",
|
||||||
|
GST_TYPE_STREAM_COLLECTION, timeline->priv->stream_collection,
|
||||||
|
NULL)));
|
||||||
|
}
|
||||||
|
|
||||||
static GstStateChangeReturn
|
static GstStateChangeReturn
|
||||||
ges_timeline_change_state (GstElement * element, GstStateChange transition)
|
ges_timeline_change_state (GstElement * element, GstStateChange transition)
|
||||||
{
|
{
|
||||||
|
@ -524,9 +534,7 @@ ges_timeline_change_state (GstElement * element, GstStateChange transition)
|
||||||
transition);
|
transition);
|
||||||
|
|
||||||
if (transition == GST_STATE_CHANGE_READY_TO_PAUSED)
|
if (transition == GST_STATE_CHANGE_READY_TO_PAUSED)
|
||||||
gst_element_post_message ((GstElement *) timeline,
|
ges_timeline_post_stream_collection (timeline);
|
||||||
gst_message_new_stream_collection ((GstObject *) timeline,
|
|
||||||
timeline->priv->stream_collection));
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2894,9 +2902,7 @@ ges_timeline_commit (GESTimeline * timeline)
|
||||||
UNLOCK_DYN (timeline);
|
UNLOCK_DYN (timeline);
|
||||||
|
|
||||||
if (pcollection != timeline->priv->stream_collection) {
|
if (pcollection != timeline->priv->stream_collection) {
|
||||||
gst_element_post_message ((GstElement *) timeline,
|
ges_timeline_post_stream_collection (timeline);
|
||||||
gst_message_new_stream_collection ((GstObject *) timeline,
|
|
||||||
timeline->priv->stream_collection));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ges_timeline_emit_snapping (timeline, NULL, NULL, GST_CLOCK_TIME_NONE);
|
ges_timeline_emit_snapping (timeline, NULL, NULL, GST_CLOCK_TIME_NONE);
|
||||||
|
|
|
@ -488,17 +488,37 @@ ges_track_handle_message (GstBin * bin, GstMessage * message)
|
||||||
{
|
{
|
||||||
GESTrack *track = GES_TRACK (bin);
|
GESTrack *track = GES_TRACK (bin);
|
||||||
|
|
||||||
if (GST_MESSAGE_TYPE (message) == GST_MESSAGE_STREAM_COLLECTION) {
|
switch (GST_MESSAGE_TYPE (message)) {
|
||||||
|
case GST_MESSAGE_STREAM_COLLECTION:
|
||||||
|
g_error ("Internal stream collection messages should be kept internal");
|
||||||
|
break;
|
||||||
|
case GST_MESSAGE_ELEMENT:
|
||||||
|
{
|
||||||
|
const GstStructure *s = gst_message_get_structure (message);
|
||||||
|
|
||||||
|
if (gst_structure_has_name (s, "ges-timeline-collection")) {
|
||||||
GstStreamCollection *collection;
|
GstStreamCollection *collection;
|
||||||
|
|
||||||
gst_message_parse_stream_collection (message, &collection);
|
gst_structure_get (s, "collection", GST_TYPE_STREAM_COLLECTION,
|
||||||
if (GES_IS_TIMELINE (GST_MESSAGE_SRC (message))) {
|
&collection, NULL);
|
||||||
|
|
||||||
ges_track_select_subtimeline_streams (track, collection,
|
ges_track_select_subtimeline_streams (track, collection,
|
||||||
GST_ELEMENT (GST_MESSAGE_SRC (message)));
|
GST_ELEMENT (GST_MESSAGE_SRC (message)));
|
||||||
}
|
|
||||||
|
GST_INFO_OBJECT (bin,
|
||||||
|
"Handled ges-timeline-collection message, dropping");
|
||||||
|
|
||||||
|
gst_message_unref (message);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_element_post_message (GST_ELEMENT_CAST (bin), message);
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_BIN_CLASS (ges_track_parent_class)->handle_message (bin, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* GObject virtual methods */
|
/* GObject virtual methods */
|
||||||
|
|
|
@ -752,7 +752,7 @@ _extract (GESAsset * asset, GError ** error)
|
||||||
GESUriSourceAssetPrivate *priv = GES_URI_SOURCE_ASSET (asset)->priv;
|
GESUriSourceAssetPrivate *priv = GES_URI_SOURCE_ASSET (asset)->priv;
|
||||||
|
|
||||||
if (GST_IS_DISCOVERER_STREAM_INFO (priv->sinfo) == FALSE) {
|
if (GST_IS_DISCOVERER_STREAM_INFO (priv->sinfo) == FALSE) {
|
||||||
GST_WARNING_OBJECT (asset, "Can not extract as no strean info set");
|
GST_WARNING_OBJECT (asset, "Can not extract as no stream info set");
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,6 +140,11 @@ nle_bin_handle_message (GstBin * bin, GstMessage * message)
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
} else if (GST_MESSAGE_TYPE (message) == GST_MESSAGE_STREAM_COLLECTION) {
|
||||||
|
GST_INFO_OBJECT (bin, "Dropping stream collection message, "
|
||||||
|
" those are internal to and should be kept as such");
|
||||||
|
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
return GST_BIN_CLASS (parent_class)->handle_message (bin, message);
|
return GST_BIN_CLASS (parent_class)->handle_message (bin, message);
|
||||||
|
|
Loading…
Reference in a new issue