mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Dive list: implement proper Qt-model semantics for DiveTripModel
Previously, each dive-list modifying function would lead to a full model reset. Instead, implement proper Qt-model semantics using beginInsertRows()/endInsertRows(), beginRemoveRows()/ endRemoveRows(), dataChange(). To do so, a DiveListNotifer singleton is generatated, which broadcasts all changes to the dive-list. Signals are sent by the commands and received by the DiveTripModel. Signals are batched by dive-trip. This seems to be an adequate compromise for the two kinds of list-views (tree and list). In the common usecase mostly dives of a single trip are affected. Thus, batching of dives is performed in two positions: - At command-level to batch by trip - In DiveTripModel to feed batches of contiguous elements to Qt's begin*/end*-functions. This is conceptually simple, but rather complex code. To avoid repetition of complex loops, the batching is implemented in templated-functions, which are passed lambda-functions, which are called for each batch. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
6ac4ddbeed
commit
ec7d85835f
11 changed files with 645 additions and 100 deletions
|
@ -668,11 +668,6 @@ void DiveListView::merge_trip(const QModelIndex &a, int offset)
|
|||
if (trip_a == trip_b || !trip_a || !trip_b)
|
||||
return;
|
||||
Command::mergeTrips(trip_a, trip_b);
|
||||
rememberSelection();
|
||||
reload(currentLayout, false);
|
||||
restoreSelection();
|
||||
mark_divelist_changed(true);
|
||||
//TODO: emit a signal to signalize that the divelist changed?
|
||||
}
|
||||
|
||||
void DiveListView::mergeTripAbove()
|
||||
|
@ -696,11 +691,6 @@ void DiveListView::removeFromTrip()
|
|||
divesToRemove.append(d);
|
||||
}
|
||||
Command::removeDivesFromTrip(divesToRemove);
|
||||
|
||||
rememberSelection();
|
||||
reload(currentLayout, false);
|
||||
restoreSelection();
|
||||
mark_divelist_changed(true);
|
||||
}
|
||||
|
||||
void DiveListView::newTripAbove()
|
||||
|
@ -717,10 +707,6 @@ void DiveListView::newTripAbove()
|
|||
dives.append(d);
|
||||
}
|
||||
Command::createTrip(dives);
|
||||
|
||||
reload(currentLayout, false);
|
||||
mark_divelist_changed(true);
|
||||
restoreSelection();
|
||||
}
|
||||
|
||||
void DiveListView::addToTripBelow()
|
||||
|
@ -765,9 +751,6 @@ void DiveListView::addToTrip(int delta)
|
|||
}
|
||||
}
|
||||
Command::addDivesToTrip(dives, trip);
|
||||
|
||||
reload(currentLayout, false);
|
||||
restoreSelection();
|
||||
}
|
||||
|
||||
void DiveListView::markDiveInvalid()
|
||||
|
@ -783,9 +766,6 @@ void DiveListView::markDiveInvalid()
|
|||
// now mark the dive invalid... how do we do THAT?
|
||||
// d->invalid = true;
|
||||
}
|
||||
if (amount_selected == 0) {
|
||||
MainWindow::instance()->cleanUpEmpty();
|
||||
}
|
||||
mark_divelist_changed(true);
|
||||
MainWindow::instance()->refreshDisplay();
|
||||
if (prefs.display_invalid_dives == false) {
|
||||
|
@ -802,26 +782,12 @@ void DiveListView::deleteDive()
|
|||
return;
|
||||
|
||||
int i;
|
||||
int lastDiveNr = -1;
|
||||
QVector<struct dive*> deletedDives;
|
||||
for_each_dive (i, d) {
|
||||
if (!d->selected)
|
||||
continue;
|
||||
deletedDives.append(d);
|
||||
lastDiveNr = i;
|
||||
if (d->selected)
|
||||
deletedDives.append(d);
|
||||
}
|
||||
// the actual dive deletion is happening in the redo command that is implicitly triggered
|
||||
Command::deleteDive(deletedDives);
|
||||
if (amount_selected == 0) {
|
||||
MainWindow::instance()->cleanUpEmpty();
|
||||
}
|
||||
mark_divelist_changed(true);
|
||||
MainWindow::instance()->refreshDisplay();
|
||||
if (lastDiveNr != -1) {
|
||||
clearSelection();
|
||||
selectDive(lastDiveNr);
|
||||
rememberSelection();
|
||||
}
|
||||
}
|
||||
|
||||
void DiveListView::contextMenuEvent(QContextMenuEvent *event)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue