summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libs/ardour/recent_sessions.cc46
-rw-r--r--libs/ardour/session_state.cc50
2 files changed, 77 insertions, 19 deletions
diff --git a/libs/ardour/recent_sessions.cc b/libs/ardour/recent_sessions.cc
index f19c0d8d37..c831b6536b 100644
--- a/libs/ardour/recent_sessions.cc
+++ b/libs/ardour/recent_sessions.cc
@@ -108,18 +108,33 @@ int
ARDOUR::read_recent_templates (std::deque<std::string>& rt)
{
std::string path = Glib::build_filename (user_config_directory(), recent_templates_file_name);
+ FILE* fin = g_fopen (path.c_str(), "rb");
- ifstream recent (path.c_str());
-
- if (!recent) {
+ if (!fin) {
if (errno != ENOENT) {
- error << string_compose (_("cannot open recent template file %1 (%2)"), path, strerror (errno)) << endmsg;
+ error << string_compose (_("Cannot open recent template file %1 (%2)"), path, strerror (errno)) << endmsg;
return -1;
} else {
return 1;
}
}
+ // Copy the file contents into a std::stringstream
+ std::stringstream recent;
+ while (!feof (fin)) {
+ char buf[1024];
+ size_t charsRead = fread (buf, sizeof(char), 1024, fin);
+ if (ferror (fin)) {
+ error << string_compose (_("Error reading recent session file %1 (%2)"), path, strerror (errno)) << endmsg;
+ fclose(fin);
+ return -1;
+ }
+ if (charsRead == 0) {
+ break;
+ }
+ recent.write (buf, charsRead);
+ }
+
while (true) {
std::string session_template_full_name;
@@ -133,6 +148,7 @@ ARDOUR::read_recent_templates (std::deque<std::string>& rt)
rt.push_back (session_template_full_name);
}
+ fclose (fin);
return 0;
}
@@ -181,18 +197,32 @@ ARDOUR::write_recent_sessions (RecentSessions& rs)
int
ARDOUR::write_recent_templates (std::deque<std::string>& rt)
{
- std::string path = Glib::build_filename (user_config_directory(), recent_templates_file_name);
+ FILE* fout = g_fopen (Glib::build_filename (user_config_directory(), recent_templates_file_name).c_str(), "wb");
- std::ofstream recent (path.c_str());
-
- if (!recent) {
+ if (!fout) {
return -1;
}
+ stringstream recent;
+
for (std::deque<std::string>::const_iterator i = rt.begin(); i != rt.end(); ++i) {
recent << (*i) << std::endl;
}
+ string recentString = recent.str();
+ size_t writeSize = recentString.length();
+
+ fwrite(recentString.c_str(), sizeof(char), writeSize, fout);
+
+ if (ferror(fout))
+ {
+ error << string_compose (_("Error writing saved template file %1 (%2)"), recent_templates_file_name, strerror (errno)) << endmsg;
+ fclose(fout);
+ return -1;
+ }
+
+ fclose (fout);
+
return 0;
}
diff --git a/libs/ardour/session_state.cc b/libs/ardour/session_state.cc
index 562db87ef3..f893c18a1b 100644
--- a/libs/ardour/session_state.cc
+++ b/libs/ardour/session_state.cc
@@ -538,9 +538,9 @@ Session::create (const string& session_template, BusProfile* bus_profile)
_writable = exists_and_writable (_path);
if (!session_template.empty()) {
- std::string in_path = (ARDOUR::Profile->get_trx () ? session_template : session_template_dir_to_file (session_template));
+ string in_path = (ARDOUR::Profile->get_trx () ? session_template : session_template_dir_to_file (session_template));
- ifstream in(in_path.c_str());
+ FILE* in = g_fopen (in_path.c_str(), "rb");
if (in) {
/* no need to call legalize_for_path() since the string
@@ -548,23 +548,51 @@ Session::create (const string& session_template, BusProfile* bus_profile)
*/
string out_path = Glib::build_filename (_session_dir->root_path(), _name + statefile_suffix);
- ofstream out(out_path.c_str());
+ FILE* out = g_fopen (out_path.c_str(), "wb");
if (out) {
- out << in.rdbuf();
- _is_new = false;
-
- if (!ARDOUR::Profile->get_trx()) {
- /* Copy plugin state files from template to new session */
- std::string template_plugins = Glib::build_filename (session_template, X_("plugins"));
- copy_recurse (template_plugins, plugins_dir ());
- }
+ char buf[1024];
+ stringstream new_session;
+
+ while (!feof (in)) {
+ size_t charsRead = fread (buf, sizeof(char), 1024, in);
+
+ if (ferror (in)) {
+ error << string_compose (_("Error reading session template file %1 (%2)"), in_path, strerror (errno)) << endmsg;
+ fclose (in);
+ fclose (out);
+ return -1;
+ }
+ if (charsRead == 0) {
+ break;
+ }
+ new_session.write (buf, charsRead);
+ }
+ fclose (in);
+
+ string file_contents = new_session.str();
+ size_t writeSize = file_contents.length();
+ if (fwrite (file_contents.c_str(), sizeof(char), writeSize, out) != writeSize) {
+ error << string_compose (_("Error writing session template file %1 (%2)"), out_path, strerror (errno)) << endmsg;
+ fclose (out);
+ return -1;
+ }
+ fclose (out);
+
+ _is_new = false;
+
+ if (!ARDOUR::Profile->get_trx()) {
+ /* Copy plugin state files from template to new session */
+ std::string template_plugins = Glib::build_filename (session_template, X_("plugins"));
+ copy_recurse (template_plugins, plugins_dir ());
+ }
return 0;
} else {
error << string_compose (_("Could not open %1 for writing session template"), out_path)
<< endmsg;
+ fclose(in);
return -1;
}