diff options
author | Kristian Rietveld <kris@imendio.com> | 2006-06-02 18:55:59 +0000 |
---|---|---|
committer | Kristian Rietveld <kristian@src.gnome.org> | 2006-06-02 18:55:59 +0000 |
commit | a70e666423928276c87632e7aef594ff68b6abfa (patch) | |
tree | 8da974f9ab6f78565b7fa33ee9d88b0617a5c6c7 /gtk/gtktreeselection.c | |
parent | 3180e4535629b9872819923bf59f2f97f17217ac (diff) | |
download | gtk+-a70e666423928276c87632e7aef594ff68b6abfa.tar.gz |
Separate sensitive/selectable properties.
2006-06-02 Kristian Rietveld <kris@imendio.com>
Separate sensitive/selectable properties.
* gtk/gtktreeselection.c (tree_column_is_sensitive): remove,
(_gtk_tree_selection_row_is_selectable): remove checks to see if at
least one column is sensitive,
(gtk_tree_selection_real_select_node): remove code which enables
insensitive rows to always be unselected.
* gtk/gtktreeview.c (gtk_tree_view_row_changed): remove code
that unselects a node if it just became insensitive.
* gtk/gtkcombobox.c (gtkcombo_box_list_select_func): new function,
based on the at least one column sensitive check from
_gtk_tree_selection_row_is_selectable(),
(gtk_combo_box_list_setup): set selection function on tree selection.
Diffstat (limited to 'gtk/gtktreeselection.c')
-rw-r--r-- | gtk/gtktreeselection.c | 51 |
1 files changed, 1 insertions, 50 deletions
diff --git a/gtk/gtktreeselection.c b/gtk/gtktreeselection.c index 3e34244e73..e7aad5bff7 100644 --- a/gtk/gtktreeselection.c +++ b/gtk/gtktreeselection.c @@ -1231,44 +1231,11 @@ gtk_tree_selection_unselect_range (GtkTreeSelection *selection, g_signal_emit (selection, tree_selection_signals[CHANGED], 0); } -static gboolean -tree_column_is_sensitive (GtkTreeViewColumn *column, - GtkTreeModel *model, - GtkTreeIter *iter) -{ - GList *cells, *list; - gboolean sensitive; - gboolean visible; - - gtk_tree_view_column_cell_set_cell_data (column, model, - iter, FALSE, FALSE); - - cells = gtk_tree_view_column_get_cell_renderers (column); - - list = cells; - while (list) - { - g_object_get (list->data, - "sensitive", &sensitive, - "visible", &visible, - NULL); - - if (visible && sensitive) - break; - - list = list->next; - } - g_list_free (cells); - - return sensitive; -} - gboolean _gtk_tree_selection_row_is_selectable (GtkTreeSelection *selection, GtkRBNode *node, GtkTreePath *path) { - GList *list; GtkTreeIter iter; gboolean sensitive = FALSE; @@ -1284,19 +1251,6 @@ _gtk_tree_selection_row_is_selectable (GtkTreeSelection *selection, return FALSE; } - for (list = selection->tree_view->priv->columns; list && !sensitive; list = list->next) - { - GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN (list->data); - - if (!column->visible) - continue; - - sensitive = tree_column_is_sensitive (column, selection->tree_view->priv->model, &iter); - } - - if (!sensitive) - return FALSE; - if (selection->user_func) return (*selection->user_func) (selection, selection->tree_view->priv->model, path, GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_IS_SELECTED), @@ -1479,10 +1433,7 @@ gtk_tree_selection_real_select_node (GtkTreeSelection *selection, if (GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_IS_SELECTED) != select) { path = _gtk_tree_view_find_path (selection->tree_view, tree, node); - if (!select) - toggle = TRUE; - else - toggle = _gtk_tree_selection_row_is_selectable (selection, node, path); + toggle = _gtk_tree_selection_row_is_selectable (selection, node, path); gtk_tree_path_free (path); } |