diff options
Diffstat (limited to 'ext/metadata')
-rw-r--r-- | ext/metadata/metadataparsexmp.c | 119 |
1 files changed, 110 insertions, 9 deletions
diff --git a/ext/metadata/metadataparsexmp.c b/ext/metadata/metadataparsexmp.c index aa503d35..0b73f2f0 100644 --- a/ext/metadata/metadataparsexmp.c +++ b/ext/metadata/metadataparsexmp.c @@ -85,6 +85,17 @@ metadataparse_xmp_dispose (void) #include <xmp.h> +#define XMP_SCHEMA_NODE 0x80000000UL + +void +metadataparse_xmp_iter_array (XmpPtr xmp, const char *schema, const char *path); + +static void +metadataparse_xmp_iter_simple (const char *schema, const char *path, + const char *value); + +static void metadataparse_xmp_iter (XmpPtr xmp, XmpIteratorPtr iter); + gboolean metadataparse_xmp_init (void) { @@ -103,8 +114,8 @@ metadataparse_xmp_tag_list_add (GstTagList * taglist, GstTagMergeMode mode, { const guint8 *buf; guint32 size; - XmpPtr *xmp = NULL; - XmpStringPtr xmp_str = NULL; + XmpPtr xmp = NULL; + XmpIteratorPtr xmp_iter = NULL; if (adapter == NULL || (size = gst_adapter_available (adapter)) == 0) { goto done; @@ -119,18 +130,17 @@ metadataparse_xmp_tag_list_add (GstTagList * taglist, GstTagMergeMode mode, if (!xmp) goto done; - xmp_str = xmp_string_new (); - if (!xmp_str) - goto done; + xmp_iter = xmp_iterator_new (xmp, NULL, NULL, XMP_ITER_JUSTCHILDREN); - xmp_serialize (xmp, xmp_str, XMP_SERIAL_ENCODEUTF8, 2); + if (!xmp_iter) + goto done; - GST_LOG (xmp_string_cstr (xmp_str)); + metadataparse_xmp_iter (xmp, xmp_iter); done: - if (xmp_str) { - xmp_string_free (xmp_str); + if (xmp_iter) { + xmp_iterator_free (xmp_iter); } if (xmp) { @@ -141,4 +151,95 @@ done: } +void +metadataparse_xmp_iter_simple_qual (const char *schema, const char *path, + const char *value) +{ + GString *string = g_string_new (path); + gchar *ch; + + ch = string->str + string->len - 3; + while (ch != string->str) { + if (*ch == '[') { + *ch = '\0'; + } + --ch; + } + + GST_LOG (" %s = %s\n", string->str, value); + g_string_free (string, TRUE); +} + +void +metadataparse_xmp_iter_simple (const char *schema, const char *path, + const char *value) +{ + GST_LOG (" %s = %s\n", path, value); +} + +void +metadataparse_xmp_iter_array (XmpPtr xmp, const char *schema, const char *path) +{ + + XmpIteratorPtr xmp_iter = NULL; + + xmp_iter = xmp_iterator_new (xmp, schema, path, XMP_ITER_JUSTCHILDREN); + + if (xmp_iter) { + metadataparse_xmp_iter (xmp, xmp_iter); + + xmp_iterator_free (xmp_iter); + } + +} + +void +metadataparse_xmp_iter (XmpPtr xmp, XmpIteratorPtr iter) +{ + XmpStringPtr xstr_schema = xmp_string_new (); + XmpStringPtr xstr_path = xmp_string_new (); + XmpStringPtr xstr_prop = xmp_string_new (); + uint32_t opt = 0; + + while (xmp_iterator_next (iter, xstr_schema, xstr_path, xstr_prop, &opt)) { + const char *schema = xmp_string_cstr (xstr_schema); + const char *path = xmp_string_cstr (xstr_path); + const char *value = xmp_string_cstr (xstr_prop); + + if (XMP_IS_NODE_SCHEMA (opt)) { + GST_LOG ("%s\n", schema); + metadataparse_xmp_iter_array (xmp, schema, path); + } else if (XMP_IS_PROP_SIMPLE (opt)) { + if (strcmp (path, "") != 0) { + if (XMP_HAS_PROP_QUALIFIERS (opt)) { + metadataparse_xmp_iter_simple_qual (schema, path, value); + } else { + metadataparse_xmp_iter_simple (schema, path, value); + } + } + } else if (XMP_IS_PROP_ARRAY (opt)) { + if (XMP_IS_ARRAY_ALTTEXT (opt)) { + metadataparse_xmp_iter_array (xmp, schema, path); + xmp_iterator_skip (iter, XMP_ITER_SKIPSUBTREE); + } else { + metadataparse_xmp_iter_array (xmp, schema, path); + xmp_iterator_skip (iter, XMP_ITER_SKIPSUBTREE); + } + } + + + + } + + if (xstr_prop) { + xmp_string_free (xstr_prop); + } + if (xstr_path) { + xmp_string_free (xstr_path); + } + if (xstr_schema) { + xmp_string_free (xstr_schema); + } +} + #endif /* else (ifndef HAVE_XMP) */ |