OSC: added group join, switch, remove function

This commit is contained in:
Len Ovens 2018-02-16 13:08:09 -08:00
parent 3504ecff5f
commit dffecfa4c6
4 changed files with 113 additions and 15 deletions

View File

@ -568,6 +568,7 @@ OSC::register_callbacks()
// Controls for the Selected strip
REGISTER_CALLBACK (serv, X_("/select/recenable"), "i", sel_recenable);
REGISTER_CALLBACK (serv, X_("/select/record_safe"), "i", sel_recsafe);
REGISTER_CALLBACK (serv, X_("/select/group"), "s", sel_group);
REGISTER_CALLBACK (serv, X_("/select/mute"), "i", sel_mute);
REGISTER_CALLBACK (serv, X_("/select/solo"), "i", sel_solo);
REGISTER_CALLBACK (serv, X_("/select/solo_iso"), "i", sel_solo_iso);
@ -638,6 +639,7 @@ OSC::register_callbacks()
REGISTER_CALLBACK (serv, X_("/strip/send/fader"), "iif", route_set_send_fader);
REGISTER_CALLBACK (serv, X_("/strip/send/enable"), "iif", route_set_send_enable);
REGISTER_CALLBACK (serv, X_("/strip/name"), "is", route_rename);
REGISTER_CALLBACK (serv, X_("/strip/group"), "is", strip_group);
REGISTER_CALLBACK (serv, X_("/strip/sends"), "i", route_get_sends);
REGISTER_CALLBACK (serv, X_("/strip/receives"), "i", route_get_receives);
REGISTER_CALLBACK (serv, X_("/strip/plugin/list"), "i", route_plugin_list);
@ -3688,18 +3690,97 @@ OSC::route_recenable (int ssid, int yn, lo_message msg)
}
int
OSC::route_rename(int ssid, char *newname, lo_message msg) {
if (!session) {
return -1;
}
OSC::route_rename (int ssid, char *newname, lo_message msg) {
if (!session) {
return -1;
}
boost::shared_ptr<Stripable> s = get_strip(ssid, get_address(msg));
boost::shared_ptr<Stripable> s = get_strip(ssid, get_address(msg));
if (s) {
s->set_name(std::string(newname));
}
if (s) {
s->set_name(std::string(newname));
}
return 0;
return 0;
}
int
OSC::strip_group (int ssid, char *group, lo_message msg) {
if (!session) {
return -1;
}
boost::shared_ptr<Stripable> s = get_strip(ssid, get_address(msg));
return strip_select_group (s, group);
}
int
OSC::sel_group (char *group, lo_message msg) {
if (!session) {
return -1;
}
OSCSurface *sur = get_surface(get_address (msg));
boost::shared_ptr<Stripable> s;
if (sur->expand_enable) {
s = get_strip (sur->expand, get_address (msg));
} else {
s = _select;
}
return strip_select_group (s, group);
}
int
OSC::strip_select_group (boost::shared_ptr<Stripable> s, char *group)
{
string grp = group;
if (grp == "" || grp == " ") {
grp = "none";
}
if (s) {
boost::shared_ptr<Route> rt = boost::dynamic_pointer_cast<Route> (s);
if (!rt) {
return -1;
}
RouteGroup *rg = rt->route_group();
RouteGroup* new_rg = session->route_group_by_name (grp);
if (rg) {
string old_group = rg->name();
if (grp == "none") {
if (rg->size () == 1) {
session->remove_route_group (*rg);
} else {
rg->remove (rt);
}
} else if (grp != old_group) {
if (new_rg) {
// group exists switch to it
if (rg->size () == 1) {
session->remove_route_group (rg);
} else {
rg->remove (rt);
}
new_rg->add (rt);
} else {
rg->set_name (grp);
}
} else {
// nothing to change
return 0;
}
} else {
if (grp == "none") {
return 0;
} else if (new_rg) {
new_rg->add (rt);
} else {
// create new group with this strip in it
RouteGroup* new_rg = new RouteGroup (*session, grp);
session->add_route_group (new_rg);
new_rg->add (rt);
}
}
}
return 0;
}
int

View File

@ -473,6 +473,18 @@ class OSC : public ARDOUR::ControlProtocol, public AbstractUI<OSCUIRequest>
return 0; \
}
#define PATH_CALLBACK1_MSG_s(name,arg1type) \
static int _ ## name (const char *path, const char *types, lo_arg **argv, int argc, void *data, void *user_data) { \
return static_cast<OSC*>(user_data)->cb_ ## name (path, types, argv, argc, data); \
} \
int cb_ ## name (const char *path, const char *types, lo_arg **argv, int argc, void *data) { \
OSC_DEBUG; \
if (argc > 0) { \
name (&argv[0]->arg1type, data); \
} \
return 0; \
}
// pan position needs message info to send feedback
PATH_CALLBACK1_MSG(master_set_pan_stereo_position,f);
@ -481,6 +493,7 @@ class OSC : public ARDOUR::ControlProtocol, public AbstractUI<OSCUIRequest>
PATH_CALLBACK1_MSG(jog_mode,f);
PATH_CALLBACK1_MSG(bank_delta,f);
PATH_CALLBACK1_MSG(use_group,f);
PATH_CALLBACK1_MSG_s(sel_group,s);
PATH_CALLBACK1_MSG(sel_recenable,i);
PATH_CALLBACK1_MSG(sel_recsafe,i);
PATH_CALLBACK1_MSG(sel_mute,i);
@ -592,6 +605,7 @@ class OSC : public ARDOUR::ControlProtocol, public AbstractUI<OSCUIRequest>
PATH_CALLBACK2(locate,i,i);
PATH_CALLBACK2(loop_location,i,i);
PATH_CALLBACK2_MSG_s(route_rename,i,s);
PATH_CALLBACK2_MSG_s(strip_group,i,s);
PATH_CALLBACK2_MSG(route_mute,i,i);
PATH_CALLBACK2_MSG(route_solo,i,i);
PATH_CALLBACK2_MSG(route_solo_iso,i,i);
@ -621,6 +635,8 @@ class OSC : public ARDOUR::ControlProtocol, public AbstractUI<OSCUIRequest>
PATH_CALLBACK2_MSG(route_plugin_reset,i,i);
int route_rename (int rid, char *s, lo_message msg);
int strip_group (int ssid, char *g, lo_message msg);
int strip_select_group (boost::shared_ptr<ARDOUR::Stripable> s, char *g);
int route_mute (int rid, int yn, lo_message msg);
int route_solo (int rid, int yn, lo_message msg);
int route_solo_iso (int rid, int yn, lo_message msg);
@ -699,6 +715,7 @@ class OSC : public ARDOUR::ControlProtocol, public AbstractUI<OSCUIRequest>
int monitor_set_mute (uint32_t state);
int monitor_set_dim (uint32_t state);
int monitor_set_mono (uint32_t state);
int sel_group (char *g, lo_message msg);
int sel_recenable (uint32_t state, lo_message msg);
int sel_recsafe (uint32_t state, lo_message msg);
int sel_mute (uint32_t state, lo_message msg);

