summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-10-21 07:50:23 +0300
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-10-21 07:50:23 +0300
commitc39d1c61563e6a8b458432c91b057eac51dcabab (patch)
tree1fe6f934db11107dd8e7367503b208c7acbe9826
parent831df38e05c8b120818a5296c59cea9d09637a62 (diff)
parent19a1693f580223a9b4e8bd35c3980f20e69c2f13 (diff)
downloadsubsurface-c39d1c61563e6a8b458432c91b057eac51dcabab.tar.gz
Merge branch 'multiple_selection' of git://github.com/dirkhh/subsurface
-rw-r--r--divelist.c37
1 files changed, 31 insertions, 6 deletions
diff --git a/divelist.c b/divelist.c
index 1cc76b38a..5f2063e9f 100644
--- a/divelist.c
+++ b/divelist.c
@@ -50,17 +50,42 @@ enum {
DIVELIST_COLUMNS
};
+static GList *selected_dives;
+
static void selection_cb(GtkTreeSelection *selection, GtkTreeModel *model)
{
GtkTreeIter iter;
GValue value = {0, };
+ GtkTreePath *path;
- if (!gtk_tree_selection_get_selected(selection, NULL, &iter))
- return;
+ int nr_selected = gtk_tree_selection_count_selected_rows(selection);
- gtk_tree_model_get_value(model, &iter, DIVE_INDEX, &value);
- selected_dive = g_value_get_int(&value);
- repaint_dive();
+ if (selected_dives) {
+ g_list_foreach (selected_dives, (GFunc) gtk_tree_path_free, NULL);
+ g_list_free (selected_dives);
+ }
+ selected_dives = gtk_tree_selection_get_selected_rows(selection, NULL);
+
+ switch (nr_selected) {
+ case 0: /* keep showing the last selected dive */
+ return;
+ case 1:
+ /* just pick that dive as selected */
+ path = g_list_nth_data(selected_dives, 0);
+ if (gtk_tree_model_get_iter(model, &iter, path)) {
+ gtk_tree_model_get_value(model, &iter, DIVE_INDEX, &value);
+ selected_dive = g_value_get_int(&value);
+ repaint_dive();
+ }
+ return;
+ default: /* multiple selections - what now? At this point I
+ * don't want to change the selected dive unless
+ * there is exactly one dive selected; not sure this
+ * is the most intuitive solution.
+ * I do however want to keep around which dives have
+ * been selected */
+ return;
+ }
}
static void date_data_func(GtkTreeViewColumn *col,
@@ -505,7 +530,7 @@ GtkWidget *dive_list_create(void)
selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(dive_list.tree_view));
- gtk_tree_selection_set_mode(GTK_TREE_SELECTION(selection), GTK_SELECTION_BROWSE);
+ gtk_tree_selection_set_mode(GTK_TREE_SELECTION(selection), GTK_SELECTION_MULTIPLE);
gtk_widget_set_size_request(dive_list.tree_view, 200, 200);
dive_list.date = divelist_column(&dive_list, DIVE_DATE, "Date", date_data_func, PANGO_ALIGN_LEFT, TRUE);