backport 1d85ab27a7e and ba128eea from cairocanvas branch to remove GIO (possible...
authorPaul Davis <paul@linuxaudiosystems.com>
Mon, 14 Apr 2014 16:53:30 +0000 (12:53 -0400)
committerPaul Davis <paul@linuxaudiosystems.com>
Mon, 14 Apr 2014 16:53:30 +0000 (12:53 -0400)
libs/ardour/lv2_plugin.cc
libs/pbd/clear_dir.cc
libs/pbd/file_utils.cc
libs/pbd/pbd/clear_dir.h

index a0720044d4bf02a83a37acc224edd5a05d18d037..204ae2c6944187d95e1ecea0c111aebd23243cef 100644 (file)
@@ -31,6 +31,7 @@
 
 #include <boost/utility.hpp>
 
+#include "pbd/clear_dir.h"
 #include "pbd/pathscanner.h"
 #include "pbd/compose.h"
 #include "pbd/error.h"
@@ -880,27 +881,6 @@ LV2Plugin::lv2_state_make_path(LV2_State_Make_Path_Handle handle,
        return g_strndup(abs_path.c_str(), abs_path.length());
 }
 
-static void
-remove_directory(const std::string& path)
-{
-       if (!Glib::file_test(path, Glib::FILE_TEST_IS_DIR)) {
-               warning << string_compose("\"%1\" is not a directory", path) << endmsg;
-               return;
-       }
-
-       Glib::RefPtr<Gio::File>           dir = Gio::File::create_for_path(path);
-       Glib::RefPtr<Gio::FileEnumerator> e   = dir->enumerate_children();
-       Glib::RefPtr<Gio::FileInfo>       fi;
-       while ((fi = e->next_file())) {
-               if (fi->get_type() == Gio::FILE_TYPE_DIRECTORY) {
-                       remove_directory(fi->get_name());
-               } else {
-                       dir->get_child(fi->get_name())->remove();
-               }
-       }
-       dir->remove();
-}
-
 void
 LV2Plugin::add_state(XMLNode* root) const
 {
@@ -952,7 +932,7 @@ LV2Plugin::add_state(XMLNode* root) const
                } else {
                        // State is identical, decrement version and nuke directory
                        lilv_state_free(state);
-                       remove_directory(new_dir);
+                       PBD::remove_directory(new_dir);
                        --_state_version;
                }
 
index 29410d41e51cbdbaab4ee7a8c5dce378ac10be7a..a7564447aba5390b7f267766b5be7b233217f680 100644 (file)
@@ -24,6 +24,8 @@
 #include <errno.h>
 #include <string.h>
 
+#include <glib.h>
+#include <glib/gstdio.h>
 #include <glibmm/miscutils.h>
 
 #include "pbd/error.h"
@@ -85,3 +87,38 @@ PBD::clear_directory (const string& dir, size_t* size, vector<string>* paths)
 
         return ret;
 }
+
+// rm -rf <dir> -- used to remove saved plugin state
+void
+PBD::remove_directory (const std::string& dir) {
+       DIR* dead;
+       struct dirent* dentry;
+       struct stat statbuf;
+
+       if ((dead = ::opendir (dir.c_str())) == 0) {
+               return;
+       }
+
+       while ((dentry = ::readdir (dead)) != 0) {
+               if(!strcmp(dentry->d_name, ".") || !strcmp(dentry->d_name, "..")) {
+                       continue;
+               }
+
+               string fullpath = Glib::build_filename (dir, dentry->d_name);
+               if (::stat (fullpath.c_str(), &statbuf)) {
+                       continue;
+               }
+
+               if (S_ISDIR (statbuf.st_mode)) {
+                       remove_directory(fullpath);
+                       continue;
+               }
+
+               if (::g_unlink (fullpath.c_str())) {
+                       error << string_compose (_("cannot remove file %1 (%2)"), fullpath, strerror (errno)) << endmsg;
+               }
+       }
+       if (::g_rmdir(dir.c_str())) {
+               error << string_compose (_("cannot remove directory %1 (%2)"), dir, strerror (errno)) << endmsg;
+       }
+}
index bb290fa6aaf1ae9ccdeba64e9a3941ed734b0184..2b03a640584cde5518569e04e0cc92ecf0b46fad 100644 (file)
 #include <glibmm/miscutils.h>
 #include <glibmm/pattern.h>
 
