+ const KItemSet selection = selectedItems();
+ if (selection != previousSelection) {
+ Q_EMIT selectionChanged(selection, previousSelection);
+ }
+
+ Q_ASSERT(m_currentItem < m_model->count());
+ Q_ASSERT(m_anchorItem < m_model->count());
+}
+
+void KItemListSelectionManager::itemsMoved(const KItemRange &itemRange, const QList<int> &movedToIndexes)
+{
+ // Store the current selection (needed in the selectionChanged() signal)
+ const KItemSet previousSelection = selectedItems();
+
+ // Store whether we were doing an anchored selection
+ const bool wasInAnchoredSelection = isAnchoredSelectionActive();
+
+ // endAnchoredSelection() adds all items between m_currentItem and
+ // m_anchorItem to m_selectedItems. They can then be moved
+ // individually later in this function.
+ endAnchoredSelection();
+
+ // Update the current item
+ if (m_currentItem >= itemRange.index && m_currentItem < itemRange.index + itemRange.count) {
+ const int previousCurrentItem = m_currentItem;
+ const int newCurrentItem = movedToIndexes.at(previousCurrentItem - itemRange.index);
+
+ // Calling setCurrentItem would trigger the selectionChanged signal, but we want to
+ // emit it only once in this function -> change the current item manually and emit currentChanged
+ m_currentItem = newCurrentItem;
+ Q_EMIT currentChanged(newCurrentItem, previousCurrentItem);
+ }
+
+ // Start a new anchored selection.
+ if (wasInAnchoredSelection) {
+ beginAnchoredSelection(m_currentItem);