summaryrefslogtreecommitdiff
path: root/usr.bin/cvs
diff options
context:
space:
mode:
authorXavier Santolaria <xsa@cvs.openbsd.org>2005-05-20 19:58:04 +0000
committerXavier Santolaria <xsa@cvs.openbsd.org>2005-05-20 19:58:04 +0000
commitb7f424bf063934bb2d18aaa8573e5c818abcd8e7 (patch)
tree96e9878006f0de1b63b60098c2d941e95b7e1ec1 /usr.bin/cvs
parent3d89f86f80c6955e03f7e59d31029b021b6f1241 (diff)
cvs_noexec checks; jfb ok
Diffstat (limited to 'usr.bin/cvs')
-rw-r--r--usr.bin/cvs/remove.c4
-rw-r--r--usr.bin/cvs/resp.c29
2 files changed, 18 insertions, 15 deletions
diff --git a/usr.bin/cvs/remove.c b/usr.bin/cvs/remove.c
index 604a20bac90..370c51dc98e 100644
--- a/usr.bin/cvs/remove.c
+++ b/usr.bin/cvs/remove.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: remove.c,v 1.13 2005/05/12 14:04:13 xsa Exp $ */
+/* $OpenBSD: remove.c,v 1.14 2005/05/20 19:58:03 xsa Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* Copyright (c) 2004 Xavier Santolaria <xsa@openbsd.org>
@@ -112,7 +112,7 @@ cvs_remove_file(CVSFILE *cf, void *arg)
if (root->cr_method != CVS_METHOD_LOCAL) {
/* if -f option is used, physically remove the file */
- if (force_remove == 1) {
+ if ((force_remove == 1) && !cvs_noexec) {
if((unlink(fpath) == -1) && (errno != ENOENT)) {
cvs_log(LP_ERRNO,
"failed to unlink `%s'", fpath);
diff --git a/usr.bin/cvs/resp.c b/usr.bin/cvs/resp.c
index d50ca15d3ec..56f10ebd6f5 100644
--- a/usr.bin/cvs/resp.c
+++ b/usr.bin/cvs/resp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: resp.c,v 1.34 2005/05/19 04:17:24 jfb Exp $ */
+/* $OpenBSD: resp.c,v 1.35 2005/05/20 19:58:03 xsa Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -346,20 +346,23 @@ cvs_resp_statdir(struct cvsroot *root, int type, char *line)
return (-1);
}
- if ((type == CVS_RESP_CLRSTATDIR) &&
- (unlink(statpath) == -1) && (errno != ENOENT)) {
- cvs_log(LP_ERRNO, "failed to unlink %s file",
- CVS_PATH_STATICENTRIES);
- return (-1);
- } else if (type == CVS_RESP_SETSTATDIR) {
- fd = open(statpath, O_CREAT|O_TRUNC|O_WRONLY, 0400);
- if (fd == -1) {
- cvs_log(LP_ERRNO,
- "failed to set static directory on %s", line);
+ if (!cvs_noexec) {
+ if ((type == CVS_RESP_CLRSTATDIR) &&
+ (unlink(statpath) == -1) && (errno != ENOENT)) {
+ cvs_log(LP_ERRNO, "failed to unlink %s file",
+ CVS_PATH_STATICENTRIES);
return (-1);
- }
- (void)close(fd);
+ } else if (type == CVS_RESP_SETSTATDIR) {
+ fd = open(statpath, O_CREAT|O_TRUNC|O_WRONLY, 0400);
+ if (fd == -1) {
+ cvs_log(LP_ERRNO,
+ "failed to set static directory on %s",
+ line);
+ return (-1);
+ }
+ (void)close(fd);
+ }
}
return (0);