[gtk+] Drop GtkWidgetAuxInfo



commit 8a540ea0d0d49d8caea6e603565a8d6ea822d62f
Author: Matthias Clasen <mclasen redhat com>
Date:   Sat Sep 12 23:56:39 2015 -0400

    Drop GtkWidgetAuxInfo
    
    Merge it into GtkWidgetPrivate. In my measurements, about half
    of all widgets have a non-default auxinfo struct, and we use this
    information in size allocation, so it is nice to avoid the gdata
    overhead.

 gtk/gtkwidget.c        |  294 ++++++++++++-----------------------------------
 gtk/gtkwidgetprivate.h |   49 +++-----
 2 files changed, 93 insertions(+), 250 deletions(-)
---
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index a162ffa..ef279f4 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -722,10 +722,6 @@ static void             gtk_widget_real_state_flags_changed     (GtkWidget
                                                                  GtkStateFlags     old_state);
 static void             gtk_widget_real_queue_draw_region       (GtkWidget         *widget,
                                                                 const cairo_region_t *region);
-static const GtkWidgetAuxInfo* _gtk_widget_get_aux_info_or_defaults (GtkWidget *widget);
-static GtkWidgetAuxInfo* gtk_widget_get_aux_info                (GtkWidget        *widget,
-                                                                 gboolean          create);
-static void            gtk_widget_aux_info_destroy             (GtkWidgetAuxInfo *aux_info);
 static AtkObject*      gtk_widget_real_get_accessible          (GtkWidget        *widget);
 static void            gtk_widget_accessible_interface_init    (AtkImplementorIface *iface);
 static AtkObject*      gtk_widget_ref_accessible               (AtkImplementor *implementor);
@@ -841,7 +837,6 @@ GtkTextDirection gtk_default_direction = GTK_TEXT_DIR_LTR;
 static GParamSpecPool  *style_property_spec_pool = NULL;
 
 static GQuark          quark_property_parser = 0;
-static GQuark          quark_aux_info = 0;
 static GQuark          quark_accel_path = 0;
 static GQuark          quark_accel_closures = 0;
 static GQuark          quark_event_mask = 0;
@@ -1013,7 +1008,6 @@ gtk_widget_class_init (GtkWidgetClass *klass)
   gtk_widget_parent_class = g_type_class_peek_parent (klass);
 
   quark_property_parser = g_quark_from_static_string ("gtk-rc-property-parser");
-  quark_aux_info = g_quark_from_static_string ("gtk-aux-info");
   quark_accel_path = g_quark_from_static_string ("gtk-accel-path");
   quark_accel_closures = g_quark_from_static_string ("gtk-accel-closures");
   quark_event_mask = g_quark_from_static_string ("gtk-event-mask");
