diff options
author | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2005-05-11 07:59:52 +0000 |
---|---|---|
committer | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2005-05-11 07:59:52 +0000 |
commit | 02ecfb2ce6166c0ce44753363d558063bcba8176 (patch) | |
tree | 444dce7f35d974cbdea50c23e978c96367f83552 /src/utils.c | |
parent | d0b069da3ae33f183352e89c5019d3bf509dd68b (diff) |
fixed several bugs, and implemented summary_unthread().
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@243 ee746299-78ed-0310-b773-934348b2243d
Diffstat (limited to 'src/utils.c')
-rw-r--r-- | src/utils.c | 47 |
1 files changed, 34 insertions, 13 deletions
diff --git a/src/utils.c b/src/utils.c index ed067a6f..4d9257d0 100644 --- a/src/utils.c +++ b/src/utils.c @@ -2070,15 +2070,13 @@ gint remove_expired_files(const gchar *dir, guint hours) return 0; } -gint remove_dir_recursive(const gchar *dir) +static gint remove_dir_recursive_real(const gchar *dir) { struct stat s; DIR *dp; struct dirent *d; gchar *prev_dir; - /* g_print("dir = %s\n", dir); */ - if (stat(dir, &s) < 0) { FILE_OP_ERROR(dir, "stat"); if (ENOENT == errno) return 0; @@ -2097,15 +2095,6 @@ gint remove_dir_recursive(const gchar *dir) prev_dir = g_get_current_dir(); /* g_print("prev_dir = %s\n", prev_dir); */ - if (!path_cmp(prev_dir, dir)) { - g_free(prev_dir); - if (chdir("..") < 0) { - FILE_OP_ERROR(dir, "chdir"); - return -1; - } - prev_dir = g_get_current_dir(); - } - if (chdir(dir) < 0) { FILE_OP_ERROR(dir, "chdir"); g_free(prev_dir); @@ -2128,7 +2117,7 @@ gint remove_dir_recursive(const gchar *dir) /* g_print("removing %s\n", d->d_name); */ if (dirent_is_directory(d)) { - if (remove_dir_recursive(d->d_name) < 0) { + if (remove_dir_recursive_real(d->d_name) < 0) { g_warning("can't remove directory\n"); return -1; } @@ -2156,6 +2145,38 @@ gint remove_dir_recursive(const gchar *dir) return 0; } +gint remove_dir_recursive(const gchar *dir) +{ + gchar *cur_dir; + gint ret; + + cur_dir = g_get_current_dir(); + + if (chdir(dir) < 0) { + FILE_OP_ERROR(dir, "chdir"); + ret = -1; + goto leave; + } + if (chdir("..") < 0) { + FILE_OP_ERROR(dir, "chdir"); + ret = -1; + goto leave; + } + + ret = remove_dir_recursive_real(dir); + +leave: + if (is_dir_exist(cur_dir)) { + if (chdir(cur_dir) < 0) { + FILE_OP_ERROR(cur_dir, "chdir"); + } + } + + g_free(cur_dir); + + return ret; +} + gint copy_file(const gchar *src, const gchar *dest, gboolean keep_backup) { FILE *src_fp, *dest_fp; |