use pbd's gstdio compatibility wrapper
[ardour.git] / libs / ardour / recent_sessions.cc
index 85c3c55f1630205cfd351a112acf065621ef4951..22244c80ba7ae5f6a881c92fcf725cbb6a93509e 100644 (file)
@@ -24,7 +24,7 @@
 #include <sstream>
 #include <algorithm>
 
-#include <glib/gstdio.h>
+#include <pbd/gstdio_compat.h>
 #include <glibmm/miscutils.h>
 
 #include "pbd/error.h"
@@ -61,27 +61,22 @@ ARDOUR::read_recent_sessions (RecentSessions& rs)
                }
        }
 
-
-
-       // Read the file into a std::string;
+       // Read the file into a std::string
        std::stringstream recent;
-       char temporaryBuffer[1024];
-       while (!feof(fin))
-       {
-               size_t charsRead = fread(&temporaryBuffer[0], sizeof(char), 1024, fin);
-               if (charsRead != 1024 && ferror(fin))
-               {
+       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;
                }
-               recent << &temporaryBuffer[0];
+               if (charsRead == 0) {
+                       break;
+               }
+               recent.write (buf, charsRead);
        }
 
-
-
-       //ifstream recent (fin);
-
        while (true) {
 
                pair<string,string> newpair;
@@ -113,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;
@@ -138,6 +148,7 @@ ARDOUR::read_recent_templates (std::deque<std::string>& rt)
                rt.push_back (session_template_full_name);
        }
 
+       fclose (fin);
        return 0;
 }
 
@@ -186,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);
-
-       std::ofstream recent (path.c_str());
+       FILE* fout = g_fopen (Glib::build_filename (user_config_directory(), recent_templates_file_name).c_str(), "wb");
 
-       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;
 }