Merge branch 'nielsdg/metadata-viewer' into 'master'

Draft: Update metadata viewer plug-in to use GtkListBox

See merge request GNOME/gimp!1553
This commit is contained in:
Niels De Graef 2025-07-01 23:14:23 +00:00
commit 5d0270b67e
4 changed files with 246 additions and 201 deletions

View file

@ -45,6 +45,7 @@ plugin_name = 'metadata-viewer'
plugin_sourcecode = [ plugin_sourcecode = [
'metadata-viewer.c', 'metadata-viewer.c',
'metadata-tag-object.c',
'metadata-tags.c', 'metadata-tags.c',
] ]
plugin_sources = plugin_sourcecode plugin_sources = plugin_sourcecode

View file

@ -0,0 +1,94 @@
/* GIMP - The GNU Image Manipulation Program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* metadata-tag.c
* Copyright (C) 2024 Niels De Graef
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
#include "config.h"
#include <libgimp/gimp.h>
#include <libgimp/gimpui.h>
#include "metadata-tag-object.h"
struct _GimpMetadataTagObject
{
GObject parent_instance;
gchar *tag;
gchar *value;
};
G_DEFINE_TYPE (GimpMetadataTagObject, gimp_metadata_tag_object, G_TYPE_OBJECT);
static void gimp_metadata_tag_object_finalize (GObject *object);
static void
gimp_metadata_tag_object_finalize (GObject *object)
{
GimpMetadataTagObject *self = GIMP_METADATA_TAG_OBJECT (object);
g_free (self->tag);
g_free (self->value);
G_OBJECT_CLASS (gimp_metadata_tag_object_parent_class)->finalize (object);
}
static void
gimp_metadata_tag_object_init (GimpMetadataTagObject *self)
{
}
static void
gimp_metadata_tag_object_class_init (GimpMetadataTagObjectClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
object_class->finalize = gimp_metadata_tag_object_finalize;
}
GimpMetadataTagObject *
gimp_metadata_tag_object_new (const gchar *tag,
const gchar *value)
{
GimpMetadataTagObject *self;
g_return_val_if_fail (tag != NULL, NULL);
g_return_val_if_fail (value != NULL, NULL);
self = g_object_new (GIMP_TYPE_METADATA_TAG_OBJECT, NULL);
self->tag = g_strdup (tag);
self->value = g_strdup (value);
return self;
}
const gchar *
gimp_metadata_tag_object_get_tag (GimpMetadataTagObject *self)
{
g_return_val_if_fail (GIMP_IS_METADATA_TAG_OBJECT (self), NULL);
return self->tag;
}
const gchar *
gimp_metadata_tag_object_get_value (GimpMetadataTagObject *self)
{
g_return_val_if_fail (GIMP_IS_METADATA_TAG_OBJECT (self), NULL);
return self->value;
}

View file

@ -0,0 +1,36 @@
/* GIMP - The GNU Image Manipulation Program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* Copyright (C) 2024 Niels De Graef
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
#ifndef __METADATA_TAG_OBJECT_H__
#define __METADATA_TAG_OBJECT_H__
#include <glib-object.h>
#define GIMP_TYPE_METADATA_TAG_OBJECT (gimp_metadata_tag_object_get_type ())
G_DECLARE_FINAL_TYPE (GimpMetadataTagObject, gimp_metadata_tag_object,
GIMP, METADATA_TAG_OBJECT,
GObject);
GimpMetadataTagObject * gimp_metadata_tag_object_new (const gchar *tag,
const gchar *value);
const gchar * gimp_metadata_tag_object_get_tag (GimpMetadataTagObject *self);
const gchar * gimp_metadata_tag_object_get_value (GimpMetadataTagObject *self);
#endif /* __METADATA_TAG_OBJECT_H__ */

View file

