diff options
Diffstat (limited to 'ext/metadata/gstmetadataparse.c')
-rw-r--r-- | ext/metadata/gstmetadataparse.c | 117 |
1 files changed, 65 insertions, 52 deletions
diff --git a/ext/metadata/gstmetadataparse.c b/ext/metadata/gstmetadataparse.c index cf7783db..45532cd5 100644 --- a/ext/metadata/gstmetadataparse.c +++ b/ext/metadata/gstmetadataparse.c @@ -62,22 +62,17 @@ #include "gstmetadataparse.h" +#include "metadataexif.h" -#include "metadataparseexif.h" +#include "metadataiptc.h" -#include "metadataparseiptc.h" - -#include "metadataparsexmp.h" +#include "metadataxmp.h" #include <string.h> GST_DEBUG_CATEGORY_STATIC (gst_metadata_parse_debug); #define GST_CAT_DEFAULT gst_metadata_parse_debug -GST_DEBUG_CATEGORY_EXTERN (gst_metadata_parse_exif_debug); -GST_DEBUG_CATEGORY_EXTERN (gst_metadata_parse_iptc_debug); -GST_DEBUG_CATEGORY_EXTERN (gst_metadata_parse_xmp_debug); - #define GOTO_DONE_IF_NULL(ptr) do { if ( NULL == (ptr) ) goto done; } while(FALSE) #define GOTO_DONE_IF_NULL_AND_FAIL(ptr, ret) do { if ( NULL == (ptr) ) { (ret) = FALSE; goto done; } } while(FALSE) @@ -139,7 +134,7 @@ static GstFlowReturn gst_metadata_parse_chain (GstPad * pad, GstBuffer * buf); static gboolean gst_metadata_parse_checkgetrange (GstPad * srcpad); -static gboolean +static GstFlowReturn gst_metadata_parse_get_range (GstPad * pad, guint64 offset_orig, guint size, GstBuffer ** buf); @@ -300,21 +295,21 @@ gst_metadata_parse_set_property (GObject * object, guint prop_id, switch (prop_id) { case ARG_EXIF: if (g_value_get_boolean (value)) - set_parse_option (filter->parse_data, PARSE_OPT_EXIF); + set_meta_option (filter->parse_data, META_OPT_EXIF); else - unset_parse_option (filter->parse_data, PARSE_OPT_EXIF); + unset_meta_option (filter->parse_data, META_OPT_EXIF); break; case ARG_IPTC: if (g_value_get_boolean (value)) - set_parse_option (filter->parse_data, PARSE_OPT_IPTC); + set_meta_option (filter->parse_data, META_OPT_IPTC); else - unset_parse_option (filter->parse_data, PARSE_OPT_IPTC); + unset_meta_option (filter->parse_data, META_OPT_IPTC); break; case ARG_XMP: if (g_value_get_boolean (value)) - set_parse_option (filter->parse_data, PARSE_OPT_XMP); + set_meta_option (filter->parse_data, META_OPT_XMP); else - unset_parse_option (filter->parse_data, PARSE_OPT_XMP); + unset_meta_option (filter->parse_data, META_OPT_XMP); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); @@ -331,15 +326,15 @@ gst_metadata_parse_get_property (GObject * object, guint prop_id, switch (prop_id) { case ARG_EXIF: g_value_set_boolean (value, - PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_EXIF); + META_DATA_OPTION (filter->parse_data) & META_OPT_EXIF); break; case ARG_IPTC: g_value_set_boolean (value, - PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_IPTC); + META_DATA_OPTION (filter->parse_data) & META_OPT_IPTC); break; case ARG_XMP: g_value_set_boolean (value, - PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_XMP); + META_DATA_OPTION (filter->parse_data) & META_OPT_XMP); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); @@ -473,8 +468,11 @@ gst_metadata_parse_src_event (GstPad * pad, GstEvent * event) filter->prepend_buffer = NULL; } + /* FIXME: related to append */ + filter->offset = start; gst_metadata_parse_translate_pos_to_orig (filter, start, &start, &filter->prepend_buffer); + filter->offset_orig = start; if (stop_type == GST_SEEK_TYPE_CUR) stop = filter->offset + stop; @@ -562,7 +560,7 @@ gst_metadata_parse_finalize (GObject * object) static void gst_metadata_parse_dispose_members (GstMetadataParse * filter) { - metadataparse_dispose (&filter->parse_data); + metadata_dispose (&filter->parse_data); if (filter->adapter_parsing) { gst_object_unref (filter->adapter_parsing); @@ -614,7 +612,7 @@ gst_metadata_parse_init_members (GstMetadataParse * filter) filter->append_buffer = NULL; filter->prepend_buffer = NULL; - memset (&filter->parse_data, 0x00, sizeof (ParseData)); + memset (&filter->parse_data, 0x00, sizeof (MetaData)); } static gboolean @@ -767,13 +765,13 @@ gst_metadata_parse_send_tags (GstMetadataParse * filter) GstTagList *taglist; GstEvent *event; - if (PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_EXIF) + if (META_DATA_OPTION (filter->parse_data) & META_OPT_EXIF) metadataparse_exif_tag_list_add (filter->taglist, GST_TAG_MERGE_KEEP, filter->parse_data.exif_adapter); - if (PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_IPTC) + if (META_DATA_OPTION (filter->parse_data) & META_OPT_IPTC) metadataparse_iptc_tag_list_add (filter->taglist, GST_TAG_MERGE_KEEP, filter->parse_data.iptc_adapter); - if (PARSE_DATA_OPTION (filter->parse_data) & PARSE_OPT_XMP) + if (META_DATA_OPTION (filter->parse_data) & META_OPT_XMP) metadataparse_xmp_tag_list_add (filter->taglist, GST_TAG_MERGE_KEEP, filter->parse_data.xmp_adapter); @@ -823,6 +821,9 @@ gst_metadata_parse_src_query (GstPad * pad, GstQuery * query) } break; case GST_QUERY_DURATION: + if (filter->state != MT_STATE_PARSED) + goto done; + gst_query_parse_duration (query, &format, NULL); if (format == GST_FORMAT_BYTES) { @@ -840,6 +841,8 @@ gst_metadata_parse_src_query (GstPad * pad, GstQuery * query) break; } +done: + gst_object_unref (filter); return ret; @@ -863,11 +866,11 @@ gst_metadata_parse_parse (GstMetadataParse * filter, const guint8 * buf, filter->next_offset = 0; filter->next_size = 0; - ret = metadataparse_parse (&filter->parse_data, buf, size, + ret = metadata_parse (&filter->parse_data, buf, size, &filter->next_offset, &filter->next_size); if (ret < 0) { - if (PARSE_DATA_IMG_TYPE (filter->parse_data) == IMG_NONE) { + if (META_DATA_IMG_TYPE (filter->parse_data) == IMG_NONE) { /* image type not recognized */ GST_ELEMENT_ERROR (filter, STREAM, TYPE_NOT_FOUND, (NULL), ("Only jpeg and png are supported")); @@ -928,8 +931,8 @@ gst_metadata_parse_parse (GstMetadataParse * filter, const guint8 * buf, filter->need_send_tag = TRUE; } - if (filter->img_type != PARSE_DATA_IMG_TYPE (filter->parse_data)) { - filter->img_type = PARSE_DATA_IMG_TYPE (filter->parse_data); + if (filter->img_type != META_DATA_IMG_TYPE (filter->parse_data)) { + filter->img_type = META_DATA_IMG_TYPE (filter->parse_data); if (!gst_metadata_parse_configure_caps (filter)) { GST_ELEMENT_ERROR (filter, STREAM, FORMAT, (NULL), ("Couldn't reconfigure caps for %s", @@ -966,8 +969,6 @@ gst_metadata_parse_chain (GstPad * pad, GstBuffer * buf) filter = GST_METADATA_PARSE (gst_pad_get_parent (pad)); - /* commented until I figure out how to strip if it wasn't parsed yet */ - if (filter->state != MT_STATE_PARSED) { guint32 adpt_size = gst_adapter_available (filter->adapter_parsing); @@ -1607,22 +1608,26 @@ gst_metadata_parse_checkgetrange (GstPad * srcpad) return gst_pad_check_pull_range (filter->sinkpad); } -static gboolean +static GstFlowReturn gst_metadata_parse_get_range (GstPad * pad, guint64 offset, guint size, GstBuffer ** buf) { GstMetadataParse *filter = NULL; - gboolean ret = TRUE; - const gint64 offset_orig = 0; + GstFlowReturn ret = GST_FLOW_OK; + gint64 offset_orig = 0; guint size_orig; GstBuffer *prepend = NULL; gboolean need_append = FALSE; filter = GST_METADATA_PARSE (GST_PAD_PARENT (pad)); + if (filter->state != MT_STATE_PARSED) { + ret = GST_FLOW_ERROR; + goto done; + } + if (offset + size > filter->duration) { - /* this should never happen */ - return FALSE; + size = filter->duration - offset; } size_orig = size; @@ -1647,10 +1652,7 @@ gst_metadata_parse_get_range (GstPad * pad, ret = gst_pad_pull_range (filter->sinkpad, offset_orig, size_orig, buf); if (ret == GST_FLOW_OK && *buf) { - /* FIXEME: put prepend here */ gst_metadata_parse_strip_push_buffer (filter, offset_orig, &prepend, buf); - filter->offset_orig = offset; - filter->offset = offset; if (GST_BUFFER_SIZE (*buf) < size) { /* need append */ @@ -1664,6 +1666,15 @@ gst_metadata_parse_get_range (GstPad * pad, done: + if (need_append) { + /* FIXME: together with SEEK and + * gst_metadata_parse_translate_pos_to_orig + * this way if chunk is added in the end we are in trolble + * ...still not implemented 'cause it will not be the + * case for the time being + */ + } + return ret; } @@ -1700,7 +1711,7 @@ gst_metadata_parse_change_state (GstElement * element, gst_metadata_parse_init_members (filter); filter->adapter_parsing = gst_adapter_new (); filter->taglist = gst_tag_list_new (); - metadataparse_init (&filter->parse_data); + metadata_init (&filter->parse_data); break; default: break; @@ -1711,6 +1722,22 @@ gst_metadata_parse_change_state (GstElement * element, goto done; switch (transition) { + case GST_STATE_CHANGE_PAUSED_TO_READY: + filter->offset = 0; + filter->offset_orig = 0; + if (filter->adapter_parsing) { + gst_adapter_clear (filter->adapter_parsing); + } + if (filter->adapter_holding) { + gst_adapter_clear (filter->adapter_holding); + } + if (filter->state != MT_STATE_PARSED) { + /* cleanup parser */ + /* FIXME: could be improved a bit to avoid mem allocation */ + metadata_dispose (&filter->parse_data); + metadata_init (&filter->parse_data); + } + break; case GST_STATE_CHANGE_READY_TO_NULL: gst_metadata_parse_dispose_members (filter); break; @@ -1733,20 +1760,6 @@ gst_metadata_parse_plugin_init (GstPlugin * plugin) GST_DEBUG_CATEGORY_INIT (gst_metadata_parse_debug, "metadataparse", 0, "Metadata demuxer"); - GST_DEBUG_CATEGORY_INIT (gst_metadata_parse_exif_debug, "metadataparse_exif", - 0, "Metadata exif demuxer"); - GST_DEBUG_CATEGORY_INIT (gst_metadata_parse_iptc_debug, "metadataparse_iptc", - 0, "Metadata iptc demuxer"); - GST_DEBUG_CATEGORY_INIT (gst_metadata_parse_xmp_debug, "metadataparse_xmp", 0, - "Metadata xmp demuxer"); - - /* FIXME: register tag should be done by plugin 'cause muxer element also uses it */ - metadataparse_exif_tags_register (); - - metadataparse_iptc_tags_register (); - - metadataparse_xmp_tags_register (); - return gst_element_register (plugin, "metadataparse", GST_RANK_PRIMARY + 1, GST_TYPE_METADATA_PARSE); } |