3c905299b8732bb097e6c7677c3f50ba868ecf39
[ardour.git] / libs / ardour / session_rtevents.cc
1 /*
2     Copyright (C) 1999-2009 Paul Davis
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 */
18
19 #include <boost/bind.hpp>
20
21 #include "pbd/error.h"
22 #include "pbd/compose.h"
23
24 #include "ardour/monitor_control.h"
25 #include "ardour/route.h"
26 #include "ardour/session.h"
27 #include "ardour/track.h"
28 #include "ardour/vca_manager.h"
29
30 #include "i18n.h"
31
32 using namespace std;
33 using namespace PBD;
34 using namespace ARDOUR;
35 using namespace Glib;
36
37 void
38 Session::set_controls (boost::shared_ptr<ControlList> cl, double val, Controllable::GroupControlDisposition gcd)
39 {
40         std::cerr << "Session::set_controls called on " << cl->size() << " controls, group = " << enum_2_string (gcd) << std::endl;
41         queue_event (get_rt_event (cl, val, gcd));
42 }
43
44 void
45 Session::set_control (boost::shared_ptr<AutomationControl> ac, double val, Controllable::GroupControlDisposition gcd)
46 {
47         boost::shared_ptr<ControlList> cl (new ControlList);
48         cl->push_back (ac);
49         set_controls (cl, val, gcd);
50 }
51
52 void
53 Session::rt_set_controls (boost::shared_ptr<ControlList> cl, double val, Controllable::GroupControlDisposition gcd)
54 {
55         for (ControlList::iterator c = cl->begin(); c != cl->end(); ++c) {
56                 (*c)->set_value (val, gcd);
57         }
58 }
59
60 void
61 Session::clear_all_solo_state (boost::shared_ptr<RouteList> rl)
62 {
63         queue_event (get_rt_event (rl, false, rt_cleanup, Controllable::NoGroup, &Session::rt_clear_all_solo_state));
64 }
65
66 void
67 Session::rt_clear_all_solo_state (boost::shared_ptr<RouteList> rl, bool /* yn */, Controllable::GroupControlDisposition /* group_override */)
68 {
69         for (RouteList::iterator i = rl->begin(); i != rl->end(); ++i) {
70                 if ((*i)->is_auditioner()) {
71                         continue;
72                 }
73                 (*i)->clear_all_solo_state();
74         }
75
76         _vca_manager->clear_all_solo_state ();
77
78         set_dirty();
79 }
80
81 void
82 Session::process_rtop (SessionEvent* ev)
83 {
84         ev->rt_slot ();
85
86         if (ev->event_loop) {
87                 ev->event_loop->call_slot (MISSING_INVALIDATOR, boost::bind (ev->rt_return, ev));
88         } else {
89                 warning << string_compose ("programming error: %1", X_("Session RT event queued from thread without a UI - cleanup in RT thread!")) << endmsg;
90                 ev->rt_return (ev);
91         }
92 }