@ -28,6 +28,7 @@
#include "libgimp/stdplugins-intl.h" #include "libgimp/stdplugins-intl.h"
#include "metadata-tag-object.h"
#include "metadata-tags.h" #include "metadata-tags.h"
#define PLUG_IN_PROC "plug-in-metadata-viewer" #define PLUG_IN_PROC "plug-in-metadata-viewer"
@ -47,46 +48,14 @@
#define RAW_DATA_MAX_SIZE 16 #define RAW_DATA_MAX_SIZE 16
enum #define GIMP_TYPE_METADATA_VIEWER (gimp_metadata_viewer_get_type ())
{ G_DECLARE_FINAL_TYPE (GimpMetadataViewer, gimp_metadata_viewer, GIMP, METADATA_VIEWER, GimpPlugIn)
C_XMP_TAG = 0,
C_XMP_VALUE,
NUM_XMP_COLS
};
enum struct _GimpMetadataViewer
{
C_EXIF_TAG = 0,
C_EXIF_VALUE,
NUM_EXIF_COLS
};
enum
{
C_IPTC_TAG = 0,
C_IPTC_VALUE,
NUM_IPTC_COLS
};
typedef struct _Metadata Metadata;
typedef struct _MetadataClass MetadataClass;
struct _Metadata
{ {
GimpPlugIn parent_instance; GimpPlugIn parent_instance;
}; };
struct _MetadataClass
{
GimpPlugInClass parent_class;
};
#define METADATA_TYPE (metadata_get_type ())
#define METADATA(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), METADATA_TYPE, Metadata))
GType metadata_get_type (void) G_GNUC_CONST;
static GList * metadata_query_procedures (GimpPlugIn *plug_in); static GList * metadata_query_procedures (GimpPlugIn *plug_in);
static GimpProcedure * metadata_create_procedure (GimpPlugIn *plug_in, static GimpProcedure * metadata_create_procedure (GimpPlugIn *plug_in,
@ -103,29 +72,23 @@ static gboolean metadata_viewer_dialog (GimpImage *image,
GimpMetadata *g_metadata, GimpMetadata *g_metadata,
GError **error); GError **error);
static void metadata_dialog_set_metadata (GExiv2Metadata *metadata, static void metadata_dialog_set_metadata (GExiv2Metadata *metadata,
GtkListStore *exif_store, GListStore *exif_store,
GtkListStore *xmp_store, GListStore *xmp_store,
GtkListStore *iptc_store); GListStore *iptc_store);
static GtkWidget * create_widget_for_tag_object (gpointer item,
gpointer user_data);
static void metadata_dialog_add_multiple_values (GExiv2Metadata *metadata, static void metadata_dialog_add_multiple_values (GExiv2Metadata *metadata,
const gchar *tag, const gchar *tag,
GtkListStore *store, GListStore *store);
gint tag_column,
gint value_column);
static void metadata_dialog_append_tags (GExiv2Metadata *metadata, static void metadata_dialog_append_tags (GExiv2Metadata *metadata,
gchar **tags, gchar **tags,
GtkListStore *store, GListStore *store,
gint tag_column,
gint value_column,
gboolean load_iptc); gboolean load_iptc);
static void metadata_dialog_add_tag (GtkListStore *store, static void metadata_dialog_add_tag (GListStore *store,
gint tag_column,
gint value_column,
const gchar *tag, const gchar *tag,
const gchar *value); const gchar *value);
static void metadata_dialog_add_translated_tag (GExiv2Metadata *metadata, static void metadata_dialog_add_translated_tag (GExiv2Metadata *metadata,
GtkListStore *store, GListStore *store,
gint tag_column,
gint value_column,
const gchar *tag); const gchar *tag);
static gchar * metadata_interpret_user_comment (gchar *comment); static gchar * metadata_interpret_user_comment (gchar *comment);
static gchar * metadata_dialog_format_tag_value (GExiv2Metadata *metadata, static gchar * metadata_dialog_format_tag_value (GExiv2Metadata *metadata,
@ -136,14 +99,14 @@ static gchar * metadata_format_string_value (const gchar *value,
static inline gboolean metadata_tag_is_string (const gchar *tag); static inline gboolean metadata_tag_is_string (const gchar *tag);
G_DEFINE_TYPE (Metadata, metadata, GIMP_TYPE_PLUG_IN) G_DEFINE_TYPE (GimpMetadataViewer, gimp_metadata_viewer, GIMP_TYPE_PLUG_IN)
GIMP_MAIN (METADATA_TYPE) GIMP_MAIN (GIMP_TYPE_METADATA_VIEWER)
DEFINE_STD_SET_I18N DEFINE_STD_SET_I18N
static void static void
metadata_class_init (MetadataClass *klass) gimp_metadata_viewer_class_init (GimpMetadataViewerClass *klass)
{ {
GimpPlugInClass *plug_in_class = GIMP_PLUG_IN_CLASS (klass); GimpPlugInClass *plug_in_class = GIMP_PLUG_IN_CLASS (klass);
@ -153,7 +116,7 @@ metadata_class_init (MetadataClass *klass)
} }
static void static void
metadata_init (Metadata *metadata) gimp_metadata_viewer_init (GimpMetadataViewer *self)
{ {
} }
@ -242,11 +205,10 @@ metadata_viewer_dialog (GimpImage *image,
GtkWidget *metadata_vbox; GtkWidget *metadata_vbox;
GtkWidget *notebook; GtkWidget *notebook;
GtkWidget *scrolled_win; GtkWidget *scrolled_win;
GtkWidget *list_view; GtkWidget *list_box;
GtkWidget *label; GtkWidget *label;
GtkListStore *exif_store, *xmp_store, *iptc_store; GtkSizeGroup *tag_size_group;
GtkCellRenderer *rend; GListStore *exif_store, *xmp_store, *iptc_store;
GtkTreeViewColumn *col;
GExiv2Metadata *metadata; GExiv2Metadata *metadata;
metadata = GEXIV2_METADATA(g_metadata); metadata = GEXIV2_METADATA(g_metadata);
@ -288,36 +250,21 @@ metadata_viewer_dialog (GimpImage *image,
gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6); gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6);
gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN); gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN);
exif_store = gtk_list_store_new (NUM_EXIF_COLS, exif_store = g_list_store_new (GIMP_TYPE_METADATA_TAG_OBJECT);
G_TYPE_STRING, /* column-name c_exif_tag */ list_box = gtk_list_box_new ();
G_TYPE_STRING); /* column-name c_exif_value */ gtk_list_box_set_selection_mode (GTK_LIST_BOX (list_box),
list_view = gtk_tree_view_new_with_model (GTK_TREE_MODEL (exif_store)); GTK_SELECTION_NONE);
gtk_widget_set_vexpand (list_view, TRUE); tag_size_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
gtk_list_box_bind_model (GTK_LIST_BOX (list_box), G_LIST_MODEL (exif_store),
rend = gtk_cell_renderer_text_new (); create_widget_for_tag_object, tag_size_group, g_object_unref);
col = gtk_tree_view_column_new_with_attributes (_("Exif Tag"), gtk_widget_set_vexpand (list_box, TRUE);
rend,
"text", C_EXIF_TAG,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
rend = gtk_cell_renderer_text_new ();
col = gtk_tree_view_column_new_with_attributes (C_("A tag value", "Value"),
rend,
"text", C_EXIF_VALUE,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
label = gtk_label_new (_("Exif")); label = gtk_label_new (_("Exif"));
gtk_widget_show (label); gtk_widget_show (label);
gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label); gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label);
gtk_container_add (GTK_CONTAINER (scrolled_win), list_view); gtk_container_add (GTK_CONTAINER (scrolled_win), list_box);
gtk_widget_show (list_view); gtk_widget_show (list_box);
gtk_widget_show (scrolled_win); gtk_widget_show (scrolled_win);
/* XMP tab */ /* XMP tab */
@ -326,36 +273,21 @@ metadata_viewer_dialog (GimpImage *image,
gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6); gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6);
gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN); gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN);
xmp_store = gtk_list_store_new (NUM_XMP_COLS, xmp_store = g_list_store_new (GIMP_TYPE_METADATA_TAG_OBJECT);
G_TYPE_STRING, /* column-name c_xmp_tag */ list_box = gtk_list_box_new ();
G_TYPE_STRING); /* column-name c_xmp_value */ gtk_list_box_set_selection_mode (GTK_LIST_BOX (list_box),
list_view = gtk_tree_view_new_with_model (GTK_TREE_MODEL (xmp_store)); GTK_SELECTION_NONE);
gtk_widget_set_vexpand (list_view, TRUE); tag_size_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
gtk_list_box_bind_model (GTK_LIST_BOX (list_box), G_LIST_MODEL (xmp_store),
rend = gtk_cell_renderer_text_new (); create_widget_for_tag_object, tag_size_group, g_object_unref);
col = gtk_tree_view_column_new_with_attributes (_("XMP Tag"), gtk_widget_set_vexpand (list_box, TRUE);
rend,
"text", C_XMP_TAG,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
rend = gtk_cell_renderer_text_new ();
col = gtk_tree_view_column_new_with_attributes (C_("A tag value", "Value"),
rend,
"text", C_XMP_VALUE,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
label = gtk_label_new (_("XMP")); label = gtk_label_new (_("XMP"));
gtk_widget_show (label); gtk_widget_show (label);
gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label); gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label);
gtk_container_add (GTK_CONTAINER (scrolled_win), list_view); gtk_container_add (GTK_CONTAINER (scrolled_win), list_box);
gtk_widget_show (list_view); gtk_widget_show (list_box);
gtk_widget_show (scrolled_win); gtk_widget_show (scrolled_win);
/* IPTC tab */ /* IPTC tab */
@ -364,41 +296,26 @@ metadata_viewer_dialog (GimpImage *image,
gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6); gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 6);
gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN); gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_win), GTK_SHADOW_IN);
iptc_store = gtk_list_store_new (NUM_IPTC_COLS, iptc_store = g_list_store_new (GIMP_TYPE_METADATA_TAG_OBJECT);
G_TYPE_STRING, /* column-name c_iptc_tag */ list_box = gtk_list_box_new ();
G_TYPE_STRING); /* column-name c_iptc_value */ gtk_list_box_set_selection_mode (GTK_LIST_BOX (list_box),
list_view = gtk_tree_view_new_with_model (GTK_TREE_MODEL (iptc_store)); GTK_SELECTION_NONE);
gtk_widget_set_vexpand (list_view, TRUE); tag_size_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
gtk_list_box_bind_model (GTK_LIST_BOX (list_box), G_LIST_MODEL (iptc_store),
rend = gtk_cell_renderer_text_new (); create_widget_for_tag_object, tag_size_group, g_object_unref);
col = gtk_tree_view_column_new_with_attributes (_("IPTC Tag"), gtk_widget_set_vexpand (list_box, TRUE);
rend,
"text", C_IPTC_TAG,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
rend = gtk_cell_renderer_text_new ();
col = gtk_tree_view_column_new_with_attributes (C_("A tag value", "Value"),
rend,
"text", C_IPTC_VALUE,
NULL);
gtk_tree_view_column_set_resizable (col, TRUE);
gtk_tree_view_column_set_spacing (col, 3);
gtk_tree_view_append_column (GTK_TREE_VIEW (list_view), col);
label = gtk_label_new (_("IPTC")); label = gtk_label_new (_("IPTC"));
gtk_widget_show (label); gtk_widget_show (label);
gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label); gtk_notebook_append_page (GTK_NOTEBOOK (notebook), scrolled_win, label);
gtk_container_add (GTK_CONTAINER (scrolled_win), list_view); gtk_container_add (GTK_CONTAINER (scrolled_win), list_box);
gtk_widget_show (list_view); gtk_widget_show (list_box);
gtk_widget_show (scrolled_win); gtk_widget_show (scrolled_win);
gtk_widget_show (notebook); gtk_widget_show (notebook);
/* Add the metadata to the tree views */ /* Add the metadata to the list models */
metadata_dialog_set_metadata (metadata, exif_store, xmp_store, iptc_store); metadata_dialog_set_metadata (metadata, exif_store, xmp_store, iptc_store);
g_object_unref (exif_store); g_object_unref (exif_store);
@ -415,34 +332,66 @@ metadata_viewer_dialog (GimpImage *image,
static void static void
metadata_dialog_set_metadata (GExiv2Metadata *metadata, metadata_dialog_set_metadata (GExiv2Metadata *metadata,
GtkListStore *exif_store, GListStore *exif_store,
GtkListStore *xmp_store, GListStore *xmp_store,
GtkListStore *iptc_store) GListStore *iptc_store)
{ {
gchar **tags; gchar **tags;
/* load exif tags */ /* load exif tags */
tags = gexiv2_metadata_get_exif_tags (metadata); tags = gexiv2_metadata_get_exif_tags (metadata);
metadata_dialog_append_tags (metadata, tags, exif_store, C_EXIF_TAG, C_EXIF_VALUE, FALSE); metadata_dialog_append_tags (metadata, tags, exif_store, FALSE);
g_strfreev (tags); g_strfreev (tags);
/* load xmp tags */ /* load xmp tags */
tags = gexiv2_metadata_get_xmp_tags (metadata); tags = gexiv2_metadata_get_xmp_tags (metadata);
metadata_dialog_append_tags (metadata, tags, xmp_store, C_XMP_TAG, C_XMP_VALUE, FALSE); metadata_dialog_append_tags (metadata, tags, xmp_store, FALSE);
g_strfreev (tags); g_strfreev (tags);
/* load iptc tags */ /* load iptc tags */
tags = gexiv2_metadata_get_iptc_tags (metadata); tags = gexiv2_metadata_get_iptc_tags (metadata);
metadata_dialog_append_tags (metadata, tags, iptc_store, C_IPTC_TAG, C_IPTC_VALUE, TRUE); metadata_dialog_append_tags (metadata, tags, iptc_store, TRUE);
g_strfreev (tags); g_strfreev (tags);
} }
static GtkWidget *
create_widget_for_tag_object (gpointer item,
gpointer user_data)
{
GimpMetadataTagObject *tag_obj = GIMP_METADATA_TAG_OBJECT (item);
GtkSizeGroup *tag_size_group = GTK_SIZE_GROUP (user_data);
GtkWidget *row;
GtkWidget *box;
GtkWidget *tag_label;
GtkWidget *value_label;
row = gtk_list_box_row_new ();
gtk_widget_show (row);
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6);
gtk_container_add (GTK_CONTAINER (row), box);
gtk_widget_show (box);
tag_label = gtk_label_new (gimp_metadata_tag_object_get_tag (tag_obj));
gtk_label_set_xalign (GTK_LABEL (tag_label), 0.0);
gtk_size_group_add_widget (tag_size_group, tag_label);
gtk_widget_show (tag_label);
gtk_box_pack_start (GTK_BOX (box), tag_label, FALSE, FALSE, 6);
value_label = gtk_label_new (gimp_metadata_tag_object_get_value (tag_obj));
gtk_label_set_selectable (GTK_LABEL (value_label), TRUE);
gtk_widget_show (value_label);
gtk_box_pack_start (GTK_BOX (box), value_label, FALSE, FALSE, 6);
return row;
}
static gchar * static gchar *
metadata_format_string_value (const gchar *value, metadata_format_string_value (const gchar *value,
gboolean truncate) gboolean truncate)
@ -497,29 +446,23 @@ metadata_tag_is_string (const gchar *tag)
} }
static void static void
metadata_dialog_add_tag (GtkListStore *store, metadata_dialog_add_tag (GListStore *store,
gint tag_column,
gint value_column,
const gchar *tag, const gchar *tag,
const gchar *value) const gchar *value)
{ {
if (value) GimpMetadataTagObject *tag_object;
{
GtkTreeIter iter;
gtk_list_store_append (store, &iter); if (value == NULL)
gtk_list_store_set (store, &iter, return;
tag_column, tag,
value_column, value, tag_object = gimp_metadata_tag_object_new (tag, value);
-1); g_list_store_append (store, tag_object);
} g_object_unref (tag_object);
} }
static void static void
metadata_dialog_add_translated_tag (GExiv2Metadata *metadata, metadata_dialog_add_translated_tag (GExiv2Metadata *metadata,
GtkListStore *store, GListStore *store,
gint tag_column,
gint value_column,
const gchar *tag) const gchar *tag)
{ {
gchar *value = NULL; gchar *value = NULL;
@ -533,8 +476,7 @@ metadata_dialog_add_translated_tag (GExiv2Metadata *metadata,
g_clear_error (&error); g_clear_error (&error);
} }
metadata_dialog_add_tag (store, tag_column, value_column, metadata_dialog_add_tag (store, tag, gettext (value));
tag, gettext (value));
g_free (value); g_free (value);
} }
@ -574,9 +516,7 @@ metadata_interpret_user_comment (gchar *comment)
static void static void
metadata_dialog_add_multiple_values (GExiv2Metadata *metadata, metadata_dialog_add_multiple_values (GExiv2Metadata *metadata,
const gchar *tag, const gchar *tag,
GtkListStore *store, GListStore *store)
gint tag_column,
gint value_column)
{ {
gchar **values; gchar **values;
GError *error = NULL; GError *error = NULL;
@ -589,37 +529,25 @@ metadata_dialog_add_multiple_values (GExiv2Metadata *metadata,
g_clear_error (&error); g_clear_error (&error);
} }
if (values) if (values == NULL)
{ return;
gint i;
for (i = 0; values[i] != NULL; i++) for (gsize i = 0; values[i] != NULL; i++)
{ {
gchar *value; gchar *value;
GtkTreeIter iter;
gtk_list_store_append (store, &iter);
value = metadata_format_string_value (values[i], /* truncate = */ TRUE); value = metadata_format_string_value (values[i], /* truncate = */ TRUE);
metadata_dialog_add_tag (store, tag, value);
gtk_list_store_set (store, &iter,
tag_column, tag,
value_column, value,
-1);
g_free (value); g_free (value);
} }
g_strfreev (values); g_strfreev (values);
} }
}
static void static void
metadata_dialog_append_tags (GExiv2Metadata *metadata, metadata_dialog_append_tags (GExiv2Metadata *metadata,
gchar **tags, gchar **tags,
GtkListStore *store, GListStore *store,
gint tag_column,
gint value_column,
gboolean load_iptc) gboolean load_iptc)
{ {
const gchar *tag; const gchar *tag;
@ -646,9 +574,7 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
last_tag = tag; last_tag = tag;
metadata_dialog_add_multiple_values (GEXIV2_METADATA (metadata), metadata_dialog_add_multiple_values (GEXIV2_METADATA (metadata),
tag, store, tag, store);
tag_column,
value_column);
} }
else if (! strcmp ("Exif.GPSInfo.GPSLongitude", tag) || else if (! strcmp ("Exif.GPSInfo.GPSLongitude", tag) ||
! strcmp ("Exif.GPSInfo.GPSLongitudeRef", tag) || ! strcmp ("Exif.GPSInfo.GPSLongitudeRef", tag) ||
@ -671,7 +597,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
{ {
str = metadata_format_gps_longitude_latitude (lng); str = metadata_format_gps_longitude_latitude (lng);
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store,
tag_column, value_column,
"Exif.GPSInfo.GPSLongitude", "Exif.GPSInfo.GPSLongitude",
str); str);
g_free (str); g_free (str);
@ -684,7 +609,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
} }
metadata_dialog_add_translated_tag (metadata, store, metadata_dialog_add_translated_tag (metadata, store,
tag_column, value_column,
"Exif.GPSInfo.GPSLongitudeRef"); "Exif.GPSInfo.GPSLongitudeRef");
if (gexiv2_metadata_try_get_gps_latitude (GEXIV2_METADATA (metadata), if (gexiv2_metadata_try_get_gps_latitude (GEXIV2_METADATA (metadata),
@ -692,7 +616,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
{ {
str = metadata_format_gps_longitude_latitude (lat); str = metadata_format_gps_longitude_latitude (lat);
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store,
tag_column, value_column,
"Exif.GPSInfo.GPSLatitude", "Exif.GPSInfo.GPSLatitude",
str); str);
g_free (str); g_free (str);
@ -705,7 +628,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
} }
metadata_dialog_add_translated_tag (metadata, store, metadata_dialog_add_translated_tag (metadata, store,
tag_column, value_column,
"Exif.GPSInfo.GPSLatitudeRef"); "Exif.GPSInfo.GPSLatitudeRef");
if (gexiv2_metadata_try_get_gps_altitude (GEXIV2_METADATA (metadata), if (gexiv2_metadata_try_get_gps_altitude (GEXIV2_METADATA (metadata),
@ -718,7 +640,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
str2 = metadata_format_gps_altitude (alt, FALSE, _(" feet")); str2 = metadata_format_gps_altitude (alt, FALSE, _(" feet"));
str3 = g_strdup_printf ("%s (%s)", str, str2); str3 = g_strdup_printf ("%s (%s)", str, str2);
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store,
tag_column, value_column,
"Exif.GPSInfo.GPSAltitude", "Exif.GPSInfo.GPSAltitude",
str3); str3);
g_free (str); g_free (str);
@ -746,7 +667,6 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
else else
index = 0; index = 0;
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store,
tag_column, value_column,
"Exif.GPSInfo.GPSAltitudeRef", "Exif.GPSInfo.GPSAltitudeRef",
gettext (gpsaltref[index])); gettext (gpsaltref[index]));
g_free (value); g_free (value);
@ -776,9 +696,7 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
/* Can start with charset. Remove part that is not relevant. */ /* Can start with charset. Remove part that is not relevant. */
value = metadata_interpret_user_comment (value); value = metadata_interpret_user_comment (value);
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store, tag, value);
tag_column, value_column,
tag, value);
g_free (value); g_free (value);
} }
else else
@ -798,18 +716,14 @@ metadata_dialog_append_tags (GExiv2Metadata *metadata,
else if (g_strcmp0 (tag_type, "XmpText") != 0) else if (g_strcmp0 (tag_type, "XmpText") != 0)
{ {
metadata_dialog_add_multiple_values (GEXIV2_METADATA (metadata), metadata_dialog_add_multiple_values (GEXIV2_METADATA (metadata),
tag, store, tag, store);
tag_column,
value_column);
continue; continue;
} }
} }
value = metadata_dialog_format_tag_value (metadata, tag, value = metadata_dialog_format_tag_value (metadata, tag,
/* truncate = */ TRUE); /* truncate = */ TRUE);
metadata_dialog_add_tag (store, metadata_dialog_add_tag (store, tag, value);
tag_column, value_column,
tag, value);
g_free (value); g_free (value);
} }
} }