X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=libs%2Fardour%2Fglobals.cc;h=2ecea550b5c400e02bf19738cd4260251d52b5b3;hb=b2bf4eee3d9ca63a34415c75e877b8c97d6b5f13;hp=389bcc196c428a6fa8836588239c8862ba5fcd89;hpb=db8b575c30845bafc34b87bacd52129c95d1c478;p=ardour.git diff --git a/libs/ardour/globals.cc b/libs/ardour/globals.cc index 389bcc196c..2ecea550b5 100644 --- a/libs/ardour/globals.cc +++ b/libs/ardour/globals.cc @@ -64,12 +64,14 @@ #include "ardour/audioengine.h" #include "ardour/audioregion.h" #include "ardour/audiosource.h" +#include "ardour/buffer_manager.h" #include "ardour/control_protocol_manager.h" #include "ardour/debug.h" #include "ardour/filesystem_paths.h" #include "ardour/mix.h" #include "ardour/playlist.h" #include "ardour/plugin_manager.h" +#include "ardour/process_thread.h" #include "ardour/profile.h" #include "ardour/region.h" #include "ardour/rc_configuration.h" @@ -96,11 +98,6 @@ using namespace ARDOUR; using namespace std; using namespace PBD; -MIDI::Port *ARDOUR::default_mmc_port = 0; -MIDI::Port *ARDOUR::default_mtc_port = 0; -MIDI::Port *ARDOUR::default_midi_port = 0; -MIDI::Port *ARDOUR::default_midi_clock_port = 0; - compute_peak_t ARDOUR::compute_peak = 0; find_peaks_t ARDOUR::find_peaks = 0; apply_gain_to_buffer_t ARDOUR::apply_gain_to_buffer = 0; @@ -144,87 +141,6 @@ ARDOUR::make_property_quarks () DEBUG_TRACE (DEBUG::Properties, string_compose ("quark for envelope_FAKE = %1\n", Properties::envelope.property_id)); } -int -ARDOUR::setup_midi () -{ - if (Config->midi_ports.size() == 0) { - return 0; - } - - BootMessage (_("Configuring MIDI ports")); - - for (std::map::iterator i = Config->midi_ports.begin(); i != Config->midi_ports.end(); ++i) { - MIDI::Manager::instance()->add_port (i->second); - } - - MIDI::Port* first; - const MIDI::Manager::PortList& ports = MIDI::Manager::instance()->get_midi_ports(); - - if (ports.size() > 1) { - - first = ports.front(); - - /* More than one port, so try using specific names for each port */ - - default_mmc_port = MIDI::Manager::instance()->port (Config->get_mmc_port_name()); - default_mtc_port = MIDI::Manager::instance()->port (Config->get_mtc_port_name()); - default_midi_port = MIDI::Manager::instance()->port (Config->get_midi_port_name()); - default_midi_clock_port = MIDI::Manager::instance()->port (Config->get_midi_clock_port_name()); - - /* If that didn't work, just use the first listed port */ - - if (default_mmc_port == 0) { - default_mmc_port = first; - } - - if (default_mtc_port == 0) { - default_mtc_port = first; - } - - if (default_midi_port == 0) { - default_midi_port = first; - } - - if (default_midi_clock_port == 0) { - default_midi_clock_port = first; - } - - } else if (ports.size() == 1) { - - first = ports.front(); - - /* Only one port described, so use it for both MTC and MMC */ - - default_mmc_port = first; - default_mtc_port = default_mmc_port; - default_midi_port = default_mmc_port; - default_midi_clock_port = default_mmc_port; - } - - if (default_mmc_port == 0) { - warning << string_compose (_("No MMC control (MIDI port \"%1\" not available)"), Config->get_mmc_port_name()) - << endmsg; - } - - - if (default_mtc_port == 0) { - warning << string_compose (_("No MTC support (MIDI port \"%1\" not available)"), Config->get_mtc_port_name()) - << endmsg; - } - - if (default_midi_port == 0) { - warning << string_compose (_("No MIDI parameter support (MIDI port \"%1\" not available)"), Config->get_midi_port_name()) - << endmsg; - } - - if (default_midi_clock_port == 0) { - warning << string_compose (_("No MIDI Clock support (MIDI port \"%1\" not available)"), Config->get_midi_clock_port_name()) - << endmsg; - } - - return 0; -} - void setup_hardware_optimization (bool try_optimization) { @@ -309,7 +225,7 @@ lotsa_files_please () if (rl.rlim_cur == RLIM_INFINITY) { info << _("Removed open file count limit. Excellent!") << endmsg; } else { - info << string_compose (_("Ardour will be limited to %1 open files"), rl.rlim_cur) << endmsg; + info << string_compose (_("%1 will be limited to %2 open files"), PROGRAM_NAME, rl.rlim_cur) << endmsg; } } } else { @@ -367,12 +283,9 @@ ARDOUR::init (bool use_vst, bool try_optimization) if (Config->load_state ()) { return -1; } - - + Config->set_use_vst (use_vst); - cerr << "After config loaded, MTC port name = " << Config->get_mtc_port_name() << endl; - Profile = new RuntimeProfile; @@ -405,18 +318,26 @@ ARDOUR::init (bool use_vst, bool try_optimization) /* singleton - first object is "it" */ new PluginManager (); + ProcessThread::init (); + BufferManager::init (10); // XX should be num_processors_for_dsp + return 0; } void ARDOUR::init_post_engine () { + /* the MIDI Manager is needed by the ControlProtocolManager */ + MIDI::Manager::create (AudioEngine::instance()->jack()); + ControlProtocolManager::instance().discover_control_protocols (); XMLNode* node; if ((node = Config->control_protocol_state()) != 0) { ControlProtocolManager::instance().set_state (*node, Stateful::loading_state_version); } + + MIDI::Manager::instance()->set_port_states (Config->midi_port_states ()); } int @@ -530,8 +451,8 @@ ARDOUR::setup_fpu () } ARDOUR::OverlapType -ARDOUR::coverage (nframes_t sa, nframes_t ea, - nframes_t sb, nframes_t eb) +ARDOUR::coverage (framepos_t sa, framepos_t ea, + framepos_t sb, framepos_t eb) { /* OverlapType returned reflects how the second (B) range overlaps the first (A). @@ -558,11 +479,8 @@ ARDOUR::coverage (nframes_t sa, nframes_t ea, "B is internal to A" */ -#ifdef OLD_COVERAGE - if ((sb >= sa) && (eb <= ea)) { -#else + if ((sb > sa) && (eb <= ea)) { -#endif return OverlapInternal; } @@ -608,3 +526,15 @@ ARDOUR::coverage (nframes_t sa, nframes_t ea, return OverlapNone; } +string +ARDOUR::translation_kill_path () +{ + return Glib::build_filename (user_config_directory().to_string(), ".love_is_the_language_of_audio"); +} + +bool +ARDOUR::translations_are_disabled () +{ + /* if file does not exist, we don't translate (bundled ardour only) */ + return Glib::file_test (translation_kill_path(), Glib::FILE_TEST_EXISTS) == false; +}