[gimp/wip/gradient-edit: 10/35] app: add gimp_data_copy()
- From: N/A <ell src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/wip/gradient-edit: 10/35] app: add gimp_data_copy()
- Date: Fri, 4 Aug 2017 14:50:36 +0000 (UTC)
commit 1ee8cb966a059074f7bcb234b229f4320abcc01c
Author: Ell <ell_se yahoo com>
Date: Wed Jul 26 13:42:21 2017 -0400
app: add gimp_data_copy()
... which copies the contents of a GimpData into an existing GimpData,
without creating a new instance.
Add a copy() virtual function to GimpData, which subclasses can
override to implement copying; gimp_data_copy() may only be called
for types that implement copy(). Keep the duplicate() virtual
function around, but provide a default implementation that creates
a new object of the source type, and uses copy() to copy the source
object into it.
app/core/gimpdata.c | 93 ++++++++++++++++++++++++++++++++++++---------------
app/core/gimpdata.h | 4 ++
2 files changed, 70 insertions(+), 27 deletions(-)
---
diff --git a/app/core/gimpdata.c b/app/core/gimpdata.c
index b3fc5d3..f037d2d 100644
--- a/app/core/gimpdata.c
+++ b/app/core/gimpdata.c
@@ -77,38 +77,39 @@ struct _GimpDataPrivate
G_TYPE_INSTANCE_GET_PRIVATE (data, GIMP_TYPE_DATA, GimpDataPrivate)
-static void gimp_data_class_init (GimpDataClass *klass);
-static void gimp_data_tagged_iface_init (GimpTaggedInterface *iface);
+static void gimp_data_class_init (GimpDataClass *klass);
+static void gimp_data_tagged_iface_init (GimpTaggedInterface *iface);
-static void gimp_data_init (GimpData *data,
- GimpDataClass *data_class);
+static void gimp_data_init (GimpData *data,
+ GimpDataClass *data_class);
-static void gimp_data_constructed (GObject *object);
-static void gimp_data_finalize (GObject *object);
-static void gimp_data_set_property (GObject *object,
- guint property_id,
- const GValue *value,
- GParamSpec *pspec);
-static void gimp_data_get_property (GObject *object,
- guint property_id,
- GValue *value,
- GParamSpec *pspec);
+static void gimp_data_constructed (GObject *object);
+static void gimp_data_finalize (GObject *object);
+static void gimp_data_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec);
+static void gimp_data_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec);
-static void gimp_data_name_changed (GimpObject *object);
-static gint64 gimp_data_get_memsize (GimpObject *object,
- gint64 *gui_size);
+static void gimp_data_name_changed (GimpObject *object);
+static gint64 gimp_data_get_memsize (GimpObject *object,
+ gint64 *gui_size);
-static gboolean gimp_data_is_name_editable (GimpViewable *viewable);
+static gboolean gimp_data_is_name_editable (GimpViewable *viewable);
-static void gimp_data_real_dirty (GimpData *data);
+static void gimp_data_real_dirty (GimpData *data);
+static GimpData * gimp_data_real_duplicate (GimpData *data);
-static gboolean gimp_data_add_tag (GimpTagged *tagged,
- GimpTag *tag);
-static gboolean gimp_data_remove_tag (GimpTagged *tagged,
- GimpTag *tag);
-static GList * gimp_data_get_tags (GimpTagged *tagged);
-static gchar * gimp_data_get_identifier (GimpTagged *tagged);
-static gchar * gimp_data_get_checksum (GimpTagged *tagged);
+static gboolean gimp_data_add_tag (GimpTagged *tagged,
+ GimpTag *tag);
+static gboolean gimp_data_remove_tag (GimpTagged *tagged,
+ GimpTag *tag);
+static GList * gimp_data_get_tags (GimpTagged *tagged);
+static gchar * gimp_data_get_identifier (GimpTagged *tagged);
+static gchar * gimp_data_get_checksum (GimpTagged *tagged);
static guint data_signals[LAST_SIGNAL] = { 0 };
@@ -185,7 +186,8 @@ gimp_data_class_init (GimpDataClass *klass)
klass->dirty = gimp_data_real_dirty;
klass->save = NULL;
klass->get_extension = NULL;
- klass->duplicate = NULL;
+ klass->copy = NULL;
+ klass->duplicate = gimp_data_real_duplicate;
g_object_class_install_property (object_class, PROP_FILE,
g_param_spec_object ("file", NULL, NULL,
@@ -379,6 +381,21 @@ gimp_data_real_dirty (GimpData *data)
gimp_object_name_changed (GIMP_OBJECT (data));
}
+static GimpData *
+gimp_data_real_duplicate (GimpData *data)
+{
+ if (GIMP_DATA_GET_CLASS (data)->copy)
+ {
+ GimpData *new = g_object_new (G_OBJECT_TYPE (data), NULL);
+
+ gimp_data_copy (new, data);
+
+ return new;
+ }
+
+ return NULL;
+}
+
static gboolean
gimp_data_add_tag (GimpTagged *tagged,
GimpTag *tag)
@@ -1073,6 +1090,28 @@ gimp_data_get_mtime (GimpData *data)
}
/**
+ * gimp_data_copy:
+ * @data: a #GimpData object
+ * @src_data: the #GimpData object to copy from
+ *
+ * Copies @src_data to @data. Only the object data is copied: the
+ * name, file name, preview, etc. are not copied.
+ **/
+void
+gimp_data_copy (GimpData *data,
+ GimpData *src_data)
+{
+ g_return_if_fail (GIMP_IS_DATA (data));
+ g_return_if_fail (GIMP_IS_DATA (src_data));
+ g_return_if_fail (GIMP_DATA_GET_CLASS (data)->copy != NULL);
+ g_return_if_fail (GIMP_DATA_GET_CLASS (data)->copy ==
+ GIMP_DATA_GET_CLASS (src_data)->copy);
+
+ if (data != src_data)
+ GIMP_DATA_GET_CLASS (data)->copy (data, src_data);
+}
+
+/**
* gimp_data_duplicate:
* @data: a #GimpData object
*
diff --git a/app/core/gimpdata.h b/app/core/gimpdata.h
index 77454ce..08536fb 100644
--- a/app/core/gimpdata.h
+++ b/app/core/gimpdata.h
@@ -61,6 +61,8 @@ struct _GimpDataClass
GOutputStream *output,
GError **error);
const gchar * (* get_extension) (GimpData *data);
+ void (* copy) (GimpData *data,
+ GimpData *src_data);
GimpData * (* duplicate) (GimpData *data);
};
@@ -104,6 +106,8 @@ void gimp_data_set_mtime (GimpData *data,
gint64 mtime);
gint64 gimp_data_get_mtime (GimpData *data);
+void gimp_data_copy (GimpData *data,
+ GimpData *src_data);
GimpData * gimp_data_duplicate (GimpData *data);
void gimp_data_make_internal (GimpData *data,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]