summaryrefslogtreecommitdiff
path: root/gtk/gtktreeviewcolumn.c
diff options
context:
space:
mode:
Diffstat (limited to 'gtk/gtktreeviewcolumn.c')
-rw-r--r--gtk/gtktreeviewcolumn.c62
1 files changed, 31 insertions, 31 deletions
diff --git a/gtk/gtktreeviewcolumn.c b/gtk/gtktreeviewcolumn.c
index 5001217fc0..487b44b849 100644
--- a/gtk/gtktreeviewcolumn.c
+++ b/gtk/gtktreeviewcolumn.c
@@ -2094,48 +2094,48 @@ gtk_tree_view_column_get_x_offset (GtkTreeViewColumn *tree_column)
return tree_column->priv->x_offset;
}
-void
-_gtk_tree_view_column_request_width (GtkTreeViewColumn *tree_column,
- gint *minimum,
- gint *natural)
+gint
+_gtk_tree_view_column_request_width (GtkTreeViewColumn *tree_column)
{
- GtkTreeViewColumnPrivate *priv = tree_column->priv;
- gint minimum_width = 1, natural_width = 1;
- gint button_minimum, button_natural;
+ GtkTreeViewColumnPrivate *priv;
+ gint real_requested_width;
- if (priv->column_type != GTK_TREE_VIEW_COLUMN_FIXED)
- {
- gtk_cell_area_context_get_preferred_width (priv->cell_area_context, &minimum_width, &natural_width);
- minimum_width += priv->padding;
- natural_width += priv->padding;
+ priv = tree_column->priv;
- if (gtk_tree_view_get_headers_visible (GTK_TREE_VIEW (priv->tree_view)))
- {
- gtk_widget_get_preferred_width (priv->button, &button_minimum, &button_natural);
- minimum_width = MAX (minimum_width, button_minimum);
- natural_width = MAX (natural_width, button_natural);
- }
+ if (priv->fixed_width != -1)
+ {
+ real_requested_width = priv->fixed_width;
}
+ else if (gtk_tree_view_get_headers_visible (GTK_TREE_VIEW (priv->tree_view)))
+ {
+ gint button_request;
+ gint requested_width;
- if (priv->fixed_width != -1)
- natural_width = MAX (priv->fixed_width, minimum_width);
+ gtk_cell_area_context_get_preferred_width (priv->cell_area_context, &requested_width, NULL);
+ requested_width += priv->padding;
- if (priv->min_width != -1)
+ gtk_widget_get_preferred_width (priv->button, &button_request, NULL);
+ real_requested_width = MAX (requested_width, button_request);
+ }
+ else
{
- minimum_width = MAX (minimum_width, priv->min_width);
- natural_width = MAX (natural_width, priv->min_width);
+ gint requested_width;
+
+ gtk_cell_area_context_get_preferred_width (priv->cell_area_context, &requested_width, NULL);
+ requested_width += priv->padding;
+
+ real_requested_width = requested_width;
+ if (real_requested_width < 0)
+ real_requested_width = 0;
}
+ if (priv->min_width != -1)
+ real_requested_width = MAX (real_requested_width, priv->min_width);
+
if (priv->max_width != -1)
- {
- minimum_width = MIN (minimum_width, priv->max_width);
- natural_width = MIN (natural_width, priv->max_width);
- }
+ real_requested_width = MIN (real_requested_width, priv->max_width);
- if (minimum != NULL)
- *minimum = minimum_width;
- if (natural != NULL)
- *natural = natural_width;
+ return real_requested_width;
}
void