diff options
author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2024-07-03 10:19:30 +0200 |
---|---|---|
committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2024-07-03 10:19:30 +0200 |
commit | a14a7a0ccc9de76aeab0b2e4bbf58f1a79deedc2 (patch) | |
tree | e469179df67a0e0db49161a43cbf8076a189f6f4 /app/bin/directory.c | |
parent | 5d2c2b27a6323e2666378b986129b2a7c2c39e5c (diff) |
New upstream version 5.3.0GAupstream/5.3.0GAupstream
Diffstat (limited to 'app/bin/directory.c')
-rw-r--r-- | app/bin/directory.c | 172 |
1 files changed, 86 insertions, 86 deletions
diff --git a/app/bin/directory.c b/app/bin/directory.c index 991e139..b0a2b23 100644 --- a/app/bin/directory.c +++ b/app/bin/directory.c @@ -17,7 +17,7 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #include "directory.h" @@ -35,18 +35,18 @@ BOOL_T SafeCreateDir(const char *dir) { - int err; - - err = mkdir(dir, 0755); - if (err < 0) { - if (errno != EEXIST) { - NoticeMessage(MSG_DIR_CREATE_FAIL, - _("Continue"), NULL, dir, strerror(errno)); - perror(dir); - return FALSE; - } - } - return TRUE; + int err; + + err = mkdir(dir, 0755); + if (err < 0) { + if (errno != EEXIST) { + NoticeMessage(MSG_DIR_CREATE_FAIL, + _("Continue"), NULL, dir, strerror(errno)); + perror(dir); + return FALSE; + } + } + return TRUE; } /************************************************ @@ -59,83 +59,83 @@ BOOL_T SafeCreateDir(const char *dir) */ BOOL_T DeleteDirectory(const char *dir_path) { - size_t path_len; - char *full_path = NULL; - DIR *dir; - struct stat stat_path, stat_entry; - struct dirent *entry; - DynString path; - - // stat for the path - int resp = stat(dir_path, &stat_path); - - if (resp != 0 && errno == ENOENT) { - return TRUE; //Does not Exist - } - - // if path is not dir - exit - if (!(S_ISDIR(stat_path.st_mode))) { - NoticeMessage(MSG_NOT_DIR_FAIL, - _("Continue"), NULL, dir_path); - return FALSE; - } - - // if not possible to read the directory for this user - if ((dir = opendir(dir_path)) == NULL) { - NoticeMessage(MSG_DIR_OPEN_FAIL, - _("Continue"), NULL, dir_path); - return FALSE; - } - - // the length of the path - path_len = strlen(dir_path) + 1; - DynStringMalloc(&path, path_len + 16); //guessing the total path length - - // iteration through entries in the directory - while ((entry = readdir(dir)) != NULL) { - - // skip entries "." and ".." - if (!strcmp(entry->d_name, ".") || !strcmp(entry->d_name, "..")) { - continue; - } - - // determinate a full path of an entry - DynStringReset(&path); - DynStringCatCStrs(&path, dir_path, FILE_SEP_CHAR, entry->d_name, NULL); - full_path = DynStringToCStr(&path); - // stat for the entry - stat(full_path, &stat_entry); - - // recursively remove a nested directory - if (S_ISDIR(stat_entry.st_mode) != 0) { - DeleteDirectory(full_path); - continue; - } - - // remove a file object - if (unlink(full_path)) { - NoticeMessage(MSG_UNLINK_FAIL, _("Continue"), NULL, full_path); - DynStringFree(&path); - closedir(dir); - return FALSE; - } else { + size_t path_len; + char *full_path = NULL; + DIR *dir; + struct stat stat_path, stat_entry; + struct dirent *entry; + DynString path; + + // stat for the path + int resp = stat(dir_path, &stat_path); + + if (resp != 0 && errno == ENOENT) { + return TRUE; //Does not Exist + } + + // if path is not dir - exit + if (!(S_ISDIR(stat_path.st_mode))) { + NoticeMessage(MSG_NOT_DIR_FAIL, + _("Continue"), NULL, dir_path); + return FALSE; + } + + // if not possible to read the directory for this user + if ((dir = opendir(dir_path)) == NULL) { + NoticeMessage(MSG_DIR_OPEN_FAIL, + _("Continue"), NULL, dir_path); + return FALSE; + } + + // the length of the path + path_len = strlen(dir_path) + 1; + DynStringMalloc(&path, path_len + 16); //guessing the total path length + + // iteration through entries in the directory + while ((entry = readdir(dir)) != NULL) { + + // skip entries "." and ".." + if (!strcmp(entry->d_name, ".") || !strcmp(entry->d_name, "..")) { + continue; + } + + // determinate a full path of an entry + DynStringReset(&path); + DynStringCatCStrs(&path, dir_path, FILE_SEP_CHAR, entry->d_name, NULL); + full_path = DynStringToCStr(&path); + // stat for the entry + stat(full_path, &stat_entry); + + // recursively remove a nested directory + if (S_ISDIR(stat_entry.st_mode) != 0) { + DeleteDirectory(full_path); + continue; + } + + // remove a file object + if (unlink(full_path)) { + NoticeMessage(MSG_UNLINK_FAIL, _("Continue"), NULL, full_path); + DynStringFree(&path); + closedir(dir); + return FALSE; + } else { #if DEBUG - printf("Removed a file: %s \n", full_path); + printf("Removed a file: %s \n", full_path); #endif - } - } + } + } - closedir(dir); - DynStringFree(&path); + closedir(dir); + DynStringFree(&path); - // remove the devastated directory and close the object of it - if (rmdir(dir_path)) { - NoticeMessage(MSG_RMDIR_FAIL, _("Continue"), NULL, dir_path); - return FALSE; - } else { + // remove the devastated directory and close the object of it + if (rmdir(dir_path)) { + NoticeMessage(MSG_RMDIR_FAIL, _("Continue"), NULL, dir_path); + return FALSE; + } else { #if DEBUG - printf("Removed a directory: %s \n", dir_path); + printf("Removed a directory: %s \n", dir_path); #endif - } - return TRUE; + } + return TRUE; } |