audio: Merge upstream stream tags

This commit is contained in:
Sebastian Dröge 2012-08-09 16:24:47 +02:00
parent b141bfed60
commit 2a1f8a4da3
2 changed files with 34 additions and 20 deletions

View File

@ -1763,6 +1763,20 @@ gst_audio_decoder_sink_eventfunc (GstAudioDecoder * dec, GstEvent * event)
gst_event_unref (event); gst_event_unref (event);
break; break;
} }
case GST_EVENT_TAG:
{
GstTagList *tags;
gst_event_parse_tag (event, &tags);
if (gst_tag_list_get_scope (tags) == GST_TAG_SCOPE_STREAM) {
gst_audio_decoder_merge_tags (dec, tags, GST_TAG_MERGE_REPLACE);
gst_event_unref (event);
event = NULL;
ret = TRUE;
}
break;
}
default: default:
if (!GST_EVENT_IS_SERIALIZED (event)) { if (!GST_EVENT_IS_SERIALIZED (event)) {
ret = ret =

View File

@ -1499,8 +1499,9 @@ gst_audio_encoder_sink_event_default (GstAudioEncoder * enc, GstEvent * event)
GstTagList *tags; GstTagList *tags;
gst_event_parse_tag (event, &tags); gst_event_parse_tag (event, &tags);
if (gst_tag_list_get_scope (tags) == GST_TAG_SCOPE_STREAM) {
tags = gst_tag_list_copy (tags); tags = gst_tag_list_copy (tags);
gst_event_unref (event);
/* FIXME: make generic based on GST_TAG_FLAG_ENCODED */ /* FIXME: make generic based on GST_TAG_FLAG_ENCODED */
gst_tag_list_remove_tag (tags, GST_TAG_CODEC); gst_tag_list_remove_tag (tags, GST_TAG_CODEC);
@ -1514,13 +1515,12 @@ gst_audio_encoder_sink_event_default (GstAudioEncoder * enc, GstEvent * event)
gst_tag_list_remove_tag (tags, GST_TAG_MINIMUM_BITRATE); gst_tag_list_remove_tag (tags, GST_TAG_MINIMUM_BITRATE);
gst_tag_list_remove_tag (tags, GST_TAG_ENCODER); gst_tag_list_remove_tag (tags, GST_TAG_ENCODER);
gst_tag_list_remove_tag (tags, GST_TAG_ENCODER_VERSION); gst_tag_list_remove_tag (tags, GST_TAG_ENCODER_VERSION);
event = gst_event_new_tag (tags);
GST_AUDIO_ENCODER_STREAM_LOCK (enc); gst_audio_encoder_merge_tags (enc, tags, GST_TAG_MERGE_REPLACE);
enc->priv->pending_events = gst_event_unref (event);
g_list_append (enc->priv->pending_events, event); event = NULL;
GST_AUDIO_ENCODER_STREAM_UNLOCK (enc);
res = TRUE; res = TRUE;
}
break; break;
} }