X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=gtk%2Fgtktreeview.c;h=4544c6f6da614c1c7f31bc43bb8659e8c0226bac;hb=af0007d0d89309838fb55cc62c76793b574fa40a;hp=af7b8a0888fd2c1dcb77589c0fd3584acef45ced;hpb=c6bbfc8e3d4eab0bb1c3cb2a5d5bd2eef234c3bd;p=~andy%2Fgtk diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c index af7b8a088..4544c6f6d 100644 --- a/gtk/gtktreeview.c +++ b/gtk/gtktreeview.c @@ -239,7 +239,6 @@ typedef enum { #define GTK_TREE_VIEW_PRIORITY_SCROLL_SYNC (GTK_TREE_VIEW_PRIORITY_VALIDATE + 2) #define GTK_TREE_VIEW_TIME_MS_PER_IDLE 30 #define SCROLL_EDGE_SIZE 15 -#define EXPANDER_EXTRA_PADDING 4 #define GTK_TREE_VIEW_SEARCH_DIALOG_TIMEOUT 5000 #define AUTO_EXPAND_TIMEOUT 500 @@ -2865,13 +2864,14 @@ static int gtk_tree_view_get_expander_size (GtkTreeView *tree_view) { gint expander_size; + gint horizontal_separator; gtk_widget_style_get (GTK_WIDGET (tree_view), "expander-size", &expander_size, + "horizontal-separator", &horizontal_separator, NULL); - expander_size += EXPANDER_EXTRA_PADDING; - return expander_size; + return expander_size + (horizontal_separator / 2); } static gboolean @@ -9240,12 +9240,19 @@ gtk_tree_view_get_arrow_xrange (GtkTreeView *tree_view, GList *list; GtkTreeViewColumn *tmp_column = NULL; gint total_width; - gint expander_size; + gint expander_size, expander_render_size; + gint horizontal_separator; gboolean indent_expanders; gboolean rtl; + gtk_widget_style_get (GTK_WIDGET (tree_view), + "indent-expanders", &indent_expanders, + "horizontal-separator", &horizontal_separator, + NULL); + rtl = (gtk_widget_get_direction (GTK_WIDGET (tree_view)) == GTK_TEXT_DIR_RTL); expander_size = gtk_tree_view_get_expander_size (tree_view); + expander_render_size = expander_size - (horizontal_separator / 2); total_width = 0; for (list = (rtl ? g_list_last (tree_view->priv->columns) : g_list_first (tree_view->priv->columns)); @@ -9267,9 +9274,7 @@ gtk_tree_view_get_arrow_xrange (GtkTreeView *tree_view, total_width += gtk_tree_view_column_get_width (tmp_column); } - gtk_widget_style_get (GTK_WIDGET (tree_view), - "indent-expanders", &indent_expanders, - NULL); + x_offset += (expander_size - expander_render_size); if (indent_expanders) { @@ -9284,7 +9289,7 @@ gtk_tree_view_get_arrow_xrange (GtkTreeView *tree_view, if (tmp_column && gtk_tree_view_column_get_visible (tmp_column)) /* +1 because x2 isn't included in the range. */ - *x2 = *x1 + expander_size + 1; + *x2 = *x1 + expander_render_size + 1; else *x2 = *x1; } @@ -10083,7 +10088,6 @@ gtk_tree_view_draw_arrow (GtkTreeView *tree_view, gint x_offset = 0; gint x2; gint vertical_separator; - gint expander_size; GtkCellRendererState flags = 0; widget = GTK_WIDGET (tree_view); @@ -10092,7 +10096,6 @@ gtk_tree_view_draw_arrow (GtkTreeView *tree_view, gtk_widget_style_get (widget, "vertical-separator", &vertical_separator, NULL); - expander_size = gtk_tree_view_get_expander_size (tree_view) - EXPANDER_EXTRA_PADDING; if (! GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_IS_PARENT)) return; @@ -10102,7 +10105,7 @@ gtk_tree_view_draw_arrow (GtkTreeView *tree_view, area.x = x_offset; area.y = gtk_tree_view_get_cell_area_y_offset (tree_view, tree, node, vertical_separator); - area.width = expander_size; + area.width = x2 - x_offset; area.height = gtk_tree_view_get_cell_area_height (tree_view, node, vertical_separator); @@ -11962,8 +11965,6 @@ gtk_tree_view_remove_column (GtkTreeView *tree_view, G_CALLBACK (column_sizing_notify), tree_view); - _gtk_tree_view_column_unset_tree_view (column); - position = g_list_index (tree_view->priv->columns, column); tree_view->priv->columns = g_list_remove (tree_view->priv->columns, column); @@ -11991,7 +11992,7 @@ gtk_tree_view_remove_column (GtkTreeView *tree_view, } _gtk_tree_view_reset_header_styles (tree_view); - + _gtk_tree_view_column_unset_tree_view (column); _gtk_tree_view_accessible_remove_column (tree_view, column, position); g_object_unref (column); @@ -13237,7 +13238,8 @@ gtk_tree_view_real_set_cursor (GtkTreeView *tree_view, GTK_CELL_RENDERER_FOCUSED); } - g_signal_emit (tree_view, tree_view_signals[CURSOR_CHANGED], 0); + if (!gtk_widget_in_destruction (GTK_WIDGET (tree_view))) + g_signal_emit (tree_view, tree_view_signals[CURSOR_CHANGED], 0); } /**