diff options
author | Robin Gareus <robin@gareus.org> | 2015-10-06 20:05:38 +0200 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2015-10-06 20:05:38 +0200 |
commit | e73fa8413e67098cbd4e9c7eaa414d01d2ce9782 (patch) | |
tree | b38d596ea389d701849f1f108ccf0dd6a5f1e42c /libs/ardour/session_rtevents.cc | |
parent | ce30132a89a5ec99d3c151d2fb54cf7d074e3f65 (diff) |
add a "reset all solo state" safeguard
Diffstat (limited to 'libs/ardour/session_rtevents.cc')
-rw-r--r-- | libs/ardour/session_rtevents.cc | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libs/ardour/session_rtevents.cc b/libs/ardour/session_rtevents.cc index 189385e2ee..d001b239ba 100644 --- a/libs/ardour/session_rtevents.cc +++ b/libs/ardour/session_rtevents.cc @@ -54,11 +54,30 @@ Session::rt_set_monitoring (boost::shared_ptr<RouteList> rl, MonitorChoice mc, b } void +Session::clear_all_solo_state (boost::shared_ptr<RouteList> rl) +{ + queue_event (get_rt_event (rl, false, rt_cleanup, false, &Session::rt_clear_all_solo_state)); +} + +void +Session::rt_clear_all_solo_state (boost::shared_ptr<RouteList> rl, bool /* yn */, bool /* group_override */) +{ + for (RouteList::iterator i = rl->begin(); i != rl->end(); ++i) { + if ((*i)->is_auditioner()) { + continue; + } + (*i)->clear_all_solo_state(); + } + set_dirty(); +} + +void Session::set_solo (boost::shared_ptr<RouteList> rl, bool yn, SessionEvent::RTeventCallback after, bool group_override) { queue_event (get_rt_event (rl, yn, after, group_override, &Session::rt_set_solo)); } + void Session::rt_set_solo (boost::shared_ptr<RouteList> rl, bool yn, bool /* group_override */) { |