From 1f812e4950932f1a163a06b6e2a65b8a4bedbab1 Mon Sep 17 00:00:00 2001 From: drotos Date: Mon, 15 Jan 2007 13:36:51 +0000 Subject: [PATCH] fix of removing sub-direcory git-svn-id: svn+ssh://cvs.lpds.sztaki.hu/var/lib/svn/szdg/dcapi/trunk@1000 a7169a2c-3604-0410-bc95-c702d8d87f7a --- dcapi/condor/condor_utils.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/dcapi/condor/condor_utils.c b/dcapi/condor/condor_utils.c index 5919d07e9a..8b9d5b9c8a 100644 --- a/dcapi/condor/condor_utils.c +++ b/dcapi/condor/condor_utils.c @@ -74,19 +74,29 @@ _DC_rmsubdir(char *name) int i= 0; if ((d= opendir(name)) == NULL) + { + DC_log(LOG_DEBUG, "Open %s: %s", name, strerror(errno)); return(0); + } while ((de= readdir(d))) { if (strcmp(de->d_name, ".") != 0 && strcmp(de->d_name, "..") != 0) { - i+= _DC_rm(de->d_name); + char *s= malloc(strlen(name)+strlen(de->d_name) + 10); + strcpy(s, name); + strcat(s, "/"); + strcat(s, de->d_name); + i+= _DC_rm(s); + free(s); } } closedir(d); if (rmdir(name)) + { DC_log(LOG_ERR, "Failed to rmdir %s: %s", name, strerror(errno)); + } return(i); } @@ -101,11 +111,15 @@ _DC_rm(char *name) return(0); i= lstat(name, &s); if (i != 0) + { return(0); + } if (S_ISDIR(s.st_mode) && strcmp(name, ".") != 0 && strcmp(name, "..") != 0) + { return(_DC_rmsubdir(name)); + } else { if (remove(name))