#include "ardour/mtdm.h"
#include "ardour/port.h"
#include "ardour/process_thread.h"
+#include "ardour/rc_configuration.h"
#include "ardour/session.h"
#include "pbd/i18n.h"
for (BackendMap::const_iterator i = _backends.begin(); i != _backends.end(); ++i) {
#ifdef NDEBUG
- if (i->first == "None (Dummy)" && !running_from_source_tree ()) {
+ if (i->first == "None (Dummy)" && !running_from_source_tree () && Config->get_hide_dummy_backend ()) {
continue;
}
#endif
int error_code = _backend->start (for_latency);
if (error_code != 0) {
- _last_backend_error_string =
- AudioBackend::get_error_string((AudioBackend::ErrorCode)error_code);
+ _last_backend_error_string = AudioBackend::get_error_string((AudioBackend::ErrorCode) error_code);
return -1;
}
}
+ /* XXX MIDI ports may not actually be available here yet .. */
+
+ PortManager::fill_midi_port_info ();
+
if (!for_latency) {
Running(); /* EMIT SIGNAL */
}
stop_engine = false;
} else {
if (_backend->stop ()) {
- if (pl.locked ()) {
+ if (pl.locked ()) {
pl.release ();
}
return -1;
AudioEngine::add_pending_port_deletion (Port* p)
{
if (_session) {
- std::cerr << "Adding " << p->name() << " to pending port deletion list\n";
+ DEBUG_TRACE (DEBUG::Ports, string_compose ("adding %1 to pending port deletion list\n", p->name()));
if (_port_deletions_pending.write (&p, 1) != 1) {
error << string_compose (_("programming error: port %1 could not be placed on the pending deletion queue\n"), p->name()) << endmsg;
}
_session->auto_connect_thread_wakeup ();
} else {
- std::cerr << "Directly delete port\n";
+ DEBUG_TRACE (DEBUG::Ports, string_compose ("Directly delete port %1\n", p->name()));
delete p;
}
}
-