summaryrefslogtreecommitdiff
path: root/libs/surfaces/osc/osc.cc
diff options
context:
space:
mode:
authorLen Ovens <len@ovenwerks.net>2016-11-18 07:53:40 -0800
committerLen Ovens <len@ovenwerks.net>2016-11-18 07:53:40 -0800
commit1015e19ad3d5b9aa0f368bc6add1fbceac0091d4 (patch)
treec2e084cbeedd6436d3284e6e1aca44ed3917b76e /libs/surfaces/osc/osc.cc
parentd624bac38e5f035e003c832aa3b11b0f176c90d5 (diff)
OSC: issue 7116 fix send enable not working
Diffstat (limited to 'libs/surfaces/osc/osc.cc')
-rw-r--r--libs/surfaces/osc/osc.cc27
1 files changed, 26 insertions, 1 deletions
diff --git a/libs/surfaces/osc/osc.cc b/libs/surfaces/osc/osc.cc
index 4a0e8657d0..4d4e20aae6 100644
--- a/libs/surfaces/osc/osc.cc
+++ b/libs/surfaces/osc/osc.cc
@@ -2597,6 +2597,18 @@ OSC::route_set_send_enable (int ssid, int sid, float val, lo_message msg)
}
if (s->send_level_controllable (sid)) {
+ boost::shared_ptr<Route> r = boost::dynamic_pointer_cast<Route> (s);
+ if (!r) {
+ return 0;
+ }
+ boost::shared_ptr<Send> snd = boost::dynamic_pointer_cast<Send> (r->nth_send(sid));
+ if (snd) {
+ if (val) {
+ snd->activate();
+ } else {
+ snd->deactivate();
+ }
+ }
return 0;
}
@@ -2624,7 +2636,20 @@ OSC::sel_sendenable (int id, float val, lo_message msg)
return 0;
}
if (s->send_level_controllable (id)) {
- return sel_send_fail ("send_enable", id + 1, 1, get_address (msg));
+ boost::shared_ptr<Route> r = boost::dynamic_pointer_cast<Route> (s);
+ if (!r) {
+ // should never get here
+ return sel_send_fail ("send_enable", id + 1, 0, get_address (msg));
+ }
+ boost::shared_ptr<Send> snd = boost::dynamic_pointer_cast<Send> (r->nth_send(id));
+ if (snd) {
+ if (val) {
+ snd->activate();
+ } else {
+ snd->deactivate();
+ }
+ }
+ return 0;
}
}
return sel_send_fail ("send_enable", id + 1, 0, get_address (msg));