diff options
author | Matthias Clasen <mclasen@redhat.com> | 2004-07-07 15:15:35 +0000 |
---|---|---|
committer | Matthias Clasen <matthiasc@src.gnome.org> | 2004-07-07 15:15:35 +0000 |
commit | 1aa00e521590a807868cdfe75e8fbf7fb6facc44 (patch) | |
tree | 5d848f45999ce4846fc2e56f82674dbc3c066807 /gtk/gtktreeselection.c | |
parent | a346f4a8ad8a037a014891b59db8efa47c30d37e (diff) | |
download | gtk+-1aa00e521590a807868cdfe75e8fbf7fb6facc44.tar.gz |
Support separators in combo boxes and more generally in tree views
2004-07-07 Matthias Clasen <mclasen@redhat.com>
Support separators in combo boxes and more generally in tree
views (#135873):
* gtk/gtkcombobox.h:
* gtk/gtkcombobox.c (gtk_combo_box_get_row_separator_column):
* gtk/gtkcombobox.c (gtk_combo_box_set_row_separator_column):
Add a ::row-separator-column property with getter and setter,
which can indicate a boolean model column to determine which
rows are separators.
* gtk/gtkcombobox.c: Display separator rows as separator menu
items in menu mode, and by using the new treeview separator
functionality in list mode.
* gtk/gtktreeview.h:
* gtk/gtktreeview.c (gtk_tree_view_get_row_separator_func):
* gtk/gtktreeview.c (gtk_tree_view_set_row_separator_func):
Add a callback to determine whether a row is a separator.
* gtk/gtktreeview.c (gtk_tree_view_bin_expose):
* gtk/gtktreeview.c (gtk_tree_view_create_row_drag_icon):
* gtk/gtktreeview.c (validate_row): Use the new callback
to determine whether a row is a separator, and draw it
as a separator then. Since separators should take up less
vertical space than regular rows, this requires removing
the redundant MAX(...,expander_size) calls which appear in
many places. Instead, the MAX() is now only done in
validate_row(), and only if the row is not a separator.
To catch possible side effects of this intrusive change,
I have left EXPANDER_MAX() calls in place of the MAX() calls
which will emit a warning if something breaks. They should
be removed before 2.6.
* gtk/gtktreeselection.c (row_is_selectable): Don't let
separator rows be selected.
* tests/testcombo.c (create_blaat): Add a separator column.
Diffstat (limited to 'gtk/gtktreeselection.c')
-rw-r--r-- | gtk/gtktreeselection.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/gtk/gtktreeselection.c b/gtk/gtktreeselection.c index 4e5a76a7da..b8ac48b8b8 100644 --- a/gtk/gtktreeselection.c +++ b/gtk/gtktreeselection.c @@ -1319,21 +1319,29 @@ row_is_selectable (GtkTreeSelection *selection, GtkTreePath *path) { GList *list; - gboolean sensitive; - - sensitive = FALSE; + GtkTreeIter iter; + gboolean sensitive = FALSE; + + if (!gtk_tree_model_get_iter (selection->tree_view->priv->model, &iter, path)) + sensitive = TRUE; + + if (!sensitive && selection->tree_view->priv->row_separator_func) + { + /* never allow separators to be selected */ + if ((* selection->tree_view->priv->row_separator_func) (selection->tree_view->priv->model, + &iter, + selection->tree_view->priv->row_separator_data)) + return FALSE; + } + for (list = selection->tree_view->priv->columns; list && !sensitive; list = list->next) { GtkTreeViewColumn *column = GTK_TREE_VIEW_COLUMN (list->data); - GtkTreeIter iter; if (!column->visible) continue; - if (gtk_tree_model_get_iter (selection->tree_view->priv->model, &iter, path)) - sensitive = tree_column_is_sensitive (column, selection->tree_view->priv->model, &iter); - else - sensitive = TRUE; + sensitive = tree_column_is_sensitive (column, selection->tree_view->priv->model, &iter); } if (!sensitive) |