20 #include <glibmm/module.h>
22 #include <glibmm/fileutils.h>
28 #include "control_protocol/control_protocol.h"
30 #include "ardour/debug.h"
53 for (list<ControlProtocol*>::iterator i = control_protocols.begin(); i != control_protocols.end(); ++i) {
57 control_protocols.clear ();
60 for (list<ControlProtocolInfo*>::iterator p = control_protocol_info.begin(); p != control_protocol_info.end(); ++p) {
64 control_protocol_info.clear();
75 for (list<ControlProtocolInfo*>::iterator i = control_protocol_info.begin(); i != control_protocol_info.end(); ++i) {
76 if ((*i)->requested || (*i)->mandatory) {
77 (void) activate (**i);
90 if ((cp = instantiate (cpi)) == 0) {
113 cp->set_active (
true);
122 return teardown (cpi);
133 for (list<ControlProtocol*>::iterator p = control_protocols.begin(); p != control_protocols.end(); ++p) {
137 control_protocols.clear ();
139 for (list<ControlProtocolInfo*>::iterator p = control_protocol_info.begin(); p != control_protocol_info.end(); ++p) {
142 if ((*p)->protocol) {
143 (*p)->requested =
true;
175 control_protocols.push_back (cpi.
protocol);
177 ProtocolStatusChange (&cpi);
207 list<ControlProtocol*>::iterator p = find (control_protocols.begin(), control_protocols.end(), cpi.
protocol);
208 if (p != control_protocols.end()) {
209 control_protocols.erase (p);
211 cerr <<
"Programming error: ControlProtocolManager::teardown() called for " << cpi.
name <<
", but it was not found in control_protocols" << endl;
220 ProtocolStatusChange (&cpi);
234 for (list<ControlProtocolInfo*>::iterator i = control_protocol_info.begin(); i != control_protocol_info.end(); ++i) {
235 if ((*i)->mandatory && ((*i)->protocol == 0)) {
237 string_compose (
_(
"Instantiating mandatory control protocol %1"), (*i)->name));
246 vector<std::string> cp_modules;
256 Glib::PatternSpec dll_extension_pattern(
"*D.dll");
257 #elif defined (RDC_BUILD)
258 Glib::PatternSpec dll_extension_pattern(
"*RDC.dll");
259 #elif defined (_WIN64)
260 Glib::PatternSpec dll_extension_pattern(
"*64.dll");
262 Glib::PatternSpec dll_extension_pattern(
"*32.dll");
265 Glib::PatternSpec dll_extension_pattern(
"*.dll");
268 Glib::PatternSpec so_extension_pattern(
"*.so");
269 Glib::PatternSpec dylib_extension_pattern(
"*.dylib");
272 dll_extension_pattern);
275 so_extension_pattern);
278 dylib_extension_pattern);
283 for (vector<std::string>::iterator i = cp_modules.begin(); i != cp_modules.end(); ++i) {
284 control_protocol_discover (*i);
291 ControlProtocolDescriptor* descriptor;
297 if (path.find (
".dylib") && Glib::file_test (path, Glib::FILE_TEST_IS_SYMLINK)) {
302 if ((descriptor = get_descriptor (path)) != 0) {
304 if (!descriptor->probe (descriptor)) {
306 string_compose (
_(
"Control protocol %1 not usable"), descriptor->name));
312 cpi->
name = descriptor->name;
320 control_protocol_info.push_back (cpi);
326 delete (Glib::Module*)descriptor->module;
332 ControlProtocolDescriptor*
335 Glib::Module* module =
new Glib::Module(path);
336 ControlProtocolDescriptor *descriptor = 0;
337 ControlProtocolDescriptor* (*dfunc)(void);
341 error <<
string_compose(
_(
"ControlProtocolManager: cannot load module \"%1\" (%2)"), path, Glib::Module::get_last_error()) <<
endmsg;
346 if (!module->get_symbol(
"protocol_descriptor", func)) {
353 dfunc = (ControlProtocolDescriptor* (*)(void))func;
354 descriptor = dfunc();
357 descriptor->module = (
void*)module;
368 for (list<ControlProtocolInfo*>::iterator i = control_protocol_info.begin(); i != control_protocol_info.end(); ++i) {
376 for (list<ControlProtocolInfo*>::iterator i = control_protocol_info.begin(); i != control_protocol_info.end(); ++i) {
377 if (name == (*i)->name) {
395 for (citer = clist.begin(); citer != clist.end(); ++citer) {
396 if ((*citer)->name() ==
X_(
"Protocol")) {
398 if ((prop = (*citer)->property (
X_(
"active"))) == 0) {
404 if ((prop = (*citer)->property (
X_(
"name"))) == 0) {
439 for (list<ControlProtocolInfo*>::iterator i = control_protocol_info.begin(); i != control_protocol_info.end(); ++i) {
441 if ((*i)->protocol) {
442 XMLNode& child_state ((*i)->protocol->get_state());
445 }
else if ((*i)->state) {
465 if (_instance == 0) {
477 for (list<ControlProtocol*>::iterator p = control_protocols.begin(); p != control_protocols.end(); ++p) {
478 (*p)->midi_connectivity_established ();
std::string to_string(T t, std::ios_base &(*f)(std::ios_base &))
ControlProtocolInfo * cpi_by_name(std::string)
virtual void session_going_away()
const std::string & value() const
int control_protocol_discover(std::string path)
void session_going_away()
int deactivate(ControlProtocolInfo &)
int set_state(const XMLNode &, int version)
ControlProtocol * protocol
LIBPBD_API Transmitter error
static ControlProtocolManager & instance()
const XMLNodeList & children(const std::string &str=std::string()) const
XMLNode & get_state(void)
std::ostream & endmsg(std::ostream &ostr)
std::list< XMLNode * > XMLNodeList
static const char * state_node_name
void find_files_matching_pattern(vector< string > &result, const Searchpath &paths, const Glib::PatternSpec &pattern)
LIBARDOUR_API PBD::Searchpath control_protocol_search_path()
void set_session(Session *)
static ControlProtocolManager * _instance
bool string_is_affirmative(const std::string &str)
ControlProtocolDescriptor * descriptor
ControlProtocol * instantiate(ControlProtocolInfo &)
#define DEBUG_TRACE(bits, str)
static const std::string state_node_name
static int loading_state_version
LIBARDOUR_API PBD::PropertyDescriptor< bool > active
int teardown(ControlProtocolInfo &)
void midi_connectivity_established()
void discover_control_protocols()
XMLProperty * add_property(const char *name, const std::string &value)
void add_child_nocopy(XMLNode &)
void load_mandatory_protocols()
ControlProtocolDescriptor * get_descriptor(std::string path)
virtual void set_session(ARDOUR::Session *)
void foreach_known_protocol(boost::function< void(const ControlProtocolInfo *)>)
XMLNodeList::const_iterator XMLNodeConstIterator
~ControlProtocolManager()
LIBARDOUR_API uint64_t ControlProtocols
std::string string_compose(const std::string &fmt, const T1 &o1)
int activate(ControlProtocolInfo &)