# HG changeset patch # User Chris Cannam # Date 1394012132 0 # Node ID f831ca41d4a556cbc75aa5a180cf1e6a8d5598b5 # Parent 711ae36a53a2730780bc59cb75b2d1c0d39026d0 Add selectionChangedByUser for selection changes prompted by interactivity rather than by undo/redo diff -r 711ae36a53a2 -r f831ca41d4a5 view/Pane.cpp --- a/view/Pane.cpp Tue Mar 04 16:45:39 2014 +0000 +++ b/view/Pane.cpp Wed Mar 05 09:35:32 2014 +0000 @@ -359,10 +359,10 @@ bool &closeToRight) const { if (m_identifyFeatures && - m_manager && - m_manager->getToolModeFor(this) == ViewManager::EditMode && - !m_manager->getSelections().empty() && - !selectionIsBeingEdited()) { + m_manager && + m_manager->getToolModeFor(this) == ViewManager::EditMode && + !m_manager->getSelections().empty() && + !selectionIsBeingEdited()) { Selection s(getSelectionAt(m_identifyPoint.x(), closeToLeft, closeToRight)); diff -r 711ae36a53a2 -r f831ca41d4a5 view/ViewManager.cpp --- a/view/ViewManager.cpp Tue Mar 04 16:45:39 2014 +0000 +++ b/view/ViewManager.cpp Wed Mar 05 09:35:32 2014 +0000 @@ -279,6 +279,7 @@ if (m_selections.getSelections() == ms.getSelections()) return; SetSelectionCommand *command = new SetSelectionCommand(this, ms); CommandHistory::getInstance()->addCommand(command); + emit selectionChangedByUser(); } size_t diff -r 711ae36a53a2 -r f831ca41d4a5 view/ViewManager.h --- a/view/ViewManager.h Tue Mar 04 16:45:39 2014 +0000 +++ b/view/ViewManager.h Wed Mar 05 09:35:32 2014 +0000 @@ -214,9 +214,14 @@ /** Emitted when the output levels change. Values in range 0.0 -> 1.0. */ void outputLevelsChanged(float left, float right); - /** Emitted when the selection has changed. */ + /** Emitted whenever the selection has changed. */ void selectionChanged(); + /** Emitted when the selection has been changed through an + * explicit selection-editing action. *Not* emitted when the + * selection has been changed through undo or redo. */ + void selectionChangedByUser(); + /** Emitted when the in-progress (rubberbanding) selection has changed. */ void inProgressSelectionChanged();