summaryrefslogtreecommitdiff
path: root/gtk2_ardour/mixer_ui.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2017-01-06 18:40:21 +0100
committerRobin Gareus <robin@gareus.org>2017-01-06 18:41:51 +0100
commit94a57e64f655c238aebd2780ea6c8b6727c48177 (patch)
treec2383f03497b9c493ed8f96faff924c419fd0617 /gtk2_ardour/mixer_ui.cc
parent2ca06335f7a7f35dc91817c5f0dd291e2ad063c3 (diff)
fix route ordering (and related possible crash on re-order)
Diffstat (limited to 'gtk2_ardour/mixer_ui.cc')
-rw-r--r--gtk2_ardour/mixer_ui.cc18
1 files changed, 18 insertions, 0 deletions
diff --git a/gtk2_ardour/mixer_ui.cc b/gtk2_ardour/mixer_ui.cc
index ce6ed294a3..49862c36a5 100644
--- a/gtk2_ardour/mixer_ui.cc
+++ b/gtk2_ardour/mixer_ui.cc
@@ -706,6 +706,9 @@ Mixer_UI::sync_presentation_info_from_treeview ()
bool change = false;
uint32_t order = 0;
+ OrderingKeys sorted;
+ const size_t cmp_max = rows.size ();
+
// special case master if it's got PI order 0 lets keep it there
if (_session->master_out() && (_session->master_out()->presentation_info().order() == 0)) {
order++;
@@ -743,9 +746,23 @@ Mixer_UI::sync_presentation_info_from_treeview ()
change = true;
}
+ sorted.push_back (OrderKeys (order, stripable, cmp_max));
+
++order;
}
+ if (!change) {
+ // VCA (and Mixbus) special cases according to SortByNewDisplayOrder
+ uint32_t n = 0;
+ SortByNewDisplayOrder cmp;
+ sort (sorted.begin(), sorted.end(), cmp);
+ for (OrderingKeys::iterator sr = sorted.begin(); sr != sorted.end(); ++sr, ++n) {
+ if (sr->old_display_order != n) {
+ change = true;
+ }
+ }
+ }
+
if (change) {
DEBUG_TRACE (DEBUG::OrderKeys, "... notify PI change from mixer GUI\n");
_session->notify_presentation_info_change ();
@@ -1487,6 +1504,7 @@ Mixer_UI::initial_track_display ()
}
redisplay_track_list ();
+ sync_treeview_from_presentation_info ();
}
void