Add test_search_path function in libardour testsuite
[ardour.git] / libs / ardour / rc_configuration.cc
index c4417b376ef9344819627db9eebd08e66e41893a..81272679757f4374a08de7db9bf74355111bdc6d 100644 (file)
 #include <glib/gstdio.h> /* for g_stat() */
 #include <glibmm/miscutils.h>
 
-#include "pbd/failed_constructor.h"
 #include "pbd/xml++.h"
-#include "pbd/filesystem.h"
 #include "pbd/file_utils.h"
 
 #include "midi++/manager.h"
 
-#include "ardour/ardour.h"
-#include "ardour/rc_configuration.h"
-#include "ardour/audio_diskstream.h"
 #include "ardour/control_protocol_manager.h"
+#include "ardour/diskstream.h"
 #include "ardour/filesystem_paths.h"
+#include "ardour/rc_configuration.h"
+#include "ardour/session_metadata.h"
 
 #include "i18n.h"
 
@@ -78,19 +76,12 @@ RCConfiguration::~RCConfiguration ()
 int
 RCConfiguration::load_state ()
 {
-       bool found = false;
-
-       sys::path system_rc_file;
+       std::string rcfile;
        struct stat statbuf;
 
        /* load system configuration first */
 
-       if (find_file_in_search_path (ardour_search_path() + system_config_search_path(),
-                       "ardour_system.rc", system_rc_file) )
-       {
-               found = true;
-
-               string rcfile = system_rc_file.to_string();
+       if (find_file_in_search_path (ardour_config_search_path(), "ardour_system.rc", rcfile)) {
 
                /* stupid XML Parser hates empty files */
 
@@ -112,20 +103,13 @@ RCConfiguration::load_state ()
                                return -1;
                        }
                } else {
-                       error << string_compose (_("your system %1 configuration file is empty. This probably means that there as an error installing %1"), PROGRAM_NAME) << endmsg;
+                       error << string_compose (_("Your system %1 configuration file is empty. This probably means that there was an error installing %1"), PROGRAM_NAME) << endmsg;
                }
        }
 
        /* now load configuration file for user */
 
-       sys::path user_rc_file;
-
-       if (find_file_in_search_path (ardour_search_path() + user_config_directory(),
-                       "ardour.rc", user_rc_file))
-       {
-               found = true;
-
-               string rcfile = user_rc_file.to_string();
+       if (find_file_in_search_path (ardour_config_search_path(), "ardour.rc", rcfile)) {
 
                /* stupid XML parser hates empty files */
 
@@ -151,29 +135,13 @@ RCConfiguration::load_state ()
                }
        }
 
-       if (!found)
-               error << string_compose (_("%1: could not find configuration file (ardour.rc), canvas will look broken."), PROGRAM_NAME) << endmsg;
-
        return 0;
 }
 
 int
 RCConfiguration::save_state()
 {
-       try
-       {
-               sys::create_directories (user_config_directory ());
-       }
-       catch (const sys::filesystem_error& ex)
-       {
-               error << "Could not create user configuration directory" << endmsg;
-               return -1;
-       }
-
-       sys::path rcfile_path(user_config_directory());
-
-       rcfile_path /= "ardour.rc";
-       const string rcfile = rcfile_path.to_string();
+       const std::string rcfile = Glib::build_filename (user_config_directory(), "ardour.rc");
 
        // this test seems bogus?
        if (!rcfile.empty()) {
@@ -221,6 +189,8 @@ RCConfiguration::get_state ()
 
        root->add_child_nocopy (get_variables ());
 
+       root->add_child_nocopy (SessionMetadata::Metadata()->get_user_state());
+
        if (_extra_xml) {
                root->add_child_copy (*_extra_xml);
        }
@@ -252,7 +222,7 @@ RCConfiguration::get_variables ()
 }
 
 int
-RCConfiguration::set_state (const XMLNode& root, int /*version*/)
+RCConfiguration::set_state (const XMLNode& root, int version)
 {
        if (root.name() != "Ardour") {
                return -1;
@@ -276,6 +246,8 @@ RCConfiguration::set_state (const XMLNode& root, int /*version*/)
 
                if (node->name() == "Config") {
                        set_variables (*node);
+               } else if (node->name() == "Metadata") {
+                       SessionMetadata::Metadata()->set_state (*node, version);
                } else if (node->name() == ControlProtocolManager::state_node_name) {
                        _control_protocol_state = new XMLNode (*node);
                } else if (node->name() == MIDI::Port::state_node_name) {