summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJean-Francois Brousseau <jfb@cvs.openbsd.org>2004-08-13 12:59:29 +0000
committerJean-Francois Brousseau <jfb@cvs.openbsd.org>2004-08-13 12:59:29 +0000
commit3249384e6474f85bc4e60c3ddd1c9afcdf2fa34a (patch)
tree4cac7af5213bf3ac2b1735fe648c309b1a505f5c
parentbd3b8659ff3a01d5debf775e46353ff410de76e5 (diff)
Make add work in client mode
-rw-r--r--usr.bin/cvs/add.c67
1 files changed, 54 insertions, 13 deletions
diff --git a/usr.bin/cvs/add.c b/usr.bin/cvs/add.c
index 733ccdff5f3..41bab1c7198 100644
--- a/usr.bin/cvs/add.c
+++ b/usr.bin/cvs/add.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: add.c,v 1.2 2004/07/30 01:49:21 jfb Exp $ */
+/* $OpenBSD: add.c,v 1.3 2004/08/13 12:59:28 jfb Exp $ */
/*
* Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
* All rights reserved.
@@ -38,6 +38,13 @@
#include "proto.h"
+extern char *__progname;
+
+
+
+int cvs_add_file (CVSFILE *, void *);
+
+
/*
* cvs_add()
@@ -49,7 +56,7 @@
int
cvs_add(int argc, char **argv)
{
- int ch, i, ret;
+ int i, ch, ret;
char *kflag, *msg;
struct cvsroot *root;
@@ -71,23 +78,57 @@ cvs_add(int argc, char **argv)
argc -= optind;
argv += optind;
- if (argc == 0) {
+ if (argc == 0)
return (EX_USAGE);
- }
- root = NULL;
+ cvs_files = cvs_file_getspec(argv, argc, 0);
+ if (cvs_files == NULL)
+ return (EX_DATAERR);
- for (i = 0; i < argc; i++) {
- ret = cvs_sendreq(root, CVS_REQ_ISMODIFIED, argv[i]);
- if (ret < 0)
- return (EX_DATAERR);
- }
+ cvs_file_examine(cvs_files, cvs_add_file, NULL);
+
+ root = CVS_DIR_ROOT(cvs_files);
+
+ for (i = 0; i < argc; i++)
+ cvs_sendarg(root, argv[i], 0);
+ if (cvs_sendreq(root, CVS_REQ_ADD, NULL) < 0)
+ return (-1);
+
+ return (0);
+}
- for (i = 0; i < argc; i++) {
- ret = cvs_sendreq(root, CVS_REQ_ARGUMENT, argv[i]);
+
+int
+cvs_add_file(CVSFILE *cf, void *arg)
+{
+ struct cvsroot *root;
+
+ if (cf->cf_type == DT_DIR) {
+ if (cf->cf_cvstat == CVS_FST_UNKNOWN) {
+ }
+ else {
+ root = cf->cf_ddat->cd_root;
+ if ((cf->cf_parent == NULL) ||
+ (root != cf->cf_parent->cf_ddat->cd_root)) {
+ cvs_connect(root);
+ }
+
+ cvs_senddir(root, cf);
+ }
+
+ return (0);
}
- ret = cvs_sendreq(root, CVS_REQ_ADD, NULL);
+ root = CVS_DIR_ROOT(cf);
+
+ cvs_sendreq(root, CVS_REQ_ISMODIFIED, cf->cf_name);
+
+ if (cvs_cmdop == CVS_OP_SERVER) {
+ cvs_log(LP_INFO, "scheduling file `%s' for addition",
+ cf->cf_name);
+ cvs_log(LP_INFO, "use `%s commit' to add this file permanently",
+ __progname);
+ }
return (0);
}