Add remove_directory_internal function and use it in PBD::clear_directory and PBD::remove_directory
This commit is contained in:
@@ -47,14 +47,14 @@ using namespace PBD;
|
||||
using namespace std;
|
||||
|
||||
int
|
||||
PBD::clear_directory (const string& dir, size_t* size, vector<string>* paths)
|
||||
remove_directory_internal (const string& dir, size_t* size, vector<string>* paths,
|
||||
bool just_remove_files)
|
||||
{
|
||||
vector<string> tmp_paths;
|
||||
struct stat statbuf;
|
||||
int ret = 0;
|
||||
|
||||
// we are only removing files, not the directory structure
|
||||
get_directory_contents (dir, tmp_paths, true, true);
|
||||
get_directory_contents (dir, tmp_paths, just_remove_files, true);
|
||||
|
||||
for (vector<string>::const_iterator i = tmp_paths.begin();
|
||||
i != tmp_paths.end(); ++i) {
|
||||
@@ -63,8 +63,8 @@ PBD::clear_directory (const string& dir, size_t* size, vector<string>* paths)
|
||||
continue;
|
||||
}
|
||||
|
||||
if (::g_unlink (i->c_str())) {
|
||||
error << string_compose (_("cannot remove file %1 (%2)"), *i, strerror (errno))
|
||||
if (::g_remove (i->c_str())) {
|
||||
error << string_compose (_("cannot remove path %1 (%2)"), *i, strerror (errno))
|
||||
<< endmsg;
|
||||
ret = 1;
|
||||
}
|
||||
@@ -82,38 +82,15 @@ PBD::clear_directory (const string& dir, size_t* size, vector<string>* paths)
|
||||
return ret;
|
||||
}
|
||||
|
||||
int
|
||||
PBD::clear_directory (const string& dir, size_t* size, vector<string>* paths)
|
||||
{
|
||||
return remove_directory_internal (dir, size, paths, true);
|
||||
}
|
||||
|
||||
// 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;
|
||||
}
|
||||
::closedir (dead);
|
||||
PBD::remove_directory (const std::string& dir)
|
||||
{
|
||||
remove_directory_internal (dir, 0, 0, false);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user