From e5561d766852cde28ebbabf2150bab5be6183897 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Tue, 10 Dec 2013 06:17:15 +0100 Subject: Fix selection tracking bug When trying to remember a newly manually created dive across the sort_table() call I abused the dive->selected flag and didn't clear it out afterwards (most likely thinking "hey, I'm calling selectDive() on this anyway"). This caused the UI code to correctly mark the dive as selected, but when it called down to the C code to keep the internal data structures in sync, that code didn't update amount_selected as it thought this dive had already been selected. And that caused other parts of the code to get confused, which manifested for example in the failed upload to divelogs.de. So this clears out the flag after abusing it to remember a dive. Maybe we should add a 'remembered' flag instead, but for now this fixes the issue. Fixes #351 Initial-fix-by: Lubomir I. Ivanov Signed-off-by: Dirk Hohndel --- qt-ui/maintab.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'qt-ui/maintab.cpp') diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp index 21451d9e0..e9855bda7 100644 --- a/qt-ui/maintab.cpp +++ b/qt-ui/maintab.cpp @@ -638,18 +638,21 @@ void MainTab::acceptChanges() if(editMode == ADD || editMode == MANUALLY_ADDED_DIVE){ mainWindow()->dive_list()->unselectDives(); struct dive *d = get_dive(dive_table.nr -1 ); - // HACK. this shouldn't be here. but apparently it's - // how we can know what was the newly added dive. + // mark the dive as remembered (abusing the selected flag) + // and then clear that flag out on the other side of the sort_table() d->selected = true; sort_table(&dive_table); int i = 0; for_each_dive(i,d){ - if (d->selected) break; + if (d->selected) { + d->selected = false; + break; + } } editMode = NONE; mainWindow()->refreshDisplay(); mainWindow()->dive_list()->selectDive( i, true ); - }else{ + } else { editMode = NONE; mainWindow()->dive_list()->rememberSelection(); sort_table(&dive_table); -- cgit v1.2.3-70-g09d2