@@ -3970,20 +3964,10 @@ gtk_widget_get_property (GObject         *object,
       g_value_set_int (value, gtk_widget_get_margin_bottom (widget));
       break;
     case PROP_MARGIN:
-      {
-        GtkWidgetAuxInfo *aux_info = gtk_widget_get_aux_info (widget, FALSE);
-        if (aux_info == NULL)
-          {
-            g_value_set_int (value, 0);
-          }
-        else
-          {
-            g_value_set_int (value, MAX (MAX (aux_info->margin.left,
-                                              aux_info->margin.right),
-                                         MAX (aux_info->margin.top,
-                                              aux_info->margin.bottom)));
-          }
-      }
+      g_value_set_int (value, MAX (MAX (priv->margin.left,
+                                        priv->margin.right),
+                                   MAX (priv->margin.top,
+                                        priv->margin.bottom)));
       break;
     case PROP_HEXPAND:
       g_value_set_boolean (value, gtk_widget_get_hexpand (widget));
@@ -4345,7 +4329,7 @@ gtk_widget_init (GTypeInstance *instance, gpointer g_class)
   priv->double_buffered = TRUE;
   priv->redraw_on_alloc = TRUE;
   priv->alloc_needed = TRUE;
-   
+ 
   switch (_gtk_widget_get_direction (widget))
     {
     case GTK_TEXT_DIR_LTR:
@@ -4362,7 +4346,6 @@ gtk_widget_init (GTypeInstance *instance, gpointer g_class)
       break;
     }
 
-
   /* this will be set to TRUE if the widget gets a child or if the
    * expand flag is set on the widget, but until one of those happen
    * we know the expand is already properly FALSE.
@@ -4372,6 +4355,12 @@ gtk_widget_init (GTypeInstance *instance, gpointer g_class)
    */
   priv->need_compute_expand = FALSE;
 
+  priv->halign = GTK_ALIGN_FILL;
+  priv->valign = GTK_ALIGN_FILL;
+
+  priv->width = -1;
+  priv->height = -1;
+
   _gtk_size_request_cache_init (&priv->requests);
 
   priv->cssnode = gtk_css_widget_node_new (widget);
@@ -6320,40 +6309,34 @@ gtk_widget_real_adjust_size_allocation (GtkWidget         *widget,
                                         gint              *allocated_pos,
                                         gint              *allocated_size)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
+  GtkWidgetPrivate *priv = widget->priv;
 
   if (orientation == GTK_ORIENTATION_HORIZONTAL)
     {
-      adjust_for_margin (aux_info->margin.left,
-                         aux_info->margin.right,
+      adjust_for_margin (priv->margin.left,
+                         priv->margin.right,
                          minimum_size, natural_size,
                          allocated_pos, allocated_size);
-      adjust_for_align (effective_align (aux_info->halign, _gtk_widget_get_direction (widget)),
+      adjust_for_align (effective_align (priv->halign, _gtk_widget_get_direction (widget)),
                         natural_size, allocated_pos, allocated_size);
     }
   else
     {
-      adjust_for_margin (aux_info->margin.top,
-                         aux_info->margin.bottom,
+      adjust_for_margin (priv->margin.top,
+                         priv->margin.bottom,
                          minimum_size, natural_size,
                          allocated_pos, allocated_size);
-      adjust_for_align (effective_align (aux_info->valign, GTK_TEXT_DIR_NONE),
+      adjust_for_align (effective_align (priv->valign, GTK_TEXT_DIR_NONE),
                         natural_size, allocated_pos, allocated_size);
     }
 }
 
 static void
-gtk_widget_real_adjust_baseline_allocation (GtkWidget         *widget,
-                                           gint              *baseline)
+gtk_widget_real_adjust_baseline_allocation (GtkWidget *widget,
+                                           gint      *baseline)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
-
   if (*baseline >= 0)
-    *baseline -= aux_info->margin.top;
+    *baseline -= widget->priv->margin.top;
 }
 
 static gboolean
@@ -10977,25 +10960,23 @@ gtk_widget_set_usize_internal (GtkWidget          *widget,
                               gint                height,
                               GtkQueueResizeFlags flags)
 {
-  GtkWidgetAuxInfo *aux_info;
+  GtkWidgetPrivate *priv = widget->priv;
   gboolean changed = FALSE;
 
   g_object_freeze_notify (G_OBJECT (widget));
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
-  if (width > -2 && aux_info->width != width)
+  if (width > -2 && priv->width != width)
     {
       if ((flags & GTK_QUEUE_RESIZE_INVALIDATE_ONLY) == 0)
        g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_WIDTH_REQUEST]);
-      aux_info->width = width;
+      priv->width = width;
       changed = TRUE;
     }
-  if (height > -2 && aux_info->height != height)
+  if (height > -2 && priv->height != height)
     {
       if ((flags & GTK_QUEUE_RESIZE_INVALIDATE_ONLY) == 0)
        g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_HEIGHT_REQUEST]);
-      aux_info->height = height;
+      priv->height = height;
       changed = TRUE;
     }
 
@@ -11084,17 +11065,13 @@ gtk_widget_get_size_request (GtkWidget *widget,
                              gint      *width,
                              gint      *height)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
   g_return_if_fail (GTK_IS_WIDGET (widget));
 
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
-
   if (width)
-    *width = aux_info->width;
+    *width = widget->priv->width;
 
   if (height)
