summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.bin/cvs/util.c46
1 files changed, 41 insertions, 5 deletions
diff --git a/usr.bin/cvs/util.c b/usr.bin/cvs/util.c
index 6de7a36c86c..f7e50816c2d 100644
--- a/usr.bin/cvs/util.c
+++ b/usr.bin/cvs/util.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: util.c,v 1.98 2007/01/17 17:54:50 joris Exp $ */
+/* $OpenBSD: util.c,v 1.99 2007/01/19 23:55:31 todd Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* Copyright (c) 2005, 2006 Joris Vink <joris@openbsd.org>
@@ -462,10 +462,11 @@ cvs_unlink(const char *path)
int
cvs_rmdir(const char *path)
{
- int ret = -1;
+ int type, ret = -1;
size_t len;
DIR *dirp;
struct dirent *ent;
+ struct stat st;
char fpath[MAXPATHLEN];
if (cvs_server_active == 0)
@@ -488,11 +489,46 @@ cvs_rmdir(const char *path)
if (len >= sizeof(fpath))
fatal("cvs_rmdir: path truncation");
- if (ent->d_type == DT_DIR) {
+ if (ent->d_type == DT_UNKNOWN) {
+ if (stat(fpath, &st) == -1)
+ fatal("'%s': %s", fpath, strerror(errno));
+
+ switch (st.st_mode & S_IFMT) {
+ case S_IFDIR:
+ type = CVS_DIR;
+ break;
+ case S_IFREG:
+ type = CVS_FILE;
+ break;
+ default:
+ fatal("'%s': Unknown file type in copy",
+ fpath);
+ }
+ } else {
+ switch (ent->d_type) {
+ case DT_DIR:
+ type = CVS_DIR;
+ break;
+ case DT_REG:
+ type = CVS_FILE;
+ break;
+ default:
+ fatal("'%s': Unknown file type in copy",
+ fpath);
+ }
+ }
+ switch (type) {
+ case CVS_DIR:
if (cvs_rmdir(fpath) == -1)
goto done;
- } else if (cvs_unlink(fpath) == -1 && errno != ENOENT)
- goto done;
+ break;
+ case CVS_FILE:
+ if (cvs_unlink(fpath) == -1 && errno != ENOENT)
+ goto done;
+ break;
+ default:
+ fatal("type %d unknown, shouldn't happen", type);
+ }
}