[gimp] Move gimp_edit_paste_as_new() to gimp_image_new_from_buffer()
- From: Michael Natterer <mitch src gnome org>
- To: svn-commits-list gnome org
- Cc:
- Subject: [gimp] Move gimp_edit_paste_as_new() to gimp_image_new_from_buffer()
- Date: Tue, 9 Feb 2010 21:41:51 +0000 (UTC)
commit 6e49a0fa5dedcf6522b88a21cae1c3e219760e5e
Author: Michael Natterer <mitch gimp org>
Date: Mon Feb 8 15:19:03 2010 +0100
Move gimp_edit_paste_as_new() to gimp_image_new_from_buffer()
because it better fits there, and it's never actually been a "paste"
from the implementation point of view.
app/actions/buffers-commands.c | 13 +++-----
app/actions/edit-commands.c | 12 +++-----
app/core/gimp-edit.c | 59 ----------------------------------------
app/core/gimp-edit.h | 3 --
app/core/gimpimage-new.c | 56 +++++++++++++++++++++++++++++++++++++
app/core/gimpimage-new.h | 3 ++
app/pdb/edit-cmds.c | 5 ++-
app/widgets/gimptoolbox-dnd.c | 12 +++-----
tools/pdbgen/pdb/edit.pdb | 5 ++-
9 files changed, 79 insertions(+), 89 deletions(-)
---
diff --git a/app/actions/buffers-commands.c b/app/actions/buffers-commands.c
index 25020b0..f288adb 100644
--- a/app/actions/buffers-commands.c
+++ b/app/actions/buffers-commands.c
@@ -27,6 +27,7 @@
#include "core/gimpcontainer.h"
#include "core/gimpcontext.h"
#include "core/gimpimage.h"
+#include "core/gimpimage-new.h"
#include "widgets/gimpbufferview.h"
#include "widgets/gimpcontainerview.h"
@@ -85,14 +86,10 @@ buffers_paste_as_new_cmd_callback (GtkAction *action,
{
GimpImage *new_image;
- new_image = gimp_edit_paste_as_new (image->gimp, image, buffer);
-
- if (new_image)
- {
- gimp_create_display (image->gimp, new_image,
- GIMP_UNIT_PIXEL, 1.0);
- g_object_unref (new_image);
- }
+ new_image = gimp_image_new_from_buffer (image->gimp, image, buffer);
+ gimp_create_display (image->gimp, new_image,
+ GIMP_UNIT_PIXEL, 1.0);
+ g_object_unref (new_image);
}
}
}
diff --git a/app/actions/edit-commands.c b/app/actions/edit-commands.c
index 08b3560..55409e9 100644
--- a/app/actions/edit-commands.c
+++ b/app/actions/edit-commands.c
@@ -34,6 +34,7 @@
#include "core/gimpdrawable.h"
#include "core/gimplayer.h"
#include "core/gimpimage.h"
+#include "core/gimpimage-new.h"
#include "core/gimpimage-undo.h"
#include "vectors/gimpvectors-import.h"
@@ -311,15 +312,12 @@ edit_paste_as_new_cmd_callback (GtkAction *action,
{
GimpImage *image;
- image = gimp_edit_paste_as_new (gimp, action_data_get_image (data),
- buffer);
+ image = gimp_image_new_from_buffer (gimp, action_data_get_image (data),
+ buffer);
g_object_unref (buffer);
- if (image)
- {
- gimp_create_display (image->gimp, image, GIMP_UNIT_PIXEL, 1.0);
- g_object_unref (image);
- }
+ gimp_create_display (image->gimp, image, GIMP_UNIT_PIXEL, 1.0);
+ g_object_unref (image);
}
else
{
diff --git a/app/core/gimp-edit.c b/app/core/gimp-edit.c
index e87e099..0016d94 100644
--- a/app/core/gimp-edit.c
+++ b/app/core/gimp-edit.c
@@ -281,65 +281,6 @@ gimp_edit_paste (GimpImage *image,
return layer;
}
-GimpImage *
-gimp_edit_paste_as_new (Gimp *gimp,
- GimpImage *invoke,
- GimpBuffer *paste)
-{
- GimpImage *image;
- GimpLayer *layer;
- GimpImageType type;
-
- g_return_val_if_fail (GIMP_IS_GIMP (gimp), NULL);
- g_return_val_if_fail (invoke == NULL || GIMP_IS_IMAGE (invoke), NULL);
- g_return_val_if_fail (GIMP_IS_BUFFER (paste), NULL);
-
- switch (tile_manager_bpp (paste->tiles))
- {
- case 1: type = GIMP_GRAY_IMAGE; break;
- case 2: type = GIMP_GRAYA_IMAGE; break;
- case 3: type = GIMP_RGB_IMAGE; break;
- case 4: type = GIMP_RGBA_IMAGE; break;
- default:
- g_return_val_if_reached (NULL);
- break;
- }
-
- /* create a new image (always of type GIMP_RGB) */
- image = gimp_create_image (gimp,
- gimp_buffer_get_width (paste),
- gimp_buffer_get_height (paste),
- GIMP_IMAGE_TYPE_BASE_TYPE (type),
- TRUE);
- gimp_image_undo_disable (image);
-
- if (invoke)
- {
- gdouble xres;
- gdouble yres;
-
- gimp_image_get_resolution (invoke, &xres, &yres);
- gimp_image_set_resolution (image, xres, yres);
- gimp_image_set_unit (image, gimp_image_get_unit (invoke));
- }
-
- layer = gimp_layer_new_from_tiles (paste->tiles, image, type,
- _("Pasted Layer"),
- GIMP_OPACITY_OPAQUE, GIMP_NORMAL_MODE);
-
- if (! layer)
- {
- g_object_unref (image);
- return NULL;
- }
-
- gimp_image_add_layer (image, layer, NULL, 0, TRUE);
-
- gimp_image_undo_enable (image);
-
- return image;
-}
-
const gchar *
gimp_edit_named_cut (GimpImage *image,
const gchar *name,
diff --git a/app/core/gimp-edit.h b/app/core/gimp-edit.h
index e79935a..a9e3e6a 100644
--- a/app/core/gimp-edit.h
+++ b/app/core/gimp-edit.h
@@ -38,9 +38,6 @@ GimpLayer * gimp_edit_paste (GimpImage *image,
gint viewport_y,
gint viewport_width,
gint viewport_height);
-GimpImage * gimp_edit_paste_as_new (Gimp *gimp,
- GimpImage *image,
- GimpBuffer *paste);
const gchar * gimp_edit_named_cut (GimpImage *image,
const gchar *name,
diff --git a/app/core/gimpimage-new.c b/app/core/gimpimage-new.c
index f7e0d46..9c46a8f 100644
--- a/app/core/gimpimage-new.c
+++ b/app/core/gimpimage-new.c
@@ -24,9 +24,12 @@
#include "core-types.h"
+#include "base/tile-manager.h"
+
#include "config/gimpcoreconfig.h"
#include "gimp.h"
+#include "gimpbuffer.h"
#include "gimpchannel.h"
#include "gimpimage.h"
#include "gimpimage-colormap.h"
@@ -184,6 +187,59 @@ gimp_image_new_from_component (Gimp *gimp,
}
GimpImage *
+gimp_image_new_from_buffer (Gimp *gimp,
+ GimpImage *invoke,
+ GimpBuffer *paste)
+{
+ GimpImage *image;
+ GimpLayer *layer;
+ GimpImageType type;
+
+ g_return_val_if_fail (GIMP_IS_GIMP (gimp), NULL);
+ g_return_val_if_fail (invoke == NULL || GIMP_IS_IMAGE (invoke), NULL);
+ g_return_val_if_fail (GIMP_IS_BUFFER (paste), NULL);
+
+ switch (tile_manager_bpp (paste->tiles))
+ {
+ case 1: type = GIMP_GRAY_IMAGE; break;
+ case 2: type = GIMP_GRAYA_IMAGE; break;
+ case 3: type = GIMP_RGB_IMAGE; break;
+ case 4: type = GIMP_RGBA_IMAGE; break;
+ default:
+ g_return_val_if_reached (NULL);
+ break;
+ }
+
+ /* create a new image (always of type GIMP_RGB) */
+ image = gimp_create_image (gimp,
+ gimp_buffer_get_width (paste),
+ gimp_buffer_get_height (paste),
+ GIMP_IMAGE_TYPE_BASE_TYPE (type),
+ TRUE);
+ gimp_image_undo_disable (image);
+
+ if (invoke)
+ {
+ gdouble xres;
+ gdouble yres;
+
+ gimp_image_get_resolution (invoke, &xres, &yres);
+ gimp_image_set_resolution (image, xres, yres);
+ gimp_image_set_unit (image, gimp_image_get_unit (invoke));
+ }
+
+ layer = gimp_layer_new_from_tiles (paste->tiles, image, type,
+ _("Pasted Layer"),
+ GIMP_OPACITY_OPAQUE, GIMP_NORMAL_MODE);
+
+ gimp_image_add_layer (image, layer, NULL, 0, TRUE);
+
+ gimp_image_undo_enable (image);
+
+ return image;
+}
+
+GimpImage *
gimp_image_new_from_pixbuf (Gimp *gimp,
GdkPixbuf *pixbuf,
const gchar *layer_name)
diff --git a/app/core/gimpimage-new.h b/app/core/gimpimage-new.h
index 12617be..1786157 100644
--- a/app/core/gimpimage-new.h
+++ b/app/core/gimpimage-new.h
@@ -29,6 +29,9 @@ GimpImage * gimp_image_new_from_drawable (Gimp *gimp,
GimpImage * gimp_image_new_from_component (Gimp *gimp,
GimpImage *image,
GimpChannelType component);
+GimpImage * gimp_image_new_from_buffer (Gimp *gimp,
+ GimpImage *invoke,
+ GimpBuffer *paste);
GimpImage * gimp_image_new_from_pixbuf (Gimp *gimp,
GdkPixbuf *pixbuf,
const gchar *layer_name);
diff --git a/app/pdb/edit-cmds.c b/app/pdb/edit-cmds.c
index 15faa01..6a26fe8 100644
--- a/app/pdb/edit-cmds.c
+++ b/app/pdb/edit-cmds.c
@@ -31,6 +31,7 @@
#include "core/gimpdrawable-blend.h"
#include "core/gimpdrawable-bucket-fill.h"
#include "core/gimpdrawable.h"
+#include "core/gimpimage-new.h"
#include "core/gimpimage.h"
#include "core/gimplayer.h"
#include "core/gimpparamspecs.h"
@@ -233,7 +234,7 @@ edit_paste_as_new_invoker (GimpProcedure *procedure,
if (gimp->global_buffer)
{
- image = gimp_edit_paste_as_new (gimp, NULL, gimp->global_buffer);
+ image = gimp_image_new_from_buffer (gimp, NULL, gimp->global_buffer);
if (! image)
success = FALSE;
@@ -470,7 +471,7 @@ edit_named_paste_as_new_invoker (GimpProcedure *procedure,
if (buffer)
{
- image = gimp_edit_paste_as_new (gimp, NULL, buffer);
+ image = gimp_image_new_from_buffer (gimp, NULL, buffer);
if (! image)
success = FALSE;
diff --git a/app/widgets/gimptoolbox-dnd.c b/app/widgets/gimptoolbox-dnd.c
index 6405bd1..3a1be5a 100644
--- a/app/widgets/gimptoolbox-dnd.c
+++ b/app/widgets/gimptoolbox-dnd.c
@@ -27,7 +27,6 @@
#include "widgets-types.h"
#include "core/gimp.h"
-#include "core/gimp-edit.h"
#include "core/gimpbuffer.h"
#include "core/gimpcontext.h"
#include "core/gimpimage.h"
@@ -232,13 +231,10 @@ gimp_toolbox_drop_buffer (GtkWidget *widget,
if (context->gimp->busy)
return;
- image = gimp_edit_paste_as_new (context->gimp, NULL, GIMP_BUFFER (viewable));
-
- if (image)
- {
- gimp_create_display (image->gimp, image, GIMP_UNIT_PIXEL, 1.0);
- g_object_unref (image);
- }
+ image = gimp_image_new_from_buffer (context->gimp, NULL,
+ GIMP_BUFFER (viewable));
+ gimp_create_display (image->gimp, image, GIMP_UNIT_PIXEL, 1.0);
+ g_object_unref (image);
}
static void
diff --git a/tools/pdbgen/pdb/edit.pdb b/tools/pdbgen/pdb/edit.pdb
index 51946d0..fa97246 100644
--- a/tools/pdbgen/pdb/edit.pdb
+++ b/tools/pdbgen/pdb/edit.pdb
@@ -239,7 +239,7 @@ HELP
{
if (gimp->global_buffer)
{
- image = gimp_edit_paste_as_new (gimp, NULL, gimp->global_buffer);
+ image = gimp_image_new_from_buffer (gimp, NULL, gimp->global_buffer);
if (! image)
success = FALSE;
@@ -482,7 +482,7 @@ HELP
if (buffer)
{
- image = gimp_edit_paste_as_new (gimp, NULL, buffer);
+ image = gimp_image_new_from_buffer (gimp, NULL, buffer);
if (! image)
success = FALSE;
@@ -917,6 +917,7 @@ CODE
"core/gimp.h"
"core/gimp-edit.h"
"core/gimpimage.h"
+ "core/gimpimage-new.h"
"core/gimpprogress.h"
"gimppdb-utils.h"
"gimp-intl.h");
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]