-    *height = aux_info->height;
+    *height = widget->priv->height;
 }
 
 /*< private >
@@ -11107,11 +11084,7 @@ gtk_widget_get_size_request (GtkWidget *widget,
 gboolean
 gtk_widget_has_size_request (GtkWidget *widget)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
-
-  return !(aux_info->width == -1 && aux_info->height == -1);
+  return !(widget->priv->width == -1 && widget->priv->height == -1);
 }
 
 /**
@@ -12198,7 +12171,6 @@ gtk_widget_finalize (GObject *object)
 {
   GtkWidget *widget = GTK_WIDGET (object);
   GtkWidgetPrivate *priv = widget->priv;
-  GtkWidgetAuxInfo *aux_info;
   GtkAccessible *accessible;
   GList *l;
 
@@ -12208,10 +12180,6 @@ gtk_widget_finalize (GObject *object)
 
   g_free (priv->name);
 
-  aux_info = gtk_widget_get_aux_info (widget, FALSE);
-  if (aux_info)
-    gtk_widget_aux_info_destroy (aux_info);
-
   accessible = g_object_get_qdata (G_OBJECT (widget), quark_accessible_object);
   if (accessible)
     g_object_unref (accessible);
@@ -12360,25 +12328,17 @@ gtk_widget_real_unrealize (GtkWidget *widget)
 }
 
 static void
-gtk_widget_real_adjust_size_request (GtkWidget         *widget,
-                                     GtkOrientation     orientation,
-                                     gint              *minimum_size,
-                                     gint              *natural_size)
+gtk_widget_real_adjust_size_request (GtkWidget      *widget,
+                                     GtkOrientation  orientation,
+                                     gint           *minimum_size,
+                                     gint           *natural_size)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
-  aux_info =_gtk_widget_get_aux_info_or_defaults (widget);
+  GtkWidgetPrivate *priv = widget->priv;
 
-  if (orientation == GTK_ORIENTATION_HORIZONTAL &&
-      aux_info->width > 0)
-    {
-      *minimum_size = MAX (*minimum_size, aux_info->width);
-    }
-  else if (orientation == GTK_ORIENTATION_VERTICAL &&
-           aux_info->height > 0)
-    {
-      *minimum_size = MAX (*minimum_size, aux_info->height);
-    }
+  if (orientation == GTK_ORIENTATION_HORIZONTAL && priv->width > 0)
+    *minimum_size = MAX (*minimum_size, priv->width);
+  else if (orientation == GTK_ORIENTATION_VERTICAL && priv->height > 0)
+    *minimum_size = MAX (*minimum_size, priv->height);
 
   /* Fix it if set_size_request made natural size smaller than min size.
    * This would also silently fix broken widgets, but we warn about them
@@ -12388,26 +12348,24 @@ gtk_widget_real_adjust_size_request (GtkWidget         *widget,
 
   if (orientation == GTK_ORIENTATION_HORIZONTAL)
     {
-      *minimum_size += (aux_info->margin.left + aux_info->margin.right);
-      *natural_size += (aux_info->margin.left + aux_info->margin.right);
+      *minimum_size += priv->margin.left + priv->margin.right;
+      *natural_size += priv->margin.left + priv->margin.right;
     }
   else
     {
-      *minimum_size += (aux_info->margin.top + aux_info->margin.bottom);
-      *natural_size += (aux_info->margin.top + aux_info->margin.bottom);
+      *minimum_size += priv->margin.top + priv->margin.bottom;
+      *natural_size += priv->margin.top + priv->margin.bottom;
     }
 }
 
 static void
-gtk_widget_real_adjust_baseline_request (GtkWidget         *widget,
-                                        gint              *minimum_baseline,
-                                        gint              *natural_baseline)
+gtk_widget_real_adjust_baseline_request (GtkWidget *widget,
+                                        gint      *minimum_baseline,
+                                        gint      *natural_baseline)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
-  aux_info =_gtk_widget_get_aux_info_or_defaults (widget);
+  GtkWidgetPrivate *priv = widget->priv;
 
-  if (aux_info->height >= 0)
+  if (priv->height >= 0)
     {
       /* No baseline support for explicitly set height */
       *minimum_baseline = -1;