View File

@ -250,7 +250,7 @@ OSCRouteObserver::clear_strip ()
_osc.float_message_with_id (X_("/strip/expand"), ssid, 0, in_line, addr);
if (feedback[0]) { // buttons are separate feedback
_osc.text_message_with_id (X_("/strip/name"), ssid, " ", in_line, addr);
_osc.text_message_with_id (X_("/strip/group/name"), ssid, " ", in_line, addr);
_osc.text_message_with_id (X_("/strip/group"), ssid, "none", in_line, addr);
_osc.float_message_with_id (X_("/strip/mute"), ssid, 0, in_line, addr);
_osc.float_message_with_id (X_("/strip/solo"), ssid, 0, in_line, addr);
_osc.float_message_with_id (X_("/strip/recenable"), ssid, 0, in_line, addr);
@ -361,9 +361,9 @@ OSCRouteObserver::group_name ()
RouteGroup *rg = rt->route_group();
if (rg) {
_osc.text_message_with_id (X_("/strip/group/name"), ssid, rg->name(), in_line, addr);
_osc.text_message_with_id (X_("/strip/group"), ssid, rg->name(), in_line, addr);
} else {
_osc.text_message_with_id (X_("/strip/group/name"), ssid, " ", in_line, addr);
_osc.text_message_with_id (X_("/strip/group"), ssid, " ", in_line, addr);
}
}

View File

@ -276,7 +276,7 @@ OSCSelectObserver::clear_observer ()
// all strip buttons should be off and faders 0 and etc.
_osc.float_message (X_("/select/expand"), 0, addr);
_osc.text_message (X_("/select/name"), " ", addr);
_osc.text_message (X_("/select/group/name"), " ", addr);
_osc.text_message (X_("/select/group"), " ", addr);
_osc.text_message (X_("/select/comment"), " ", addr);
_osc.float_message (X_("/select/mute"), 0, addr);
_osc.float_message (X_("/select/solo"), 0, addr);
@ -655,9 +655,9 @@ OSCSelectObserver::group_name ()
RouteGroup *rg = rt->route_group();
if (rg) {
_osc.text_message (X_("/select/group/name"), rg->name(), addr);
_osc.text_message (X_("/select/group"), rg->name(), addr);
} else {
_osc.text_message (X_("/select/group/name"), " ", addr);
_osc.text_message (X_("/select/group"), " ", addr);
}
}