[gimp/soc-2010-cage-2] app: some GimpImageWindow cleanup



commit f5b752dc0831ccf9645e2331b482b68c4b7ec2b7
Author: Michael Natterer <mitch gimp org>
Date:   Fri Nov 26 09:19:36 2010 +0100

    app: some GimpImageWindow cleanup
    
    - implement GObject::constructed() instead of ::construct()
    - remove the display pause/resume idle hack because any tool
      drawing flickering is gone now by using cairo
    - some formatting cleanup
    - remove some unused local variables

 app/display/gimpimagewindow.c |   73 +++++++++++++++--------------------------
 1 files changed, 27 insertions(+), 46 deletions(-)
---
diff --git a/app/display/gimpimagewindow.c b/app/display/gimpimagewindow.c
index 428d9d0..d792c2e 100644
--- a/app/display/gimpimagewindow.c
+++ b/app/display/gimpimagewindow.c
@@ -55,6 +55,7 @@
 #include "gimp-log.h"
 #include "gimp-intl.h"
 
+
 #define GIMP_EMPTY_IMAGE_WINDOW_ENTRY_ID  "gimp-empty-image-window"
 #define GIMP_SINGLE_IMAGE_WINDOW_ENTRY_ID "gimp-single-image-window"
 
@@ -109,9 +110,7 @@ typedef struct
 
 /*  local function prototypes  */
 
-static GObject * gimp_image_window_constructor         (GType                type,
-                                                        guint                n_params,
-                                                        GObjectConstructParam *params);
+static void      gimp_image_window_constructed         (GObject             *object);
 static void      gimp_image_window_dispose             (GObject             *object);
 static void      gimp_image_window_finalize            (GObject             *object);
 static void      gimp_image_window_set_property        (GObject             *object,
@@ -152,7 +151,6 @@ static void      gimp_image_window_hide_tooltip        (GimpUIManager       *man
                                                         GimpImageWindow     *window);
 static void      gimp_image_window_update_ui_manager   (GimpImageWindow     *window);
 
-static gboolean  gimp_image_window_resume_shell        (GimpDisplayShell    *shell);
 static void      gimp_image_window_shell_size_allocate (GimpDisplayShell    *shell,
                                                         GtkAllocation       *allocation,
                                                         PosCorrectionData   *data);
@@ -203,7 +201,7 @@ gimp_image_window_class_init (GimpImageWindowClass *klass)
   GObjectClass   *object_class = G_OBJECT_CLASS (klass);
   GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
 
-  object_class->constructor        = gimp_image_window_constructor;
+  object_class->constructed        = gimp_image_window_constructed;
   object_class->dispose            = gimp_image_window_dispose;
   object_class->finalize           = gimp_image_window_finalize;
   object_class->set_property       = gimp_image_window_set_property;
@@ -246,20 +244,12 @@ gimp_image_window_init (GimpImageWindow *window)
   gtk_window_set_resizable (GTK_WINDOW (window), TRUE);
 }
 
-static GObject *
-gimp_image_window_constructor (GType                  type,
-                               guint                  n_params,
-                               GObjectConstructParam *params)
+static void
+gimp_image_window_constructed (GObject *object)
 {
-  GObject                *object;
+  GimpImageWindow        *window  = GIMP_IMAGE_WINDOW (object);
+  GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (window);
   GimpGuiConfig          *config;
-  GimpImageWindow        *window;
-  GimpImageWindowPrivate *private;
-
-  object = G_OBJECT_CLASS (parent_class)->constructor (type, n_params, params);
-
-  window  = GIMP_IMAGE_WINDOW (object);
-  private = GIMP_IMAGE_WINDOW_GET_PRIVATE (window);
 
   g_assert (GIMP_IS_UI_MANAGER (private->menubar_manager));
 
@@ -375,21 +365,18 @@ gimp_image_window_constructor (GType                  type,
                            window, G_CONNECT_SWAPPED);
 
   private->entry_id = gimp_image_window_config_to_entry_id (config);
-
-  return object;
 }
 
 static void
 gimp_image_window_dispose (GObject *object)
 {
-  GimpImageWindow        *window  = GIMP_IMAGE_WINDOW (object);
-  GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (window);
+  GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (object);
 
   if (private->dialog_factory)
     {
       g_signal_handlers_disconnect_by_func (private->dialog_factory,
                                             gimp_image_window_update_ui_manager,
-                                            window);
+                                            object);
       private->dialog_factory = NULL;
     }
 