@@ -12415,8 +12373,8 @@ gtk_widget_real_adjust_baseline_request (GtkWidget         *widget,
     }
   else
     {
-      *minimum_baseline += aux_info->margin.top;
-      *natural_baseline += aux_info->margin.top;
+      *minimum_baseline += priv->margin.top;
+      *natural_baseline += priv->margin.top;
     }
 }
 
@@ -12848,72 +12806,6 @@ gtk_widget_propagate_state (GtkWidget    *widget,
     }
 }
 
-static const GtkWidgetAuxInfo default_aux_info = {
-  -1, -1,
-  GTK_ALIGN_FILL,
-  GTK_ALIGN_FILL,
-  { 0, 0, 0, 0 }
-};
-
-/*
- * gtk_widget_get_aux_info:
- * @widget: a #GtkWidget
- * @create: if %TRUE, create the #GtkWidgetAuxInfo-struct if it doesn’t exist
- *
- * Get the #GtkWidgetAuxInfo-struct for the widget.
- *
- * Returns: the #GtkWidgetAuxInfo-struct for the widget, or
- *    %NULL if @create is %FALSE and one doesn’t already exist.
- */
-static GtkWidgetAuxInfo *
-gtk_widget_get_aux_info (GtkWidget *widget,
-                        gboolean   create)
-{
-  GtkWidgetAuxInfo *aux_info;
-
-  aux_info = g_object_get_qdata (G_OBJECT (widget), quark_aux_info);
-  if (!aux_info && create)
-    {
-      aux_info = g_slice_new0 (GtkWidgetAuxInfo);
-
-      *aux_info = default_aux_info;
-
-      g_object_set_qdata (G_OBJECT (widget), quark_aux_info, aux_info);
-    }
-
-  return aux_info;
-}
-
-static const GtkWidgetAuxInfo*
-_gtk_widget_get_aux_info_or_defaults (GtkWidget *widget)
-{
-  GtkWidgetAuxInfo *aux_info;
-
-  aux_info = gtk_widget_get_aux_info (widget, FALSE);
-  if (aux_info == NULL)
-    {
-      return &default_aux_info;
-    }
-  else
-    {
-      return aux_info;
-    }
-}
-
-/*****************************************
- * gtk_widget_aux_info_destroy:
- *
- *   arguments:
- *
- *   results:
- *****************************************/
-
-static void
-gtk_widget_aux_info_destroy (GtkWidgetAuxInfo *aux_info)
-{
-  g_slice_free (GtkWidgetAuxInfo, aux_info);
-}
-
 /**
  * gtk_widget_shape_combine_region:
  * @widget: a #GtkWidget
@@ -14637,7 +14529,7 @@ gtk_widget_get_halign (GtkWidget *widget)
 
   g_return_val_if_fail (GTK_IS_WIDGET (widget), GTK_ALIGN_FILL);
 
-  align = _gtk_widget_get_aux_info_or_defaults (widget)->halign;
+  align = widget->priv->halign;
   if (align == GTK_ALIGN_BASELINE)
     return GTK_ALIGN_FILL;
   return align;
@@ -14655,16 +14547,12 @@ void
 gtk_widget_set_halign (GtkWidget *widget,
                        GtkAlign   align)
 {
-  GtkWidgetAuxInfo *aux_info;
-
   g_return_if_fail (GTK_IS_WIDGET (widget));
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
-  if (aux_info->halign == align)
+  if (widget->priv->halign == align)
     return;
 
-  aux_info->halign = align;
+  widget->priv->halign = align;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_HALIGN]);
 }
@@ -14684,7 +14572,7 @@ GtkAlign
 gtk_widget_get_valign_with_baseline (GtkWidget *widget)
 {
   g_return_val_if_fail (GTK_IS_WIDGET (widget), GTK_ALIGN_FILL);
-  return _gtk_widget_get_aux_info_or_defaults (widget)->valign;
+  return widget->priv->valign;
 }
 
 /**
@@ -14725,16 +14613,12 @@ void
 gtk_widget_set_valign (GtkWidget *widget,
                        GtkAlign   align)
 {
-  GtkWidgetAuxInfo *aux_info;
-
   g_return_if_fail (GTK_IS_WIDGET (widget));
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
-  if (aux_info->valign == align)
+  if (widget->priv->valign == align)
     return;
 
-  aux_info->valign = align;
+  widget->priv->valign = align;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_VALIGN]);
 }
@@ -14756,7 +14640,7 @@ gtk_widget_get_margin_left (GtkWidget *widget)
 {
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  return _gtk_widget_get_aux_info_or_defaults (widget)->margin.left;
+  return widget->priv->margin.left;
 }
 
 /**
@@ -14775,20 +14659,17 @@ void
 gtk_widget_set_margin_left (GtkWidget *widget,
                             gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
   gboolean rtl;
 
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
   rtl = _gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL;
 
-  if (aux_info->margin.left == margin)
+  if (widget->priv->margin.left == margin)
     return;
 
-  aux_info->margin.left = margin;
+  widget->priv->margin.left = margin;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_MARGIN_LEFT]);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[rtl ? PROP_MARGIN_END : PROP_MARGIN_START]);
@@ -14811,7 +14692,7 @@ gtk_widget_get_margin_right (GtkWidget *widget)
 {
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  return _gtk_widget_get_aux_info_or_defaults (widget)->margin.right;
+  return widget->priv->margin.right;
 }
 
 /**
@@ -14830,20 +14711,17 @@ void
 gtk_widget_set_margin_right (GtkWidget *widget,
                              gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
   gboolean rtl;
 
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
   rtl = _gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL;
 
-  if (aux_info->margin.right == margin)
+  if (widget->priv->margin.right == margin)
     return;
 
-  aux_info->margin.right = margin;
+  widget->priv->margin.right = margin;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_MARGIN_RIGHT]);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[rtl ? PROP_MARGIN_START : PROP_MARGIN_END]);
@@ -14862,16 +14740,12 @@ gtk_widget_set_margin_right (GtkWidget *widget,
 gint
 gtk_widget_get_margin_start (GtkWidget *widget)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
-
   if (_gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
-    return aux_info->margin.right;
+    return widget->priv->margin.right;
   else
-    return aux_info->margin.left;
+    return widget->priv->margin.left;
 }
 
 /**
@@ -14888,21 +14762,18 @@ void
 gtk_widget_set_margin_start (GtkWidget *widget,
                              gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
   gint16 *start;
   gboolean rtl;
 
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
   rtl = _gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL;
 
   if (rtl)
-    start = &aux_info->margin.right;
+    start = &widget->priv->margin.right;
   else
-    start = &aux_info->margin.left;
+    start = &widget->priv->margin.left;
 
   if (*start == margin)
     return;
@@ -14926,16 +14797,12 @@ gtk_widget_set_margin_start (GtkWidget *widget,
 gint
 gtk_widget_get_margin_end (GtkWidget *widget)
 {
-  const GtkWidgetAuxInfo *aux_info;
-
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  aux_info = _gtk_widget_get_aux_info_or_defaults (widget);
-
   if (_gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
-    return aux_info->margin.left;
+    return widget->priv->margin.left;
   else
-    return aux_info->margin.right;
+    return widget->priv->margin.right;
 }
 
 /**
@@ -14952,21 +14819,18 @@ void
 gtk_widget_set_margin_end (GtkWidget *widget,
                            gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
   gint16 *end;
   gboolean rtl;
 
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
   rtl = _gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL;
 
   if (rtl)
-    end = &aux_info->margin.left;
+    end = &widget->priv->margin.left;
   else
-    end = &aux_info->margin.right;
+    end = &widget->priv->margin.right;
 
   if (*end == margin)
     return;
@@ -14992,7 +14856,7 @@ gtk_widget_get_margin_top (GtkWidget *widget)
 {
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  return _gtk_widget_get_aux_info_or_defaults (widget)->margin.top;
+  return widget->priv->margin.top;
 }
 
 /**
@@ -15009,17 +14873,13 @@ void
 gtk_widget_set_margin_top (GtkWidget *widget,
                            gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
-
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
-  if (aux_info->margin.top == margin)
+  if (widget->priv->margin.top == margin)
     return;
 
-  aux_info->margin.top = margin;
+  widget->priv->margin.top = margin;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_MARGIN_TOP]);
 }
@@ -15039,7 +14899,7 @@ gtk_widget_get_margin_bottom (GtkWidget *widget)
 {
   g_return_val_if_fail (GTK_IS_WIDGET (widget), 0);
 
-  return _gtk_widget_get_aux_info_or_defaults (widget)->margin.bottom;
+  return widget->priv->margin.bottom;
 }
 
 /**
@@ -15056,17 +14916,13 @@ void
 gtk_widget_set_margin_bottom (GtkWidget *widget,
                               gint       margin)
 {
-  GtkWidgetAuxInfo *aux_info;
-
   g_return_if_fail (GTK_IS_WIDGET (widget));
   g_return_if_fail (margin <= G_MAXINT16);
 
-  aux_info = gtk_widget_get_aux_info (widget, TRUE);
-
-  if (aux_info->margin.bottom == margin)
+  if (widget->priv->margin.bottom == margin)
     return;
 
-  aux_info->margin.bottom = margin;
+  widget->priv->margin.bottom = margin;
   gtk_widget_queue_resize (widget);
   g_object_notify_by_pspec (G_OBJECT (widget), widget_props[PROP_MARGIN_BOTTOM]);
 }
diff --git a/gtk/gtkwidgetprivate.h b/gtk/gtkwidgetprivate.h
index 3621b5a..5063604 100644
--- a/gtk/gtkwidgetprivate.h
+++ b/gtk/gtkwidgetprivate.h
@@ -36,27 +36,6 @@ G_BEGIN_DECLS
 
 #define GTK_STATE_FLAGS_BITS 12
 
-/**
- * GtkWidgetAuxInfo:
- * @width: the widget’s width
- * @height: the widget’s height
- * @halign: the widget’s horizontal alignment
- * @valign: the widget’s horizontal alignment
- * @margin: the widget’s #GtkBorder margins
- *
- */
-typedef struct _GtkWidgetAuxInfo GtkWidgetAuxInfo;
-struct _GtkWidgetAuxInfo
-{
-  gint width;
-  gint height;
-
-  guint   halign : 4;
-  guint   valign : 4;
-
-  GtkBorder margin;
-};
-
 struct _GtkWidgetPrivate
 {
   /* The state of the widget. Needs to be able to hold all GtkStateFlags bits
@@ -107,9 +86,26 @@ struct _GtkWidgetPrivate
   /* SizeGroup related flags */
   guint have_size_groups      : 1;
 
+  /* Alignment */
+  guint   halign              : 4;
+  guint   valign              : 4;
+
   guint8 alpha;
   guint8 user_alpha;
 
+#ifdef G_ENABLE_CONSISTENCY_CHECKS
+  /* Number of gtk_widget_push_verify_invariants () */
+  guint8 verifying_invariants_count;
+#endif
+
+  gint width;
+  gint height;
+  GtkBorder margin;
+
+  /* Animations and other things to update on clock ticks */
+  guint clock_tick_id;
+  GList *tick_callbacks;
+
   /* The widget's name. If the widget does not have a name
    * (the name is NULL), then its name (as returned by
    * "gtk_widget_get_name") is its class's name.
@@ -135,13 +131,8 @@ struct _GtkWidgetPrivate
 
   /* The widget's allocated size */
   GtkAllocation allocation;
-  gint allocated_baseline;
   GtkAllocation clip;
-
-#ifdef G_ENABLE_DEBUG
-  /* Number of gtk_widget_push_verify_invariants () */
-  guint verifying_invariants_count;
-#endif /* G_ENABLE_DEBUG */
+  gint allocated_baseline;
 
   /* The widget's requested sizes */
   SizeRequestCache requests;
@@ -156,10 +147,6 @@ struct _GtkWidgetPrivate
   /* The widget's parent */
   GtkWidget *parent;
 
-  /* Animations and other things to update on clock ticks */
-  GList *tick_callbacks;
-  guint clock_tick_id;
-
   GList *event_controllers;
 };
 


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