aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-30 07:05:30 +1100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-30 07:05:30 +1100
commit468d3f28f9f1f2795960b8e8b79b9d02024e34ed (patch)
treebe0a5e70292f59d5013b566db11c539da04b76fb
parent4b5b732f2cf8a63445a610642285304526850c91 (diff)
downloadsubsurface-468d3f28f9f1f2795960b8e8b79b9d02024e34ed.tar.gz
Make the selection logic more robust
In commit 304526850c91 ("Don't deselect all dives on all selection "change" events") the handling of "selected_dive" is incorrect. We ended up with non-sensical values for the selected dive, including dives that Gtk didn't think were selected. This commit tries to be smart about what to do when the dive that we currently consider selected is unselected (we have this weird notion of many dives being selected, but one of them is shown in the profile and that is the "selected_dive"). As long as there are others selected, we pick one of them (first walking to earlier dives and if there are none that are selected, looking for a later dive) as the new selected dive. This appears to give us a rather intuitive behavior when playing with multiple selected dives. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--divelist.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/divelist.c b/divelist.c
index e023dcd6c..f286eb660 100644
--- a/divelist.c
+++ b/divelist.c
@@ -2611,8 +2611,22 @@ static void deselect_dive(int idx)
if (dive && dive->selected) {
dive->selected = 0;
amount_selected--;
- if (selected_dive > idx)
- selected_dive--;
+ if (selected_dive == idx && amount_selected > 0) {
+ /* pick a different dive as selected */
+ while(--selected_dive >= 0) {
+ dive = get_dive(selected_dive);
+ if (dive && dive->selected)
+ return;
+ }
+ selected_dive = idx;
+ while(++selected_dive < dive_table.nr) {
+ dive = get_dive(selected_dive);
+ if (dive && dive->selected)
+ return;
+ }
+ }
+ if (amount_selected == 0)
+ selected_dive = -1;
}
}