@@ -405,8 +392,7 @@ gimp_image_window_dispose (GObject *object)
 static void
 gimp_image_window_finalize (GObject *object)
 {
-  GimpImageWindow        *window  = GIMP_IMAGE_WINDOW (object);
-  GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (window);
+  GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (object);
 
   if (private->menubar_manager)
     {
@@ -1080,24 +1066,22 @@ gimp_image_window_keep_canvas_pos (GimpImageWindow *window)
   gint               image_origin_window_y = -1;
   PosCorrectionData *data                  = NULL;
 
-  /* Freeze the active tool until the UI has stabilized. If it draws
-   * while we hide widgets there will be flicker
-   */
-  gimp_display_shell_pause (shell);
-  g_idle_add ((GSourceFunc) gimp_image_window_resume_shell, shell);
-
   gimp_display_shell_transform_xy (shell,
                                    0.0, 0.0,
-                                   &image_origin_shell_x, &image_origin_shell_y);
+                                   &image_origin_shell_x,
+                                   &image_origin_shell_y);
   gtk_widget_translate_coordinates (GTK_WIDGET (shell->canvas),
                                     GTK_WIDGET (window),
-                                    image_origin_shell_x, image_origin_shell_y,
-                                    &image_origin_window_x, &image_origin_window_y);
+                                    image_origin_shell_x,
+                                    image_origin_shell_y,
+                                    &image_origin_window_x,
+                                    &image_origin_window_y);
 
   data         = g_new0 (PosCorrectionData, 1);
   data->window = window;
   data->x      = image_origin_window_x;
   data->y      = image_origin_window_y;
+
   g_signal_connect_data (shell, "size-allocate",
                          G_CALLBACK (gimp_image_window_shell_size_allocate),
                          data, (GClosureNotify) g_free,
@@ -1170,21 +1154,15 @@ static void
 gimp_image_window_update_ui_manager (GimpImageWindow *window)
 {
   GimpImageWindowPrivate *private = GIMP_IMAGE_WINDOW_GET_PRIVATE (window);
-  gimp_ui_manager_update (private->menubar_manager, private->active_shell->display);
-}
 
-static gboolean
-gimp_image_window_resume_shell (GimpDisplayShell *shell)
-{
-  gimp_display_shell_resume (shell);
-
-  return FALSE;
+  gimp_ui_manager_update (private->menubar_manager,
+                          private->active_shell->display);
 }
 
 static void
 gimp_image_window_shell_size_allocate (GimpDisplayShell  *shell,
-                                         GtkAllocation     *allocation,
-                                         PosCorrectionData *data)
+                                       GtkAllocation     *allocation,
+                                       PosCorrectionData *data)
 {
   GimpImageWindow *window               = data->window;
   gint             image_origin_shell_x = -1;
@@ -1193,13 +1171,16 @@ gimp_image_window_shell_size_allocate (GimpDisplayShell  *shell,
   gtk_widget_translate_coordinates (GTK_WIDGET (window),
                                     GTK_WIDGET (shell->canvas),
                                     data->x, data->y,
-                                    &image_origin_shell_x, &image_origin_shell_y);
+                                    &image_origin_shell_x,
+                                    &image_origin_shell_y);
 
   /* Note that the shell offset isn't the offset of the image into the
    * shell, but the offset of the shell relative to the image,
-   * therefor we need to negate
+   * therefore we need to negate
    */
-  gimp_display_shell_scroll_set_offset (shell, -image_origin_shell_x, -image_origin_shell_y);
+  gimp_display_shell_scroll_set_offset (shell,
+                                        -image_origin_shell_x,
+                                        -image_origin_shell_y);
 
   g_signal_handlers_disconnect_by_func (shell,
                                         gimp_image_window_shell_size_allocate,



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]