X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Frc_configuration.cc;h=3227a644dde5c10f80c48416a43264668c1e5865;hb=b285559767e21aae4467270590f048c3263fd742;hp=7fe030fb7e0102e3d39acc2a44586f45f253900f;hpb=f4b5f4c72ee60b6f509e307c5bfd164108d1f30b;p=ardour.git diff --git a/libs/ardour/rc_configuration.cc b/libs/ardour/rc_configuration.cc index 7fe030fb7e..3227a644dd 100644 --- a/libs/ardour/rc_configuration.cc +++ b/libs/ardour/rc_configuration.cc @@ -21,21 +21,25 @@ #include /* for snprintf, grrr */ #include -#include /* for g_stat() */ +#include "pbd/gstdio_compat.h" #include #include "pbd/xml++.h" #include "pbd/file_utils.h" +#include "pbd/replace_all.h" #include "ardour/audioengine.h" +#include "ardour/disk_reader.h" +#include "ardour/disk_writer.h" #include "ardour/control_protocol_manager.h" -#include "ardour/diskstream.h" #include "ardour/filesystem_paths.h" #include "ardour/port.h" #include "ardour/rc_configuration.h" #include "ardour/session_metadata.h" +#include "ardour/transport_master_manager.h" +#include "ardour/types_convert.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace ARDOUR; using namespace std; @@ -49,6 +53,9 @@ namespace ARDOUR { float speed_quietning = 0.251189; // -12dB reduction for ffwd or rewind } +static const char* user_config_file_name = "config"; +static const char* system_config_file_name = "system_config"; + RCConfiguration::RCConfiguration () : /* construct variables */ @@ -60,12 +67,14 @@ RCConfiguration::RCConfiguration () #undef CONFIG_VARIABLE #undef CONFIG_VARIABLE_SPECIAL _control_protocol_state (0) + , _transport_master_state (0) { } RCConfiguration::~RCConfiguration () { delete _control_protocol_state; + delete _transport_master_state; } int @@ -76,7 +85,7 @@ RCConfiguration::load_state () /* load system configuration first */ - if (find_file_in_search_path (ardour_config_search_path(), "ardour_system.rc", rcfile)) { + if (find_file (ardour_config_search_path(), system_config_file_name, rcfile)) { /* stupid XML Parser hates empty files */ @@ -85,7 +94,7 @@ RCConfiguration::load_state () } if (statbuf.st_size != 0) { - info << string_compose (_("Loading system configuration file %1"), rcfile) << endl; + info << string_compose (_("Loading system configuration file %1"), rcfile) << endmsg; XMLTree tree; if (!tree.read (rcfile.c_str())) { @@ -104,7 +113,7 @@ RCConfiguration::load_state () /* now load configuration file for user */ - if (find_file_in_search_path (ardour_config_search_path(), "ardour.rc", rcfile)) { + if (find_file (ardour_config_search_path(), user_config_file_name, rcfile)) { /* stupid XML parser hates empty files */ @@ -113,7 +122,7 @@ RCConfiguration::load_state () } if (statbuf.st_size != 0) { - info << string_compose (_("Loading user configuration file %1"), rcfile) << endl; + info << string_compose (_("Loading user configuration file %1"), rcfile) << endmsg; XMLTree tree; if (!tree.read (rcfile)) { @@ -136,7 +145,7 @@ RCConfiguration::load_state () int RCConfiguration::save_state() { - const std::string rcfile = Glib::build_filename (user_config_directory(), "ardour.rc"); + const std::string rcfile = Glib::build_filename (user_config_directory(), user_config_file_name); // this test seems bogus? if (!rcfile.empty()) { @@ -168,7 +177,6 @@ XMLNode& RCConfiguration::get_state () { XMLNode* root; - LocaleGuard lg (X_("POSIX")); root = new XMLNode("Ardour"); @@ -182,6 +190,10 @@ RCConfiguration::get_state () root->add_child_nocopy (ControlProtocolManager::instance().get_state()); + if (TransportMasterManager::exists()) { + root->add_child_nocopy (TransportMasterManager::instance().get_state()); + } + return *root; } @@ -189,7 +201,6 @@ XMLNode& RCConfiguration::get_variables () { XMLNode* node; - LocaleGuard lg (X_("POSIX")); node = new XMLNode ("Config"); @@ -229,10 +240,13 @@ RCConfiguration::set_state (const XMLNode& root, int version) SessionMetadata::Metadata()->set_state (*node, version); } else if (node->name() == ControlProtocolManager::state_node_name) { _control_protocol_state = new XMLNode (*node); + } else if (node->name() == TransportMasterManager::state_node_name) { + _transport_master_state = new XMLNode (*node); } } - Diskstream::set_disk_io_chunk_frames (minimum_disk_io_bytes.get() / sizeof (Sample)); + DiskReader::set_chunk_samples (minimum_disk_read_bytes.get() / sizeof (Sample)); + DiskWriter::set_chunk_samples (minimum_disk_write_bytes.get() / sizeof (Sample)); return 0; } @@ -267,3 +281,4 @@ RCConfiguration::map_parameters (boost::function& functor) #undef CONFIG_VARIABLE #undef CONFIG_VARIABLE_SPECIAL } +