summaryrefslogtreecommitdiff
path: root/gtk2_ardour/selection.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2014-02-25 21:53:52 -0500
committerPaul Davis <paul@linuxaudiosystems.com>2014-02-25 21:53:52 -0500
commit9ba2c0482086fe34f4dc828673a1f40698931f5b (patch)
tree6f934694ac8df4d5534fc2ea45e3766c99ffa1cf /gtk2_ardour/selection.cc
parentaff595c739b825a5f7d4302a48e6597eb30fef5f (diff)
ensure that track selection operations call ::set_selected() for tracks, allowing faster lookups of selected status during drags
Diffstat (limited to 'gtk2_ardour/selection.cc')
-rw-r--r--gtk2_ardour/selection.cc31
1 files changed, 21 insertions, 10 deletions
diff --git a/gtk2_ardour/selection.cc b/gtk2_ardour/selection.cc
index 146d9a65c5..04c479e0d9 100644
--- a/gtk2_ardour/selection.cc
+++ b/gtk2_ardour/selection.cc
@@ -125,6 +125,9 @@ void
Selection::clear_tracks ()
{
if (!tracks.empty()) {
+ for (TrackViewList::iterator x = tracks.begin(); x != tracks.end(); ++x) {
+ (*x)->set_selected (false);
+ }
tracks.clear ();
if (!_no_tracks_changed) {
TracksChanged();
@@ -249,8 +252,10 @@ Selection::toggle (TimeAxisView* track)
TrackSelection::iterator i;
if ((i = find (tracks.begin(), tracks.end(), track)) == tracks.end()) {
+ track->set_selected (true);
tracks.push_back (track);
} else {
+ track->set_selected (false);
tracks.erase (i);
}
@@ -392,6 +397,9 @@ Selection::add (const TrackViewList& track_list)
TrackViewList added = tracks.add (track_list);
if (!added.empty()) {
+ for (TrackViewList::iterator x = added.begin(); x != added.end(); ++x) {
+ (*x)->set_selected (true);
+ }
if (!_no_tracks_changed) {
TracksChanged ();
}
@@ -402,6 +410,7 @@ void
Selection::add (TimeAxisView* track)
{
TrackViewList tr;
+ track->set_selected (true);
tr.push_back (track);
add (tr);
}
@@ -589,6 +598,7 @@ Selection::remove (TimeAxisView* track)
{
list<TimeAxisView*>::iterator i;
if ((i = find (tracks.begin(), tracks.end(), track)) != tracks.end()) {
+ track->set_selected (false);
tracks.erase (i);
if (!_no_tracks_changed) {
TracksChanged();
@@ -597,15 +607,6 @@ Selection::remove (TimeAxisView* track)
}
void
-Selection::remove (ControlPoint* p)
-{
- PointSelection::iterator i = find (points.begin(), points.end(), p);
- if (i != points.end ()) {
- points.erase (i);
- }
-}
-
-void
Selection::remove (const TrackViewList& track_list)
{
bool changed = false;
@@ -614,6 +615,7 @@ Selection::remove (const TrackViewList& track_list)
TrackViewList::iterator x = find (tracks.begin(), tracks.end(), *i);
if (x != tracks.end()) {
+ (*i)->set_selected (false);
tracks.erase (x);
changed = true;
}
@@ -627,6 +629,15 @@ Selection::remove (const TrackViewList& track_list)
}
void
+Selection::remove (ControlPoint* p)
+{
+ PointSelection::iterator i = find (points.begin(), points.end(), p);
+ if (i != points.end ()) {
+ points.erase (i);
+ }
+}
+
+void
Selection::remove (const MidiNoteSelection& midi_list)
{
bool changed = false;
@@ -924,7 +935,7 @@ Selection::selected (Marker* m)
bool
Selection::selected (TimeAxisView* tv)
{
- return find (tracks.begin(), tracks.end(), tv) != tracks.end();
+ return tv->get_selected ();
}
bool