#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"
return info;
}
+#ifdef NDEBUG
static bool running_from_source_tree ()
{
// dup ARDOUR_UI_UTILS::running_from_source_tree ()
gchar const *x = g_getenv ("ARDOUR_THEMES_PATH");
return x && (string (x).find ("gtk2_ardour") != string::npos);
}
+#endif
vector<const AudioBackendInfo*>
AudioEngine::available_backends() const
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;
delete p;
}
}
-