Merge remote-tracking branch 'origin/master' into 0.11

This commit is contained in:
Tim-Philipp Müller 2011-11-27 23:33:45 +00:00
commit 025ce3e6ca
4 changed files with 51 additions and 0 deletions

View file

@ -7,6 +7,7 @@ libgstaiff_la_CFLAGS = \
$(GST_BASE_CFLAGS) \ $(GST_BASE_CFLAGS) \
$(GST_CFLAGS) $(GST_CFLAGS)
libgstaiff_la_LIBADD = \ libgstaiff_la_LIBADD = \
$(GST_PLUGINS_BASE_LIBS) -lgsttag-$(GST_MAJORMINOR) \
$(GST_BASE_LIBS) \ $(GST_BASE_LIBS) \
$(LIBM) $(LIBM)
libgstaiff_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS) libgstaiff_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)

View file

@ -22,6 +22,8 @@
#include "config.h" #include "config.h"
#endif #endif
#include <gst/tag/tag.h>
#include <gst/gst-i18n-plugin.h> #include <gst/gst-i18n-plugin.h>
#include "aiffparse.h" #include "aiffparse.h"
@ -54,6 +56,8 @@ plugin_init (GstPlugin * plugin)
ret &= gst_element_register (plugin, "aiffmux", GST_RANK_PRIMARY, ret &= gst_element_register (plugin, "aiffmux", GST_RANK_PRIMARY,
GST_TYPE_AIFF_MUX); GST_TYPE_AIFF_MUX);
gst_tag_register_musicbrainz_tags ();
return ret; return ret;
} }

View file

@ -57,6 +57,7 @@
#include "aiffparse.h" #include "aiffparse.h"
#include <gst/audio/audio.h> #include <gst/audio/audio.h>
#include <gst/tag/tag.h>
#include <gst/gst-i18n-plugin.h> #include <gst/gst-i18n-plugin.h>
GST_DEBUG_CATEGORY (aiffparse_debug); GST_DEBUG_CATEGORY (aiffparse_debug);
@ -163,6 +164,11 @@ gst_aiff_parse_reset (GstAiffParse * aiff)
gst_adapter_clear (aiff->adapter); gst_adapter_clear (aiff->adapter);
aiff->adapter = NULL; aiff->adapter = NULL;
} }
if (aiff->tags != NULL) {
gst_tag_list_free (aiff->tags);
aiff->tags = NULL;
}
} }
static void static void
@ -892,6 +898,38 @@ gst_aiff_parse_stream_headers (GstAiffParse * aiff)
} }
break; break;
} }
case GST_MAKE_FOURCC ('I', 'D', '3', ' '):{
GstTagList *tags;
if (aiff->streaming) {
if (!gst_aiff_parse_peek_chunk (aiff, &tag, &size))
return GST_FLOW_OK;
gst_adapter_flush (aiff->adapter, 8);
aiff->offset += 8;
buf = gst_adapter_take_buffer (aiff->adapter, size);
} else {
if ((res = gst_aiff_parse_read_chunk (aiff,
&aiff->offset, &tag, &buf)) != GST_FLOW_OK)
return res;
}
GST_LOG_OBJECT (aiff, "ID3 chunk of size %u", GST_BUFFER_SIZE (buf));
tags = gst_tag_list_from_id3v2_tag (buf);
gst_buffer_unref (buf);
GST_INFO_OBJECT (aiff, "ID3 tags: %" GST_PTR_FORMAT, tags);
if (aiff->tags == NULL) {
aiff->tags = tags;
} else {
gst_tag_list_insert (aiff->tags, tags, GST_TAG_MERGE_APPEND);
gst_tag_list_free (tags);
}
break;
}
default: default:
gst_aiff_parse_ignore_chunk (aiff, buf, tag, size); gst_aiff_parse_ignore_chunk (aiff, buf, tag, size);
} }
@ -1117,6 +1155,11 @@ iterate_adapter:
gst_pad_push_event (aiff->srcpad, aiff->start_segment); gst_pad_push_event (aiff->srcpad, aiff->start_segment);
aiff->start_segment = NULL; aiff->start_segment = NULL;
} }
if (G_UNLIKELY (aiff->tags != NULL)) {
gst_element_found_tags_for_pad (GST_ELEMENT_CAST (aiff), aiff->srcpad,
aiff->tags);
aiff->tags = NULL;
}
obtained = GST_BUFFER_SIZE (buf); obtained = GST_BUFFER_SIZE (buf);

View file

@ -113,6 +113,9 @@ struct _GstAiffParse {
/* discont after seek */ /* discont after seek */
gboolean discont; gboolean discont;
/* tags */
GstTagList *tags;
}; };
struct _GstAiffParseClass { struct _GstAiffParseClass {