-#include <giomm/file.h>
+#include <errno.h>
+#include <string.h> /* strerror */
+
+/* open() */
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+
+/* close(), read(), write() */
+#ifdef COMPILER_MSVC
+#include <io.h> // Microsoft's nearest equivalent to <unistd.h>
+#else
+#include <unistd.h>
+#endif
 
 #include "pbd/compose.h"
 #include "pbd/file_utils.h"
@@ -139,21 +152,57 @@ copy_file(const std::string & from_path, const std::string & to_path)
 {
        if (!Glib::file_test (from_path, Glib::FILE_TEST_EXISTS)) return false;
 
-       Glib::RefPtr<Gio::File> from_file = Gio::File::create_for_path(from_path);
-       Glib::RefPtr<Gio::File> to_file = Gio::File::create_for_path(to_path);
+       int fd_from = -1;
+       int fd_to = -1;
+       char buf[4096]; // BUFSIZ  ??
+       ssize_t nread;
 
-       try
-       {
-               from_file->copy (to_file, Gio::FILE_COPY_OVERWRITE);
+       fd_from = ::open(from_path.c_str(), O_RDONLY);
+       if (fd_from < 0) {
+               goto copy_error;
        }
-       catch(const Glib::Exception& ex)
-       {
-               error << string_compose (_("Unable to Copy file %1 to %2 (%3)"),
-                               from_path, to_path, ex.what())
-                       << endmsg;
-               return false;
+
+       fd_to = ::open(to_path.c_str(), O_WRONLY | O_CREAT, 0666);
+       if (fd_to < 0) {
+               goto copy_error;
        }
-       return true;
+
+       while (nread = ::read(fd_from, buf, sizeof(buf)), nread > 0) {
+               char *out_ptr = buf;
+               do {
+                       ssize_t nwritten = ::write(fd_to, out_ptr, nread);
+                       if (nwritten >= 0) {
+                               nread -= nwritten;
+                               out_ptr += nwritten;
+                       } else if (errno != EINTR) {
+                               goto copy_error;
+                       }
+               } while (nread > 0);
+       }
+
+       if (nread == 0) {
+               if (::close(fd_to)) {
+                       fd_to = -1;
+                       goto copy_error;
+               }
+               ::close(fd_from);
+               return true;
+       }
+
+copy_error:
+       int saved_errno = errno;
+
+       if (fd_from >= 0) {
+               ::close(fd_from);
+       }
+       if (fd_to >= 0) {
+               ::close(fd_to);
+       }
+
+       error << string_compose (_("Unable to Copy file %1 to %2 (%3)"),
+                       from_path, to_path, strerror(saved_errno))
+               << endmsg;
+       return false;
 }
 
 static
@@ -181,8 +230,8 @@ copy_files(const std::string & from_path, const std::string & to_dir)
 std::string
 get_absolute_path (const std::string & p)
 {
-       Glib::RefPtr<Gio::File> f = Gio::File::create_for_path (p);
-       return f->get_path ();
+       if (Glib::path_is_absolute(p)) return p;
+       return Glib::build_filename (Glib::get_current_dir(), p);
 }
 
 bool
index 9c128d994d76897fe13784f4ee805efdf6bcf233..5f57483b63d26ffae1321b2197d682e04ee89252 100644 (file)
@@ -26,6 +26,7 @@
 
 namespace PBD {
         int clear_directory (const std::string&, size_t* = 0, std::vector<std::string>* = 0);
+        void remove_directory (const std::string& dir);
 }
 
 #endif /* __pbd_clear_dir_h__ */